自定义colorRampPalette的Colorbar

Ben*_*min 17 r colors

我已经定义了colorRampPalette:

my.colors = colorRampPalette(c("light green", "yellow", "orange", "red"))
Run Code Online (Sandbox Code Playgroud)

如何为其绘制颜色条"图例"项目,最好只使用基础包?我在一个充满了颜色渐变的矩形之后.

我真正想要的是一种生成相同类型的图例(颜色条)的方法,该图例使用"光栅"栅格绘制:

require(raster)
plot(raster("myfile.tif"), legend=T)
Run Code Online (Sandbox Code Playgroud)

我需要能够把它置于另一个情节之上.

Joh*_*lby 28

我前一段时间做了一个很好的灵活功能来做到这一点.

# Function to plot color bar
color.bar <- function(lut, min, max=-min, nticks=11, ticks=seq(min, max, len=nticks), title='') {
    scale = (length(lut)-1)/(max-min)

    dev.new(width=1.75, height=5)
    plot(c(0,10), c(min,max), type='n', bty='n', xaxt='n', xlab='', yaxt='n', ylab='', main=title)
    axis(2, ticks, las=1)
    for (i in 1:(length(lut)-1)) {
     y = (i-1)/scale + min
     rect(0,y,10,y+1/scale, col=lut[i], border=NA)
    }
}
Run Code Online (Sandbox Code Playgroud)

然后你可以这样做:

> color.bar(colorRampPalette(c("light green", "yellow", "orange", "red"))(100), -1)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

更多示例:http://www.colbyimaging.com/wiki/statistics/color-bars

  • 如果您取出dev.new,您可以使用包中的子图:Hmisc将其叠加到现有图上. (4认同)

Spa*_*man 9

制作一个矩阵,使用带有某些轴参数的图像......

my.colors = colorRampPalette(c("light green", "yellow", "orange", "red"))
z=matrix(1:100,nrow=1)
x=1
y=seq(3,2345,len=100) # supposing 3 and 2345 are the range of your data
image(x,y,z,col=my.colors(100),axes=FALSE,xlab="",ylab="")
axis(2)
Run Code Online (Sandbox Code Playgroud)

图像传奇