jer*_*n81 6 r highcharts rcharts
我想通过rCharts为标准的Highcharts工具提示添加一些额外的值.示例代码:
require(rCharts)
df <- data.frame(x = c(1:5), y = c(5:1),
z = c("A", "B", "C", "D", "E"),
name = c("K", "L", "M", "N", "O"))
h1 <- hPlot(x = "x", y = "y", data = df, type = "scatter", group = "z")
Run Code Online (Sandbox Code Playgroud)
这会生成带有x和y值的工具提示.系列名称为标题.现在我还想将名称值添加到工具提示中.但是我不知道如何做到这一点.
几年后,我有了答案。
即使使用简单的自定义格式化程序函数,这些包装函数似乎hPlot()也不支持其他工具提示变量。请参阅下面基于问题数据集的工作示例。
require(rCharts)
# create data frame
df <- data.frame(x = c(1:5), y = c(5:1),
z = c("A", "B", "C", "D", "E"),
name = c("K", "L", "M", "N", "O"))
# Plot using hPlot() approach
h1 <- hPlot(x = "x", y = "y", data = df, type = "scatter", group = "z")
h1$tooltip(borderWidth=0, followPointer=TRUE, followTouchMove=TRUE, shared = FALSE,
formatter = "#! function(){return 'X: ' + this.point.x + '<br>Y: ' + this.point.y + '<br>Z: ' + this.point.z + '<br>Name: ' + this.point.name;} !#")
h1
Run Code Online (Sandbox Code Playgroud)
工具提示在上面的示例中不起作用,因为数组中的变量未命名。看str(h1)。
# Plot using manual build
h1 <- rCharts:::Highcharts$new()
dlev <- levels(factor(as.character(df$z)))
for(i in 1:length(dlev))
{
h1$series(data = toJSONArray2(df[df$z==dlev[i],,drop=F], json = F,names=T), name = dlev[i],type = c("scatter"), marker = list(radius = 3))
}
h1$tooltip(borderWidth=0, followPointer=TRUE, followTouchMove=TRUE, shared = FALSE,
formatter = "#! function(){return 'X: ' + this.point.x + '<br>Y: ' + this.point.y + '<br>Z: ' + this.point.z + '<br>Name: ' + this.point.name;} !#")
h1
Run Code Online (Sandbox Code Playgroud)
这是可行的,因为数组变量是names=T在以 开头的行中使用命名的h1$series...。看str(h1)。
这解决了工具提示问题,但命名数组可能存在其他问题。例如,它会破坏闪亮应用程序环境中的事物。hPlot()不使用命名数组一定是有原因的。