[Rd] Clipping using par(plt=..., xpd=FALSE) inconsistencies

Prof Brian Ripley ripley at stats.ox.ac.uk
Mon Feb 25 22:06:00 CET 2008


The following works in R-devel

      x <- rnorm(1000)
      hist(x, xlim=c(-4,4))
      usr <- par("usr")
      clip(usr[1], -2, usr[3], usr[4])
      hist(x, col = 'red', add = TRUE)
      clip(2, usr[2], usr[3], usr[4])
      hist(x, col = 'blue', add = TRUE)
      do.call("clip", as.list(usr))  # reset to plot region

I think that is a general enough mechanism -- see its help page for how 
long one can expect a clipping region to persist.

On Fri, 22 Feb 2008, Prof Brian Ripley wrote:

> I think you misunderstand what par("plt") is supposed to do.  The 
> documentation says
>
>     'plt' A vector of the form 'c(x1, x2, y1, y2)' giving the
>          coordinates of the plot region as fractions of the current
>          figure region.
>
> You haven't subsequently made a new plot, so why do you expect the clipping 
> region to be changed to that you indicated for the next plot?
>
> I'd say the bug was that box() changed it, and that happens because it 
> internally sets xpd and so resetting xpd sets the clipping region next time 
> it is used.  Because of
>
> void GClip(pGEDevDesc dd)
> {
>    if (gpptr(dd)->xpd != gpptr(dd)->oldxpd) {
> 	double x1, y1, x2, y2;
> 	setClipRect(&x1, &y1, &x2, &y2, DEVICE, dd);
> 	GESetClip(x1, y1, x2, y2, dd);
> 	gpptr(dd)->oldxpd = gpptr(dd)->xpd;
>    }
> }
>
> Maybe we should have user-level code to set the clipping region?
>
>
> On Fri, 22 Feb 2008, Greg Snow wrote:
>
>> Here is a demonstration of behaviour that is probably an optimization by
>> someone far smarter than me that did not anticipate anyone wanting to do
>> this, but for my purposes it looks more like a bug than a feature.
>> 
>> I have tested this with R2.6.2 on Windows, no additional packages loaded
>> (beyond the default), I have tested using the default graphics object,
>> pdf, jpeg, and cairoDevice (ok I loaded a package for that) and all show
>> the same behavior.
>> 
>> Run the following set of commands:
>> 
>> x <- rnorm(1000)
>> hist(x, xlim=c(-4,4))
>> 
>> tmp <- par('plt')
>> 
>> box(col='#00000000')
>> tmp2 <- tmp
>> tmp2[2] <- tmp2[1] + 0.3
>> par(xpd = FALSE, plt=tmp2)
>> hist(x, col='red', add=TRUE)
>> 
>> box(col='#00000000')
>> tmp3 <- tmp
>> tmp3[1] <- tmp3[2] - 0.3
>> par(xpd=FALSE, plt=tmp3)
>> hist(x, col='blue', add=TRUE)
>> par(plt=tmp)
>> 
>> 
>> This gives me the plot that I want and expect (a histogram with the left
>> section red, the middle white/background, and the right blue).
>> 
>> Now comment out or delete the 2 box commands and rerun everything.  The
>> clipping does not happen this time and the final result is a full blue
>> histogram.
>> 
>> Is this a bug? Feature? Something else?
>> Does anyone have a better work around than drawing transparent boxes?
>> 
>> Thanks,
>> 
>> 
>> 
>> 
>
> -- 
> Brian D. Ripley,                  ripley at stats.ox.ac.uk
> Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
> University of Oxford,             Tel:  +44 1865 272861 (self)
> 1 South Parks Road,                     +44 1865 272866 (PA)
> Oxford OX1 3TG, UK                Fax:  +44 1865 272595
>

-- 
Brian D. Ripley,                  ripley at stats.ox.ac.uk
Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
University of Oxford,             Tel:  +44 1865 272861 (self)
1 South Parks Road,                     +44 1865 272866 (PA)
Oxford OX1 3TG, UK                Fax:  +44 1865 272595



More information about the R-devel mailing list