ggplot2繪制環(huán)狀條形圖(進(jìn)階)

本節(jié)繼續(xù)介紹通過ggplot2來繪制環(huán)狀條形圖浪听,重點(diǎn)使用annotate函數(shù)對數(shù)據(jù)進(jìn)行注釋

library(tidyverse)

自定義顏色

colors <-c("#FED439FF","#709AE1FF",
           "#D5E4A2FF","#197EC0FF","#F05C3BFF","#46732EFF",
           "#71D0F5FF","#370335FF","#075149FF","#C80813FF","#91331FFF",
           "#1A9993FF","#FD8CC1FF")

構(gòu)建數(shù)據(jù)

data1 <- mtcars %>% head(6) %>% 
  mutate_if(is.numeric, function(x) x+10) %>% 
  log10() %>% as.data.frame() %>% 
  rownames_to_column("type") %>%
  pivot_longer(-type) %>% arrange(name) %>% 
  mutate(type=factor(type))

計(jì)算角度

empty_bar <- 0
data1$id <- seq(1,nrow(data1))
label_data <- data1
number_of_bar <- nrow(label_data)
angle <-  90 - 360 * (label_data$id-0.5) /number_of_bar    
label_data$hjust<-ifelse( angle < -90, 1, 0)
label_data$angle<-ifelse(angle < -90, angle+180, angle)

構(gòu)建分組線段

df <- data1 %>% 
  group_by(name) %>% 
  summarize(start=min(id), end=max(id) - empty_bar) %>% 
  rowwise() %>% 
  mutate(title=mean(c(start,end))) %>% 
  mutate(name=as.factor(name))

數(shù)據(jù)可視化

ggplot(data1,aes(id,value,fill=type))+
  geom_bar(stat="identity",alpha=0.8)+
  scale_fill_manual(values = colors)+
  labs(x=NULL,y=NULL)+
  ylim(-7,8)+
  coord_polar(start = 0)+
  theme_void()+
  theme(
  legend.text = element_text(color="black"),
  legend.title=element_blank(),
  legend.spacing.x=unit(0.2,'cm'),
  legend.key=element_blank(),
  legend.key.width=unit(0.3,'cm'),
  legend.key.height=unit(0.3,'cm'),
  legend.position=c(0.5,0.5))+
  # 添加分組線段
 # geom_segment(data=df,aes(x = start,y =-0.3,xend = end,yend =-0.3),
 #              colour = "black",alpha=0.8,size=0.5,inherit.aes = FALSE)+
  # 添加標(biāo)簽
  geom_text(data=label_data,aes(x=id, y=value+0.5,label=type, hjust=hjust), 
            color="black", fontface="plain",size=2.5, 
            angle= label_data$angle, inherit.aes = FALSE )+
  # 添加文本
  annotate("text",x=4,y=-0.8,label="A",angle=-35,size=3.5,color="black")+
  annotate("text",x=10,y=-0.8,label="B",angle=-50,size=3.5,color="black")+
  # 添加外圈
  geom_segment(aes(x=0, y=8,xend=66.5,yend =8),size=1.5,color="#3B9AB2",
    arrow = arrow(length = unit(0, "npc"),type="closed"))+
  # 添加豎線
  annotate("segment",x=0,xend =0,y=-3,yend =8,colour="#FF0000")+
  annotate("segment",x=6.5,xend =6.5,y=-3,yend =8,colour="#00A08A")+
  annotate("segment",x=12.5,xend =12.5,y=-3,yend=8,colour="#FF0000")+
  annotate("segment",x=18.5,xend =18.5,y=-3,yend =8,colour="#00A08A")+
  annotate("segment",x=24.5,xend =24.5,y=-3,yend =8,colour="#FF0000")+
  annotate("segment",x=30.5,xend =30.5,y=-3,yend =8,colour="#00A08A")+
  annotate("segment",x=36.5,xend =36.5,y=-3,yend =8,colour="#FF0000")+
  annotate("segment",x=42.5, xend =42.5,y=-3,yend =8,colour="#00A08A")+
  annotate("segment",x=48.5,xend =48.5,y=-3,yend =8,colour="#FF0000")+
  annotate("segment",x=54.5,xend =54.5,y=-3,yend =8,colour="#00A08A")+
  annotate("segment",x=60.5,xend =60.5,y=-3,yend =8,colour="#FF0000")+
  # 添加內(nèi)圈
  geom_segment(aes(x=0, y=-3,xend=66.5,yend =-3),size=0.5,color="#3B9AB2",
               arrow = arrow(length = unit(0, "npc"),type="closed"))+
  geom_segment(aes(x=0, y=-0.1,xend=66.5,yend =-0.1),size=0.5,color="black",
               arrow = arrow(length = unit(0, "npc"),type="closed"))
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子我碟,更是在濱河造成了極大的恐慌拔疚,老刑警劉巖伶唯,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異昂羡,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)摔踱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進(jìn)店門虐先,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人派敷,你說我怎么就攤上這事蛹批。” “怎么了篮愉?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵腐芍,是天一觀的道長。 經(jīng)常有香客問我试躏,道長猪勇,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任颠蕴,我火速辦了婚禮埠对,結(jié)果婚禮上络断,老公的妹妹穿的比我還像新娘。我一直安慰自己项玛,他們只是感情好貌笨,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著襟沮,像睡著了一般锥惋。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上开伏,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天膀跌,我揣著相機(jī)與錄音,去河邊找鬼固灵。 笑死捅伤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的巫玻。 我是一名探鬼主播丛忆,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼仍秤!你這毒婦竟也來了熄诡?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤诗力,失蹤者是張志新(化名)和其女友劉穎凰浮,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體苇本,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡袜茧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瓣窄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片笛厦。...
    茶點(diǎn)故事閱讀 39,965評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖康栈,靈堂內(nèi)的尸體忽然破棺而出递递,到底是詐尸還是另有隱情,我是刑警寧澤啥么,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布登舞,位于F島的核電站,受9級特大地震影響悬荣,放射性物質(zhì)發(fā)生泄漏菠秒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望践叠。 院中可真熱鬧言缤,春花似錦、人聲如沸禁灼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽弄捕。三九已至僻孝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間守谓,已是汗流浹背穿铆。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留斋荞,地道東北人荞雏。 一個(gè)月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像平酿,于是被迫代替她去往敵國和親凤优。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容