在传单中着色连续数据,R不起作用

时间:2017-12-15 02:18:22

标签: r colors leaflet

这是我的数据:

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的增加,颜色可能会从红色变为绿色。但我的地图上只有红点:

enter image description here

另一个问题是无论我如何更改radius的值,数据点的大小根本不会改变。我不知道我哪里出错了。

所以,我的问题是:

如何使用连续的颜色? 如何改变积分的大小?

1 个答案:

答案 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

是的,它确实按预期工作了。