3

假设我有以下数据框:

ret <- rnorm(100, 0, 5)
df <- data.frame(
  x = seq(1, 100, 1),
  ret = ret,
  y = 100 + cumsum(ret),
  col = c(ifelse(ret > 0, "red", "forestgreen"), NA)[-1]
)

在这里,我使用名为“ret”的 rnorm 模拟一些虚构金融资产的回报,并定义了一个名为“col”的颜色向量,其中上升为绿色,下降为红色。

我想要制作的是如下内容:

library(ggplot2)
ggplot(df, aes(x=x, y=y)) + geom_line(aes(colour=col, group=1)) 

在此处输入图像描述

但我想使用 plotly 制作类似的图像,以便放大绘图的各个部分。我的第一个想法是尝试在生成所需图像的代码周围简单地使用 ggplotly() 函数:

library(plotly)
ggplotly(ggplot(df, aes(x=x, y=y)) + geom_line(aes(colour=col, group=1)))

使用 ggplotly

但情节不再分组。此外,我尝试使用 plot_ly() 但似乎无法根据我指定的“col”属性使线段获得颜色:

plot_ly(data=df, x = ~x) %>% add_lines(y = ~y, line = list(color=~col))

在此处输入图像描述

但我的颜色参数不会影响线条的颜色。我尝试了其他各种方法,但最终还是以两个不受欢迎的情节之一结束。任何帮助将非常感激!

注意:我已经使用 plot_ly() 制作了烛台和 OHLC 图表,但我无法使用它们,因为当您放大到绘图的某个子部分时,y 轴不会缩放。

4

1 回答 1

3

无论颜色如何,我都能ggplotly通过使用geom_segment并使每个段链接到下一个值来获得所需的行为:(x, y)

library(dplyr)
df = df %>%
    arrange(x) %>%
    mutate(x_next = lead(x), y_next = lead(y))

p = ggplot(df, aes(x=x, y=y)) + 
    geom_segment(aes(xend = x_next, yend = y_next, colour=col))
ggplotly(p)

ggplotly也就是说,对于为什么不首先产生所需的输出,我没有一个好的答案。

于 2017-09-11T00:50:29.373 回答