4

我正在尝试使用从 Rcolorbrewer 包中获取的已定义配色方案绘制栅格,到目前为止没有问题。栅格的值范围从 0 到 1,没有 NA。

library(RColorBrewer)
library(classInt)

pal <- brewer.pal(n=50, name = "RdYlGn")
plot(rw_start_goal_stan, col=pal)

在此处输入图像描述

现在我尝试包含分位数中断,我使用 ClassInt 包计算

library(RColorBrewer)
library(classInt)

pal <- brewer.pal(n=50, name = "RdYlGn")
breaks.qt <- classIntervals(rw_start_goal_stan@data@values, style = "quantile")
plot(rw_start_goal_stan, breaks = breaks.qt$brks, col=pal)

错误地,plot() 仅将配色方案应用于值范围的 50%,其余部分保持白色。

在此处输入图像描述

我究竟做错了什么?

4

1 回答 1

1

编辑:使用此答案中的 OP 和rasterVis::levelplot解决方案提供的数据

library(raster)
library(rasterVis)
library(classInt)

plotVar <- raster("LCPs_standartized.tif")

nColor <- 50
break1 <- classIntervals(plotVar[!is.na(plotVar)], 
                         n = nColor, style = "quantile")

lvp <- levelplot(plotVar, 
                 col.regions = colorRampPalette(brewer.pal(9, 'RdYlGn')), 
                 at = break1$brks, margin = FALSE)
lvp 

在此处输入图像描述


您需要指定颜色的数量,classIntervals然后为该classInterval对象分配颜色代码。

library(RColorBrewer)
library(classInt)

plotVar <- rw_start_goal_stan@data@values
nColor <- 50
plotColor <- brewer.pal(nColor, name = "RdYlGn")

# equal-frequency class intervals
class <- classIntervals(plotVar, nColor, style = "quantile")
# assign colors to classes from classInterval object
colorCode <- findColours(class, plotColor)

# plot
plot(rw_start_goal_stan)
plot(rw_start_goal_stan, col = colorCode, add = TRUE)

# specify the location of the legend, change -117 & 44 to numbers that fit your data
legend(-117, 44, legend = names(attr(colorCode, "table")),
  fill = attr(colorCode, "palette"), cex = 0.8, bty = "n")

资料来源:R 中的地图

于 2018-04-19T01:44:33.360 回答