[R-sig-Geo] Unit of parameters in the expandBB argument
Roger Bivand
Roger@B|v@nd @end|ng |rom nhh@no
Wed Feb 28 10:40:28 CET 2024
On Wed, 28 Feb 2024, Edzer Pebesma wrote:
>
>
> On 28/02/2024 06:04, Xiang Ye via R-sig-Geo wrote:
>> Dear community,
>>
>> I recently revisited the expandBB argument in the plot() function for sf
>> objects. It conveys a numeric vector of length 4 to expand the default
>> canvas (in the order of bottom, left, top, right) when drawing an sf
>> object. A quick refresh is here:
>>
>> https://r.geocompx.org/spatial-class#:~:text=to%20geographic%20data.-,expandBB,-%2C%20for%20example%2C%20can
>> [https://r.geocompx.org/images/cover.png]<https://r.geocompx.org/spatial-class#:~:text=to%20geographic%20data.-,expandBB,-%2C%20for%20example%2C%20can>
>> Chapter 2 Geographic data in R | Geocomputation with
>> R<https://r.geocompx.org/spatial-class#:~:text=to%20geographic%20data.-,expandBB,-%2C%20for%20example%2C%20can>
>> Prerequisites This is the first practical chapter of the book, and
>> therefore it comes with some software requirements. You need access to a
>> computer with a recent version of R installed (R 4.3.2...
>> r.geocompx.org
>>
>> I am curious about the unit for the four values of the expandBB argument.
>> In the help document, it only says the values are "fraction values to
>> expand the bounding box with":
>>
>> https://r-spatial.github.io/sf/reference/plot.html#:~:text=fractional%20values%20to%20expand%20the%20bounding%20box%20with
>> [https://r-spatial.github.io/sf/logo.png]<https://r-spatial.github.io/sf/reference/plot.html#:~:text=fractional%20values%20to%20expand%20the%20bounding%20box%20with>
>> plot sf object ��
>> plot<https://r-spatial.github.io/sf/reference/plot.html#:~:text=fractional%20values%20to%20expand%20the%20bounding%20box%20with>
>> plot one or more attributes of an sf object on a map Plot sf object
>> r-spatial.github.io
>>
>> However, it did not explicitly mention the unit adopted for the values.
>>
>> My guess:
>> For the 1st and 3rd values in the argument, the unit is the height of the
>> bounding box of the sf object; therefore a value of 0.2 expands (downward
>> and upward, respectively) the canvas by 20% of the height of the bounding
>> box.
>> For the 2nd and 4th values in the argument, the unit is the width of the
>> bounding box of the sf object; therefore a value of 0.2 expands (leftward
>> and rightward, respectively) the canvas by 20% of the width of the
>> bounding box.
>>
>> Is my understanding correct?
>
> Yes. It takes 4 values for each of the sides (bottom, left, top, right). You
> can use xlim and ylim to set the plot region in spatial coordinates.
>
The code is at:
https://github.com/r-spatial/sf/blob/bd1940f68dd7607b7e9098ccc32c99e273c30a60/R/plot.R#L598-L611
based on the equivalent in sp:
https://github.com/edzer/sp/blob/e60dedf3ff3d06d9ebd9d38818b072e4475758cf/R/Spatial-methods.R#L211-L226
and added in a commit 8 years ago:
https://github.com/edzer/sp/commit/d65045951bfebf28fbd5d0ad56bfff3cb48d57a8.
So the units are implicitly those of sp::bbox() and sf::st_bbox().
Roger
>>
>> Thank you in advance!
>>
>> Ҷ�� YE, Xiang
>> THINKING
>> SPATIALLY<http://www.linkedin.com/in/spatialyexiang>.
>> Ph.D. in Spatial Statistics
>>
>> [[alternative HTML version deleted]]
>>
>>
>> _______________________________________________
>> R-sig-Geo mailing list
>> R-sig-Geo using r-project.org
>> https://stat.ethz.ch/mailman/listinfo/r-sig-geo
>
>
--
Roger Bivand
Emeritus Professor
Department of Economics, Norwegian School of Economics,
Postboks 3490 Ytre Sandviken, 5045 Bergen, Norway.
e-mail: Roger.Bivand using nhh.no
More information about the R-sig-Geo
mailing list