Plotly - Controllo cursore
Plotly ha un comodo Slider che può essere utilizzato per modificare la visualizzazione di data/style di un grafico facendo scorrere una manopola sul controllo che si trova nella parte inferiore del grafico sottoposto a rendering.
Slider control è composto da diverse proprietà che sono le seguenti:
steps property è necessario per definire le posizioni di scorrimento della manopola sul controllo.
method property sta avendo valori possibili come restyle | relayout | animate | update | skip, l'impostazione predefinita è restyle.
args property imposta i valori degli argomenti da passare al metodo Plotly impostato nel metodo sulla diapositiva.
Ora distribuiamo un semplice controllo cursore su un grafico a dispersione che varierà la frequenza di sine wavementre la manopola scorre lungo il controllo. Il dispositivo di scorrimento è configurato per avere 50 passaggi. Per prima cosa aggiungi 50 tracce di curva sinusoidale con frequenza crescente, tutte tranne la decima traccia impostata su visibile.
Quindi, configuriamo ogni passaggio con restylemetodo. Per ogni passaggio, tutti gli altri oggetti del passaggio hanno la visibilità impostata sufalse. Infine, aggiorna il layout dell'oggetto Figura inizializzando la proprietà dei cursori.
# Add traces, one for each slider step
for step in np.arange(0, 5, 0.1):
fig.add_trace(
go.Scatter(
visible = False,
line = dict(color = "blue", width = 2),
name = " = " + str(step),
x = np.arange(0, 10, 0.01),
y = np.sin(step * np.arange(0, 10, 0.01))
)
)
fig.data[10].visible=True
# Create and add slider
steps = []
for i in range(len(fig.data)):
step = dict(
method = "restyle",
args = ["visible", [False] * len(fig.data)],
)
step["args"][1][i] = True # Toggle i'th trace to "visible"
steps.append(step)
sliders = [dict(active = 10, steps = steps)]
fig.layout.update(sliders=sliders)
iplot(fig)
Iniziare con, 10th sine wavesarà visibile la traccia. Prova a far scorrere la manopola sul controllo orizzontale in basso. Vedrai la frequenza cambiare come mostrato di seguito.