Tunnel
Recursive viewport scaling and rotating
data:image/s3,"s3://crabby-images/0edb8/0edb871db321dc5a6abaf4a7336f2ce85e764570" alt=""
Inspired by Päivi Julin.
Sample generated images:
data:image/s3,"s3://crabby-images/c3225/c322572fa919a1643cdf6b59687458aa4905e3bb" alt=""
data:image/s3,"s3://crabby-images/bbeae/bbeae3c7c01a6c7dfc592d32b34dc0a97294b758" alt=""
data:image/s3,"s3://crabby-images/40608/406081ef122a237193cce0fee1280337f35aa1f0" alt=""
library(grid)
## Number of frames
N <- 500
## Number of colors
k <- 100
## N/k is number of times color palette will repeat
## Some sample colors
colors <- rep(rainbow(k, s=0.8), N/k)
#colors <- rep(colorRampPalette(c('orange','yellow', 'darkorange'))(k), N/k)
#colors <- rep(colorRampPalette(c('white', 'pink', 'white', 'lightblue', 'white'))(k), N/k)
#colors <- colorRampPalette(c('beige', 'forestgreen', 'darkgreen'))(N)
## Draw background
dev.new()
pushViewport(viewport(width=1, height=1, angle=0))
grid.rect(gp = gpar(col = NA, fill = colors[1]))
## Scale viewport and rotate
for(i in 2:N){
## Optionally try increasing the angle or increasing the scale rate
pushViewport(viewport(width=0.99, height=0.99, angle=1))
# Optionally try: grid.circle(), grid.roundedrect()
grid.rect(
# Optionally shift: x = 0, y = 1,
gp = gpar(col = NA, fill = colors[i])
)
}
data:image/s3,"s3://crabby-images/d6f19/d6f19bafe639ddc52735befbba988cfabe6eae3d" alt=""