R - 传单 - highcharter 工具提示

标签 r highcharts leaflet r-leaflet r-highcharter

我想包括一个 highcharter情节在我的 leaflet弹出。在 this 的帮助下帖子我可以包含一个 sparkline阴谋。但是,由于我缺乏 html 技能,我不知道如何修改代码以使用 highcharter . This answer on SO ( example from answer ) 正是我想要的。我只是不知道如何在 R 中实现.

library(leaflet)
library(tidyverse)
library(htmlwidgets)
library(htmltools)
library(sparkline)
library(highcharter)

# Step 1 convert htmlwidget to character representation of HTML components
as.character.htmlwidget <- function(x, ...) {
  htmltools::HTML(
    htmltools:::as.character.shiny.tag.list(
      htmlwidgets:::as.tags.htmlwidget(
        x
      ),
      ...
    )
  )
}


add_deps <- function(dtbl, name, pkg = name) {
  tagList(
    dtbl,
    htmlwidgets::getDependency(name, pkg)
  )
}

这工作正常:
leaflet() %>% 
  addTiles() %>% 
  addCircleMarkers(lat = 45.4, lng = 14.9,
                   popup = list(paste(as.character(sparkline(1:19))))) %>%
  onRender(
    "
function(el,x) {
  this.on('popupopen', function() {HTMLWidgets.staticRender();})
}
") %>%
  add_deps("sparkline") %>%
  browsable()

enter image description here

不幸的是,它不仅仅是变化 add_depshighcharter
leaflet() %>% 
  addTiles() %>% 
  addCircleMarkers(lat = 45.4, lng = 14.9,
                   popup = list(paste(as.character(
                     hchart(data.frame(x = 1:10, y = 1:10), type = "line", hcaes(x = x, y = y)) %>% hc_size(width = 300, height = 200)
                     ))),
                   popupOptions = popupOptions(minWidth = 300, maxHeight = 200)) %>%
  onRender(
    "
function(el,x) {
  this.on('popupopen', function() {HTMLWidgets.staticRender();})
}
") %>%
  add_deps("highcharter") %>%
  browsable()

enter image description here

我曾尝试修改“popupopen”功能但没有成功。

最佳答案

一、解决办法:

leaflet() %>% 
  addTiles() %>% 
  addCircleMarkers(lat = 45.4, lng = 14.9,
                   popup = list(paste(as.character(
                     hchart(data.frame(x = 1:10, y = 1:10), type = "line", hcaes(x = x, y = y)) %>% hc_size(width = 300, height = 200)
                   ))),
                   popupOptions = popupOptions(minWidth = 300, maxHeight = 200)) %>%
  onRender(
    "
function(el,x) {
  this.on('popupopen', function() {HTMLWidgets.staticRender();})
}
") %>%
  add_deps("highchart", 'highcharter') %>%
  browsable()

enter image description here

而现在,为什么?

这是由于 add_deps功能:
add_deps <- function(dtbl, name, pkg = name) {
  tagList(
    dtbl,
    htmlwidgets::getDependency(name, pkg)
  )
}

如您所见,它在内部使用 htmlwidgets::getDependency .如果我们尝试使用 leaflet包裹:

library(htmlwidgets)
getDependency('leaflet')[1:3]
#> [[1]]
#> List of 10
#>  $ name      : chr "htmlwidgets"
#>  $ version   : chr "1.5.1"
#>  $ src       :List of 1
#>   ..$ file: chr "/home/malditobarbudo/R/x86_64-pc-linux-gnu-library/3.6/htmlwidgets/www"
#>  $ meta      : NULL
#>  $ script    : chr "htmlwidgets.js"
#>  $ stylesheet: NULL
#>  $ head      : NULL
#>  $ attachment: NULL
#>  $ package   : NULL
#>  $ all_files : logi TRUE
#>  - attr(*, "class")= chr "html_dependency"
#> 
#> [[2]]
#> List of 10
#>  $ name      : chr "jquery"
#>  $ version   : chr "1.12.4"
#>  $ src       :List of 1
#>   ..$ file: chr "/home/malditobarbudo/R/x86_64-pc-linux-gnu-library/3.6/leaflet/htmlwidgets/lib/jquery"
#>  $ meta      : NULL
#>  $ script    : chr "jquery.min.js"
#>  $ stylesheet: NULL
#>  $ head      : NULL
#>  $ attachment: NULL
#>  $ package   : NULL
#>  $ all_files : logi TRUE
#>  - attr(*, "class")= chr "html_dependency"
#> 
#> [[3]]
#> List of 10
#>  $ name      : chr "leaflet"
#>  $ version   : chr "1.3.1"
#>  $ src       :List of 1
#>   ..$ file: chr "/home/malditobarbudo/R/x86_64-pc-linux-gnu-library/3.6/leaflet/htmlwidgets/lib/leaflet"
#>  $ meta      : NULL
#>  $ script    : chr "leaflet.js"
#>  $ stylesheet: chr "leaflet.css"
#>  $ head      : NULL
#>  $ attachment: NULL
#>  $ package   : NULL
#>  $ all_files : logi TRUE
#>  - attr(*, "class")= chr "html_dependency"

创建于 2019-12-05 由 reprex package (v0.3.0)

我们可以看到它返回一个列表 leaflet js 依赖项(截断为前三个)。如果我们对 highcharter 尝试相同的方法它不返回任何依赖项(除了强制性的 htmlwidgets 依赖项)

library(htmlwidgets)
getDependency('highcharter')
#> [[1]]
#> List of 10
#>  $ name      : chr "htmlwidgets"
#>  $ version   : chr "1.5.1"
#>  $ src       :List of 1
#>   ..$ file: chr "/home/malditobarbudo/R/x86_64-pc-linux-gnu-library/3.6/htmlwidgets/www"
#>  $ meta      : NULL
#>  $ script    : chr "htmlwidgets.js"
#>  $ stylesheet: NULL
#>  $ head      : NULL
#>  $ attachment: NULL
#>  $ package   : NULL
#>  $ all_files : logi TRUE
#>  - attr(*, "class")= chr "html_dependency"
#> 
#> [[2]]
#> NULL

创建于 2019-12-05 由 reprex package (v0.3.0)

这是因为 highcharter是R包名,不是js库名。你
可以看list.files(system.file('htmlwidgets', package = 'highcharter'))
看到该库被称为 Highcharts ,因此在此使用正确的名称
少量:
{...} %>%
  add_deps("highchart", 'highcharter') %>%
  {...}

会做的伎俩;)

关于R - 传单 - highcharter 工具提示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59173708/

相关文章:

javascript - Mapbox 不再与 Leaflet 一起使用

r - 当我有唯一的名称时, tidyr::gather() 出错

r - sqldf更新错误

r - 为什么Bookdown的index.Rmd中必须包含一些R代码?

javascript - Highcharts 对数 X 轴在没有零值或阈值低于零或最小值的情况下失败

leaflet - 除了不透明度之外,如何更改传单的 imageOverlay 中的样式?

r - ggplot添加线散布

HTML 页面在外部服务器上丢失格式

javascript - 在 highcharts 中为同步图表添加或声明两个绘图选项

javascript - 使用 shp-write 将 Geojson 转换为 Javascript 中的 Shapefile