是的,这样做的一种方法是使用ggplot
.
ggplot
要求您的数据采用data.frame
格式。在此data.frame
我添加一列col
,指示您想要的颜色。然后用ggplot
, geom_line
,构造图,scale_colour_identity
因为 col 变量已经是一种颜色:
library(ggplot2)
df <- data.frame(
x = 1:100,
y = rnorm(100,1,100),
col = c(rep("red", 50), rep("black", 10), rep("red", 40))
)
ggplot(df, aes(x=x, y=y)) +
geom_line(aes(colour=col, group=1)) +
scale_colour_identity()
data:image/s3,"s3://crabby-images/bc0cc/bc0cc67202cd4e3b616ece3c085581312cb6d604" alt="在此处输入图像描述"
更一般地,每个线段可以是不同的颜色。在下一个示例中,我将颜色映射到 x 值,给出一个将颜色从蓝色平滑更改为红色的绘图:
df <- data.frame(
x = 1:100,
y = rnorm(100,1,100)
)
ggplot(df, aes(x=x, y=y)) + geom_line(aes(colour=x))
data:image/s3,"s3://crabby-images/3fad0/3fad0e5b863e2f5ac57861ffd31408390a636672" alt="在此处输入图像描述"
如果你坚持使用基础图形,那么使用segments
如下:
df <- data.frame(
x = 1:100,
y = rnorm(100,1,100),
col = c(rep("red", 50), rep("black", 10), rep("red", 40))
)
plot(df$x, df$y, type="n")
for(i in 1:(length(df$x)-1)){
segments(df$x[i], df$y[i], df$x[i+1], df$y[i+1], col=df$col[i])
}
data:image/s3,"s3://crabby-images/318be/318be7ca36b78f28adb71b00d099d4372c2e247b" alt="在此处输入图像描述"