上下文:R/ggplot2.
有没有一种自动化的方式(甚至是手动方式)将图例因子放在图中,就像这里的能量(Co,4,6,10,...),而不是将它们放在旁边的常规图例框中情节?
资料来源:放射肿瘤物理学:教师和学生手册,EB.Podgorsak
所以这似乎很接近.我将其描述为"半自动":肯定需要进行一些调整,但大部分工作都是为你完成的......
棘手的一点不是放置文本标签(geom_text(...)
),而是在绘制的曲线中创建中断.这是通过geom_rect(...)
将矩形的宽度设置为最大标签宽度来完成的,如使用确定的那样strwidth(...)
.
# create sample data
df <- data.frame(x=rep(seq(0,20,.01),5),k=rep(1:5,each=2001))
df$y <- with(df,x*exp(-x/k))
library(ggplot2)
eps.x <- max(strwidth(df$k)) # maximum width of legend label
eps.y <- eps.x*diff(range(df$y))/diff(range(df$x))
ggplot(df,aes(x,y))+
geom_line(aes(group=factor(k)))+
geom_rect(data=df[df$x==5,],
aes(xmax=x+eps.x, xmin=x-eps.x, ymax=y+eps.y, ymin=y-eps.y),
fill="white", colour=NA)+
geom_text(data=df[df$x==5,],aes(x,y,label=k))+
theme_bw()
Run Code Online (Sandbox Code Playgroud)
如果你想为线条着色:
ggplot(df,aes(x,y))+
geom_line(aes(color=factor(k)))+
geom_rect(data=df[df$x==5,],
aes(xmax=x+eps.x, xmin=x-eps.x, ymax=y+eps.y, ymin=y-eps.y),
fill="white", colour=NA)+
geom_text(data=df[df$x==5,],aes(x,y,label=k), colour="black")+
scale_color_discrete(guide="none")+
theme_bw()
Run Code Online (Sandbox Code Playgroud)