[英]R Plotly: Change legend symbol
如何更改 R 中的默認圖例符號? 在下面的示例中,我希望兩個符號都是圖例中的點。 “A”的圖例條目應該是一個藍色圓圈。 (默認情況下,Plotly 使用每個類別的第一個點的符號。)
library(plotly)
# generate example data
name = rep("A", 100)
name[1:100%%6 == 0] = "B"
data = data.frame(x = 1:100, y = sin(1:100),
name = name,
symbol = c(2, rep(1, 50), 2, 2,2, 2, 2, 2, rep(1, 43)))
plot_ly(data)%>%
add_markers(x = ~x, y = ~y, symbol = ~symbol,
symbols = c(27, 4),
mode = 'markers', split = ~name)
通過將符號和顏色參數映射到因子變量,您可以為每個符號和名稱創建一個軌跡。 以下代碼可能會解決您的問題:
col3 <- colorRamp(c("red", "blue"))
p = plot_ly(data,x = ~x, y = ~y)
add_markers(p, symbol = ~factor(symbol),
color = ~factor(name),
colors = col3, symbols = c(27,4))
檢查此鏈接以獲取有關散點圖跟蹤的更多詳細信息https://plotly-book.cpsievert.me/scatter-traces.html
啊, plotly
已經選擇了symbol
列的第一個條目以在其圖例中使用。
> head(data[data$name == 'A', ])
x y name symbol
1 1 0.8414710 A 2 # The first value is 2
2 2 0.9092974 A 1
3 3 0.1411200 A 1
4 4 -0.7568025 A 1
5 5 -0.9589243 A 1
7 7 0.6569866 A 1
而在“B”的情況下,-
> head(data[data$name == 'B', ])
x y name symbol
6 6 -0.2794155 B 1 # The first value is 1
12 12 -0.5365729 B 1
18 18 -0.7509872 B 1
24 24 -0.9055784 B 1
30 30 -0.9880316 B 1
36 36 -0.9917789 B 1
如果您按name
和symbol
對數據進行排序,那么圖例應該是一致的。
library(plotly)
# generate example data
name = rep("A", 100)
name[1:100%%6 == 0] = "B"
data = data.frame(x = 1:100, y = sin(1:100),
name = name,
symbol = c(2, rep(1, 50), 2, 2,2, 2, 2, 2, rep(1, 43)))
data <- data[with(data, order(symbol, name)), ]
plot_ly(data)%>%
add_markers(x = ~x, y = ~y, symbol = ~symbol, symbols = c(27, 4),
mode = 'markers', split = ~name)
如果我們對符號使用 2 級分類變量,我們可以嘗試symbols = I(c('27', '4'))
來指定符號。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.