Colorbar из пользовательского colorRampPalette - PullRequest
16 голосов
/ 16 февраля 2012

Я определил colorRampPalette:

my.colors = colorRampPalette(c("light green", "yellow", "orange", "red"))

Как я могу построить для него элемент «легенды» на цветной панели, желательно используя только базовые пакеты? Я за прямоугольником, заполненным этим цветным градиентом.

Что мне действительно нужно, так это способ создать легенду того же типа (цветную полосу), которая наносится растровым растром:

require(raster)
plot(raster("myfile.tif"), legend=T)

Мне нужно иметь возможность разместить это поверх другого графика.

Ответы [ 4 ]

27 голосов
/ 16 февраля 2012

Некоторое время назад я сделал хорошую гибкую функцию для этого.

# 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)
    }
}

Затем вы можете сделать что-то вроде:

> color.bar(colorRampPalette(c("light green", "yellow", "orange", "red"))(100), -1)

enter image description here

Подробнеепримеры по адресу: http://www.colbyimaging.com/wiki/statistics/color-bars

9 голосов
/ 16 февраля 2012

Сделать матрицу, использовать изображение с некоторыми параметрами осей ...

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)

image legend

4 голосов
/ 21 июля 2014

colorbar.plot () из пакета полей является стандартным решением. Многие люди будут искать здесь решения, которые размещают легенду за пределами стандартной области графика или исходного диапазона х / у. Это ограничение colorbar.plot () легко преодолевается с помощью:

  1. изображение вашего изображения (),
  2. расширение размера графического устройства с параметром par (pin = c (width, length))
  3. вызов colorbar.plot () с использованием оригинальных значений x и y

Поскольку область устройства печати теперь расширена, легенда появится за пределами исходного изображения () графика. Экспериментируя со значениями x и y, вы можете получить легенду где угодно. Легенда градиента может быть горизонтальной или вертикальной, используя стандартные параметры аргумента.

0 голосов
/ 14 декабря 2014

Я знаю, что это очень старый вопрос, и ответы на него все великолепны.Я просто хотел отметить, что вы можете просто сгладить цветную полосу от levelplot.

Создание поддельных данных и цветового градиента

mat = matrix(rnorm(400,1,1), ncol=20)
grad = rev(rainbow(1000, start=rgb2hsv(col2rgb('green'))[1], 
       end=rgb2hsv(col2rgb('blue'))[1]))

Создание графика и указание разрывов на цветовой шкале

levelplot(mat, col.regions=grad, colorkey = list(at=seq(0,max(mat),length.out=400)))

Эта функциональность для levelplot может иметьбыл добавлен долго после того, как все вы, ребята, придумали сладкие обходные решения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...