这是我的数据:
t <- data.frame(Name=c('A','B','C','D','E','F','G','H','I','J'),
Longitude=c(151.2008,151.2458,150.8217,151.1215,150.8906,151.0660,150.8889,150.9188,150.4364,150.9982),
Latitude=c(-33.90772,-33.89250,-34.05951,-33.97856,-34.40470,-33.90010,-33.92832,-33.90761,-34.44651,-33.79232),
Diff=c(0.03,0.10,0.12,0.04,-0.12,0.34,-0.14,-0.01,0.21,-0.02),
Diff1=c(30,100,120,40,-120,340,-140,-10,210,-20))
我想使用leaflet和R在地图上绘制这些点,并使用Diff / Diff1的值作为连续颜色。这是我的代码:
library(leaflet)
pal <- colorNumeric(
palette = colorRampPalette(c('red','green')),
domain = t$Diff1)
leaflet(data=t) %>%
addTiles() %>%
addCircles(lng=~Longitude,lat=~Latitude,radius=10,popup=~Name,color=~pal(Diff1))
我这里不需要很多不同的颜色。我只是希望随着Diff1的增加,颜色可能会从红色变为绿色。但我的地图上只有红点:
另一个问题是无论我如何更改radius的值,数据点的大小根本不会改变。我不知道我哪里出错了。
所以,我的问题是:
如何使用连续的颜色? 如何改变积分的大小?
答案 0 :(得分:2)
试试这个(排除下面的数据框t
):
library(leaflet)
pal <- colorNumeric(
palette = colorRampPalette(c('red', 'green'))(length(t$Diff1)),
domain = t$Diff1)
leaflet(data = t) %>%
addTiles() %>%
addCircleMarkers(
lng = ~ Longitude,
lat = ~ Latitude,
radius = ~ Diff * 100,
popup = ~ Name,
color = ~ pal(Diff1)
)
请记住,colorRampPalette
实际上会返回一个函数,所以你需要&#34;破解&#34;当你要使用时,用()
打开函数,如下所示:
colorRampPalette(c('red', 'green'))(length(t$Diff1))
# "#FF0000" "#E21C00" "#C63800" "#AA5500" "#8D7100" "#718D00" "#55AA00" "#38C600" "#1CE200" "#00FF00"
检查开始和结束颜色(应为&#34;红色&#34;和&#34;绿色&#34;):
col2rgb("#FF0000")
# [,1]
# red 255
# green 0
# blue 0
col2rgb("#00FF00")
# [,1]
# red 0
# green 255
# blue 0
是的,它确实按预期工作了。