Скажите, что у меня есть эти данные. Один для округления штатов штата, а другой для построения точек.
library(tidyverse)
library(gganimate)
devtools::install_github("UrbanInstitute/urbnmapr")
library(urbanmapr)
#1. counties dataset for the shading of the background
data(counties)
#keep only Texas counties
counties <- filter(counties, state_fips==48)
#2. dots dataset for dots over time
dots <- data.frame(group = c(rep(1,3), rep(2,3)),
lat = c(rep(32, 3), rep(33, 3)),
long = c(rep(-100, 3), rep(-99,3)),
year = c(1:3, 1:3))
Затем я строю их (сначала не используя gganimate
):
ggplot() +
geom_polygon(data = counties, aes(long, lat, group = county_fips, fill = as.numeric(county_fips))) +
scale_fill_gradient(low = "navy", high = "lightskyblue3") +
geom_point(data = dots, aes(long, lat, group=interaction(long, lat), color=year),
size=6, show.legend = FALSE) +
theme_bw() +
scale_color_gradientn(colours = c("red", "yellow", "darkgreen")) +
coord_map() +
labs(subtitle = paste('Year: {frame_time}')) +
theme(plot.subtitle = element_text(hjust = 0.8, vjust=-10, size=30)) +
theme(panel.background = element_rect(fill = 'white')) +
theme(panel.grid = element_blank(),axis.title = element_blank(),
axis.text = element_blank(),axis.ticks = element_blank(),
panel.border = element_blank())+
theme(legend.position = c(0.15, .15)) +
theme(legend.key.size = unit(2,"line"),legend.title=element_text(size=16),
legend.text=element_text(size=14)) +
labs(fill = "abc")
Вот результат:
![enter image description here](https://i.stack.imgur.com/PWQ7m.png)
Проблема возникает, когда я пытаюсь анимировать точки, используя gganimate
:
map <- ggplot() +
geom_polygon(data = counties, aes(long, lat, group = county_fips, fill = as.numeric(county_fips))) +
scale_fill_gradient(low = "navy", high = "lightskyblue3") +
geom_point(data = dots, aes(long, lat, group=interaction(long, lat), color=year),
size=6, show.legend = FALSE) +
theme_bw() +
scale_color_gradientn(colours = c("red", "yellow", "darkgreen")) +
coord_map() +
labs(subtitle = paste('Year: {frame_time}')) +
theme(plot.subtitle = element_text(hjust = 0.8, vjust=-10, size=30)) +
theme(panel.background = element_rect(fill = 'white')) +
theme(panel.grid = element_blank(),axis.title = element_blank(),
axis.text = element_blank(),axis.ticks = element_blank(),
panel.border = element_blank())+
theme(legend.position = c(0.15, .15)) +
theme(legend.key.size = unit(2,"line"),legend.title=element_text(size=16),
legend.text=element_text(size=14)) +
labs(fill = "abc") +
transition_time(year) +
shadow_mark(size=6)
anim_save("output/test.gif", map, end_pause=6, width = 800, height = 800, duration=8)
Обратите внимание, что этоточно так же, за исключением строк transition_time
и shadow_mark
. Вот результат:
![enter image description here](https://i.stack.imgur.com/IgR5B.gif)
Цвета фона ОЧЕНЬ разные. Это может быть тот случай, когда цвета поменялись местами или что-то;Я не уверена. Тем не менее, в моем реальном примере, использующем намного больше точек и различных значений для затенения, затенение имеет небольшое сходство с фактическими данными. Что в мире происходит и как я могу это исправить?