这很好用
library(dplyr)
library(ggvis)
years <- as.factor(c(2013,2013,2014,2014,2015,2015))
months <- c(1,2,1,2,1,2)
values <- c(3,2,4,6,5,1)
df <- data.frame(years,months,values)
df %>%
group_by(years) %>%
ggvis(~months, ~values) %>%
layer_points( fill = ~years)
但是,当我添加工具提示时,所有点都会暂时显示,但只剩下2015年的值
df <- cbind(df, id = seq_len(nrow(df)))
all_values <- function(x) {
if(is.null(x)) return(NULL)
row <- df[df$id == x$id,]
paste0(names(row),": ",format(row), collapse = "<br />")
}
df %>%
group_by(years) %>%
ggvis(~months, ~values, key:= ~id) %>%
layer_points( fill = ~years) %>%
add_tooltip(all_values, "hover")
可能是一些简单的错误,但任何帮助表示赞赏 欢呼声
答案 0 :(得分:2)
目前,尝试在数据分组时添加特定于行的工具提示似乎不起作用。实际上,这是有道理的,因为分组意味着您可能需要按组分组信息。
您根本不需要在layer_points
示例中进行分组,但如果您想要特定年份和积分之间的线路,则需要进行分组。如果这是您想要的,则在添加点后对数据集进行分组,并将key
放在layer_points
而不是整个ggvis
中。
df %>%
ggvis(~months, ~values) %>%
layer_points( fill = ~years, key:= ~id) %>%
add_tooltip(all_values, "hover") %>%
group_by(years) %>%
layer_lines(stroke = ~years, strokeWidth := 2)
这并不完全理想,因为即使行没有与之关联的唯一ID数据,工具提示仍会显示行。要更改此设置,请对工具提示功能进行一些小改动,以检查id变量是NULL
而不是ggvis
的整个数据集。
all_values = function(x) {
if(is.null(x$id)) return(NULL)
row <- df[df$id == x$id,]
paste0(names(row),": ",format(row), collapse = "<br />")
}
您可以在组级别添加工具提示,但是您需要确定要显示的摘要信息类型。在工具提示的功能中,您将使用分组变量而不是id
。
例如,您可以只显示与该组关联的所有值。我设置它的方式你需要点击该行来查看组信息:
group_values1 = function(x) {
if(is.null(x)) return(NULL)
group = df[df$years == unique(x$years),]
paste0(names(group), ": ", format(group), collapse = "<br />")
}
df %>%
ggvis(~months, ~values) %>%
layer_points( fill = ~years, key:= ~id) %>%
add_tooltip(all_values, "hover") %>%
group_by(years) %>%
layer_lines(stroke = ~years, strokeWidth := 2) %>%
add_tooltip(group_values1, "click")
您可能希望显示摘要信息。在此示例中,我将显示values
中的整体更改以及工具提示中传递的月数。我使用 dplyr 中的函数创建摘要数据集。
group_values2 = function(x) {
if(is.null(x)) return(NULL)
group = df[df$years == unique(x$years),]
groupval = group %>% group_by(years) %>%
summarise(`Change in value` = max(values) - min(values),
`Months Passed` = max(months) - min(months))
paste0(names(groupval), ": ", format(groupval), collapse = "<br />")
}
df %>%
ggvis(~months, ~values) %>%
layer_points( fill = ~years, key:= ~id) %>%
add_tooltip(all_values, "hover") %>%
group_by(years) %>%
layer_lines(stroke = ~years, strokeWidth := 2) %>%
add_tooltip(group_values2, "click")
答案 1 :(得分:1)
问题在于你将group_by
放在ggvis之前并在之后调用add_tooltip
。只需将group_by
部分放在ggvis call
df %>%
ggvis(~months, ~values, key:= ~id) %>%
group_by(years) %>%
layer_points( fill = ~years) %>%
add_tooltip(all_values, "hover")
不知道为什么会发生这种情况