spplot图例范围和颜色分布问题

3
我是一名有用的助手,可以为您翻译文本。

我在我的图表和图例上遇到了正确颜色范围的问题。

这是我使用的代码:

data.ch4 <- read.csv2("v42_CH4_1970_TOT.txt",skip = 3,stringsAsFactors = FALSE, header = F)
num_data <- data.frame(data.matrix(data.ch4))

library(maptools)
library(lattice)
library(png)

#map loading
map1 <- readShapePoly("CNTR_2014_03M_SH/Data/CNTR_RG_03M_2014.shp")
coordinates(num_data) <- ~V2+V1  
gridded(num_data) <- TRUE

#plotting
png(file="Map2.png",width=35,height=30,unit="cm", res=200, type = "cairo")

spplot(num_data["V3"], xlim=c(-5,35), ylim=c(35,70),
             sp.layout = list("sp.polygons",map1),contour=F)
dev.off()

这是带有数据的文件: https://www.sendspace.com/file/hjtatp(通常压缩后大小为57 MB)

地图来自这里(但地图不是首要任务,可以跳过)

这是没有任何比例修改的样子: enter image description here

所以一切都是蓝色的。显然,最小值到最大值之间的比例距离太大了。我想修复比例尺,例如,最后一个值将是“高于x”。我尝试这样做:

enter image description here

现在看起来好多了。这是我做的:

#Fixed breakpoints (?)
at <- c(0e+0, 1.5e-5, 1.0e-4, 1.0e-3, 1.0e-2, 1.0e-1, 1.0e+0, 2.0e+0, 1.0e+1, 1.0e+2, 2.0e+2,5.0e+2)

spplot(num_data["V3"], xlim=c(-5,35), ylim=c(35,70),
             sp.layout = list("sp.polygons",map1),
             contour=F,
             at=at) #right there

所以我手动添加了at值(但没有精确的比例尺)。一切看起来好多了,但是...
如您所见,右侧的比例尺分布不均匀。我看不到任何蓝紫色,只有橙色和黄色。
此外,地图上的某些点非常明亮(德国地区),因为这里的值最高,但遗憾的是比例尺上没有这种颜色。
可能我没有做好。我不知道如何设置比例尺才能看起来好。我希望拥有像这样的比例尺:

enter image description here

我通过添加以下内容来实现这个:
spplot(num_data["V3"], xlim=c(-5,35), ylim=c(35,70),
             sp.layout = list("sp.polygons",map1),
             contour=F,at=at,
             colorkey=list(at=seq(0, 400, 30))  #right there 
             )

但是,这只是虚假的比例尺,它不起作用。

第二个问题:如何在绘制的数据上添加国家轮廓线?因为现在轮廓线被多彩的数据埋没了:c

1个回答

6

将数据转换为因子可以使图例的间隔更加规则。您可以通过 colorkey = list(labels = list(at = ..., labels = ...)) 更改标签及其位置。

[Edited; (I noticed that some values are over 500, sorry)]

 ## convert numeric to factor
num_data@data$cutV3 <- cut(num_data@data$V3, breaks = c(at, Inf))   # I modified the breaks

spplot(num_data["cutV3"], xlim=c(-5, 35), ylim=c(35, 70), 
   colorkey = list(height = 1, labels = list(at = seq(0.5, length(at) -0.5), labels = at)),
   sp.layout = list("sp.polygons", map1, first = F), contour = F)  # drawn after main plot

enter image description here


太棒了!这正是我所需要的!非常感谢 :) - Karmel
还有一件事,是否可以制作从深蓝色到黄色再到红色的比例颜色(蓝-黄-红)?我在考虑彩虹模式,但我只能使用绿-黄-红或蓝-粉-红。 - Karmel
1
@Karmel; 你需要的是 spplot(..., col.regions = colorRampPalette(c("blue", "yellow", "red")), ...) - cuttlefish44

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接