Chcę utworzyć interaktywną figurę segmentów linii lub prostokątów, tak aby każdy segment lub prostokąt dawał inne informacje, gdy użytkownik najedzie na niego myszą. Spojrzałem na htmlwidgets showcase i pomyślałem, że wyglądał obiecująco. (Jestem otwarty na inne metody związane z R).Segmenty linii lub prostokąty z informacją na zawiasach w R sprytnie rysunek
Poniżej znajduje się prosty przykład. Mogę utworzyć wykres punktów końcowych (t1 i t2), które dostarczają informacji o najechaniu. Chciałbym jednak, aby informacje o zawisaniu pojawiały się za każdym razem, gdy użytkownik unosi się nad przestrzenią między dwoma punktami końcowymi).
Mogę dodać segment linii za pomocą add_trace()
, ale nie mogę uruchomić funkcji Hover. A jeśli dodać segment drugiego wiersza, otrzymuję komunikat o błędzie:
Error in plot_ly(data = mydat, x = t2, y = y, mode = "markers", hoverinfo = "text", :
requires numeric/complex matrix/vector arguments
mogę dodać prostokąty za pomocą layout()
, ale znowu, nie mogę uzyskać unoszą się do pracy.
Jeśli ktoś zaproponuje sposób, w jaki można zastosować argumenty najeżdżania dla któregoś z tych podejść, z zadowoleniem przyjmuję również sugestie, jak zakodować to dla dużej liczby segmentów/prostokątów (nie tylko 2, jak w tym prostym przykładzie).
Wszelkie sugestie?
mydat <- data.frame(t1=c(1, 3), t2=c(4, 5), y=c(1, 2), task=c("this", "that"))
library(plotly)
# attempt with one line segment - hover doesn't work
plot_ly(data=mydat, x=t2, y=y, mode="markers",
hoverinfo="text", text=task) %>%
add_trace(data=mydat, x=t1, y=y, mode="markers",
hoverinfo="text", text=task) %>%
add_trace(
x=c(mydat$t1[1], mydat$t2[1]), y=c(mydat$y[1], mydat$y[1]),
mode="lines", hoverinfo="text", text=mydat$task[1])
# attempt with both line segments -
# Error in plot_ly, requires numeric/complex matrix/vector arguments
plot_ly(data=mydat, x=t2, y=y, mode="markers",
hoverinfo="text", text=task) %>%
add_trace(data=mydat, x=t1, y=y, mode="markers",
hoverinfo="text", text=task) %>%
add_trace(
x=c(mydat$t1[1], mydat$t2[1]), y=c(mydat$y[1], mydat$y[1]),
mode="lines", hoverinfo="text", text=mydat$task[1]) %*%
add_trace(
x=c(mydat$t1[2], mydat$t2[2]), y=c(mydat$y[2], mydat$y[2]),
mode="lines", hoverinfo="text", text=mydat$task[2])
# attempt with rectangles - hover doesn't work
plot_ly(data=mydat, x=t2, y=y, mode="markers",
hoverinfo="text", text=task) %>%
add_trace(data=mydat, x=t1, y=y, mode="markers",
hoverinfo="text", text=task) %>%
layout(shapes=list(
list(type="rect", x0=mydat$t1[1], x1=mydat$t2[1], xref="x",
y0=mydat$y[1], y1=mydat$y[1]+0.1, yref="y",
hoverinfo="text", text=mydat$task[1]),
list(type="rect", x0=mydat$t1[2], x1=mydat$t2[2], xref="x",
y0=mydat$y[2], y1=mydat$y[2]+0.1, yref="y",
hoverinfo="text", text=mydat$task[2])
))