- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试制作动画来展示人均 GDP 排名前 10 的国家。我可以制作如下 gif。我想在 y 轴的左侧制作国家标签。我怎样才能做到这一点?
这是我的代码:
install.packages("ggplot2")
install.packages("data.table")
install.packages("gapminder")
library(gapminder)
library(ggplot2)
library(data.table)
gapminder10 = gapminder[,.SD[order(gdpPercap,decreasing = TRUE),][1:10],by = year]
gapminder10[, rank := 1:.N, by = year]
p <- ggplot(gapminder10) +
geom_bar(aes(x=gdpPercap, y=rank, fill = country), stat = "identity")+ # I need to use geom_bar to make the bar
geom_text(aes(x=0, y=rank, label = country), vjust = 0.2, hjust = "inward", size = 4) +
labs(x = "GDP per capita", y = "country")+
scale_y_reverse() + # reverse the y-axis
theme(legend.position="none", axis.text.y=element_blank(), axis.title.y=element_blank(),
axis.ticks=element_blank(),panel.background=element_blank())
g<-p + transition_time(year) +
labs(title = "Year: {frame_time}")
animate(g, nframes = 350,fps = 20, renderer = gifski_renderer())
最佳答案
通过 geom_text
贴标签在 y 轴的左侧可以这样实现:
hjust = 1
.x = -1000
在标签和轴之间添加了一些空间expand
增加规模的扩展来实现。 scale_x_continuous
的论据.我将低端的扩展增加到 20%,同时在高端保持默认的 5%。x = -1000
时出现负值中断在 geom_text 中,我通过 breaks = seq(0, 90000, 10000)
强制中断从 0 开始.scale_y_reverse
我转换了
rank
到一个因素并使用
forcats::fct_rev
颠倒顺序。
library(gapminder)
library(ggplot2)
library(gganimate)
library(dplyr)
library(forcats)
gapminder10 <- gapminder %>%
group_by(year) %>%
top_n(10, gdpPercap) %>%
arrange(year, desc(gdpPercap)) %>%
mutate(rank = row_number(),
rank = fct_rev(factor(rank))) %>%
ungroup()
p <- gapminder10 %>%
ggplot() +
geom_bar(aes(x=gdpPercap, y = rank, fill = country), stat = "identity")+ # I need to use geom_bar to make the bar
geom_text(aes(x = -1000, y = rank, label = country), vjust = 0.2, hjust = 1, size = 4) +
labs(x = "GDP per capita", y = NULL) +
scale_x_continuous(breaks = seq(0, 90000, 10000), expand = expansion(mult = c(.2, 0.05))) +
theme(legend.position="none",
axis.text.y = element_blank(),
axis.title.y=element_blank(),
axis.ticks=element_blank(),panel.background=element_blank())
g<-p + transition_time(year) +
labs(title = "Year: {frame_time}")
animate(g, nframes = 50, fps = 20, renderer = gifski_renderer())
关于r - 如何在 y 轴的左侧制作 geom_text,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62578368/
我正在使用这段代码: border-right:0px solid #ddd; height:85px; box-shadow :5px 5px 10px 1px #eaeaea; 但我刚刚得到
我遇到的问题是将文本放在图像的左侧... HTML 和 CSS h2, social-hand { font-family: 'PT Sans', sans-serif; display: i
美好的一天 我今天的 CSS 很糟糕。我有 3 列 div(水平,这就是我使用 float 的原因),但我想将我的文本居中对齐,但在包含列 div 的左侧。 HTML:
在我的应用程序中,我在截取屏幕截图时在我的 Imageview 中获得了透明像素。如何剪切顶部、左侧、右侧 和 Imageview 的底部。我尝试了下面的代码但没有工作 Bitmap bitmap =
如何在左侧的以下 LinearLayout 内部添加边框,使其宽度为 5dp 并适合 LinearLayout 的整个高度? LinearLayout 的高度是动态的,这意味着有时它可以是 50dp
我是第一次做网站。我在使用下拉菜单时遇到问题。它正在向左侧移动。请帮助我处理代码,使其位于导航菜单的正下方,并且将鼠标悬停在其上时应该可见。提前致谢。 这是我的 CSS 代码: ul { li
我对 html 和 css 有点生疏,我无法让 2 个图像 float ,一个在另一个之上。这是代码...   &nbs
我有一个固定宽度 (px) 的左侧边栏,右侧是我的主要内容。 这是我的演示:http://jsfiddle.net/fxWg7/4031/ 代码如下: 这是我的 html 代码: left co
所以我正在尝试做一个弹出式菜单,但我遇到了一点问题。 我已经申请了: .menu-side, .menu { -webkit-transition: left 0.2s ease; -
在下面的 CSS @media screen and (max-width: 750px) { .flexbox { display: block; } .menu ul {
@import 'https://fonts.googleapis.com/css?family=PT+Sans'; * { font-family: 'PT Sans', sans-serif
我想在我的标题旁边放一个图标。但它不合适..我怎样才能让它合适? My heading 最佳答案 使用vertical-align:middle,因此如果您更改文本或图像的大小,位
我正在使用参数方程围绕一个圆定位图像 ( How do I calculate a point on a circle’s circumference? ) 我使用简单的数学方法以更少的方式完成此操作
我想使用外部列表属性将 ul 列表正确定位在左浮动 img 的右侧,但元素符号未在图像右侧对齐,因为没有任何图像,但更多在左边。 Lorem ipsum dolor sit amet, c
我有一个layer-list.xml 现在我想在运行时更改 (top,right) 等项目的
我通过按:M-x linum-mode 来启用它们。如何将其“翻译”到 my.emacs 文件中,以便每次打开 EMACS 时自动启用它? 最佳答案 如果您希望每个缓冲区都使用它,请将 (global
我的Code : HTML 1 2 3 CSS #score { height:50px; } .myDiv { width:40px; height:40px;
我可以轻松设置 canvas.width 和 canvas.height 属性。我找不到正确的 JavaScript 语法来使用顶部和左侧设置 Canvas 的偏移量。我尝试过直接在 Canvas 上
我正在尝试为我正在编写的单人纸牌游戏完成条件游戏。 我把所有的 Action 和棋子都移除了。每一 block 都作为椭圆 UI 元素保存在一个二维数组中,当一 block 被拿走时,它会被替换为边框
我正在使用导航 View 修改 Android 应用程序。对于前几个菜单项,我给出了一个图标,但之后,我只给出了菜单标题。但是在导航面板中,没有图标的菜单项有一个空白区域。 如何删除空白区域?我希望菜
我是一名优秀的程序员,十分优秀!