DrawCircle.Rd
Draw one or several circle on an existing plot.
a vector (or scalar) of xy-coordinates for the center(s) of the circle(s).
a vector (or scalar) of the outer radius of the circle.
a vector (or scalar) of a potential inner radius of an annulus.
a vector (or scalar) of the starting angle(s). The sectors are built counterclockwise.
a vector (or scalar) of the ending angle(s).
number of vertices to draw the circle.
color for circle borders. The default is par("fg"). Use border = NA
to omit borders.
color(s) to fill or shade the circle(s) with. The default NA
(or also NULL) means
do not fill, i.e., draw transparent circles, unless density is specified.
line type for borders and shading; defaults to "solid"
.
line width for borders and shading.
logical. If TRUE
the structure will be plotted. If FALSE
only the points are
calculated and returned. Use this option if you want to combine several geometric
structures to a polygon.
All geometric arguments will be recycled.
The function invisibly returns a list of the calculated coordinates for all shapes.
Canvas(xlim = c(-5,5), xpd=TRUE)
cols <- Pal("Helsana")[1:4]
# Draw ring
DrawCircle (r.in = 1, r.out = 5, border="darkgrey",
col=SetAlpha(DescTools::hyellow, 0.2), lwd=2)
# Draw circle
DrawCircle (r.in = 6, border=DescTools::hgreen, lwd=3)
# Draw sectors
geom <- rbind(c(-pi, 0, .25, .5), c(0, pi, 1, 2),
c(-pi/2, pi/2, 2, 2.5), c(pi/2, 3 * pi/2, 3, 4),
c(pi - pi/8, pi + pi/8, 1.5, 2.5))
DrawCircle (r.in = geom[,3], r.out = geom[,4],
theta.1 = geom[,1], theta.2 = geom[,2],
col = SetAlpha(cols, 0.6),
border = cols, lwd=1)
# clipping
Canvas(bg="lightgrey", main="Yin ~ Yang")
DrawCircle (r.out = 1, col="white")
clip(0, 2, 2, -2)
DrawCircle(col="black")
clip(-2, 2, 2, -2)
DrawCircle (y = c(-0.5,0.5), r.out = 0.5, col=c("black", "white"), border=NA)
DrawCircle (y = c(-0.5,0.5), r.out = 0.1, col=c("white", "black"), border=NA)
DrawCircle ()
# overplotting circles
Canvas(xlim=c(-5,5))
DrawCircle (r.out=4:1, col=c("white", "steelblue2", "white", "red"), lwd=3, nv=300)
# rotation
x <- seq(-3, 3, length.out=10)
y <- rep(0, length.out=length(x))
Canvas(xlim=c(-5,5), bg="black")
sapply( (0:11) * pi/6, function(theta) {
xy <- Rotate(x, y=y, theta=theta)
DrawCircle (x=xy$x, y=xy$y, r.in=2.4, border=SetAlpha("white", 0.2))
} )
#> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10]
#> [1,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [2,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [3,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [4,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [5,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [6,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [7,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [8,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [9,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [10,] list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2 list,2
#> [,11] [,12]
#> [1,] list,2 list,2
#> [2,] list,2 list,2
#> [3,] list,2 list,2
#> [4,] list,2 list,2
#> [5,] list,2 list,2
#> [6,] list,2 list,2
#> [7,] list,2 list,2
#> [8,] list,2 list,2
#> [9,] list,2 list,2
#> [10,] list,2 list,2