在R中自定义传单图例时如何添加三角形?

问题描述 投票:0回答:1

我从这篇文章开始,@Hallie Swan 的代码效果很好,但我想将图例中的最后一个形状更改为空心三角形。

我的印象是,纯粹用 CSS 绘制一个空心三角形是很有挑战性的。然后我发现如果我可以在 R 中的自定义 CSS 部分内联一个 svg 标签(绘制一个空心三角形),它可能会起作用。但我失败了。

这是来自原始帖子的代码,不包括闪亮的部分:

library(leaflet)

colors <- c("red", "white", "blue", "white", "blue", "red")
labels <- c("filled_square", "empty_square", "big_square", "empty_circle", "filled_circle", "big_circle")
sizes <- c(10, 20, 30, 10, 20, 30)
shapes <- c("square", "square", "square", "circle", "circle", "circle")
borders <- c("red", "blue", "black", "blue", "blue", "black")

addLegendCustom <- function(map, colors, labels, sizes, shapes, borders, opacity = 0.5){
  
  make_shapes <- function(colors, sizes, borders, shapes) {
    shapes <- gsub("circle", "50%", shapes)
    shapes <- gsub("square", "0%", shapes)
    paste0(colors, "; width:", sizes, "px; height:", sizes, "px; border:3px solid ", borders, "; border-radius:", shapes)
  }
  make_labels <- function(sizes, labels) {
    paste0("<div style='display: inline-block;height: ", 
           sizes, "px;margin-top: 4px;line-height: ", 
           sizes, "px;'>", labels, "</div>")
  }
  
  legend_colors <- make_shapes(colors, sizes, borders, shapes)
  # I added my modification here, see below
  legend_labels <- make_labels(sizes, labels)
  
  return(addLegend(map, colors = legend_colors, labels = legend_labels, opacity = opacity))
}

leaflet() %>% addTiles() %>% 
  addLegendCustom(colors, labels, sizes, shapes, borders)

我尝试过的:

基于原始代码,我尝试修改

legend_colors
向量中的最后一个元素,如下所示:

legend_colors[length(legend_colors)] <- "url('data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' height='20' width='30'><polygon points='15,3 25,15 5,15' style='fill:transparent;stroke:black;stroke-width:3' /></svg>')"

但是当我将上述行添加到原始脚本中后,没有显示三角形。三角形应该出现的地方是空的:

目前的屏幕截图:
A screenshot of what it looks like at the moment

根据另一篇文章中的信息,对于我试图修改的最后一个图例形状,由传单在引擎盖下构建的CSS代码应该是(如果我错了,请纠正我):

        {
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' height='20' width='30'><polygon points='15,3 25,15 5,15' style='fill:transparent;stroke:black;stroke-width:3' /></svg>");
    opacity: 0.5;
}
css r r-leaflet
1个回答
1
投票

我想通了。解决方案是将图像的 Base64 数据 URI 馈送到 R 中。我首先为空心三角形创建了一个 png 图像,将其保存为我想要的大小,然后使用 这个免费服务 来获取 Base64 数据 URI。

这是R代码(仅针对我正在修改的部分):

  legend_colors[length(legend_colors)] <- "url('')"
  
  legend_colors[length(legend_colors)] <- gsub("=')", 
                                               "='); width:36px; height:36px", 
                                               legend_colors[length(legend_colors)])

请注意,第二部分是附加更多 CSS 代码来控制元素的大小。只需参考 HTML 源代码即可根据需要调整大小。

传说现在是什么样子

© www.soinside.com 2019 - 2024. All rights reserved.