Plotly-버튼 드롭 다운 추가

Plotly는 버튼, 드롭 다운 및 슬라이더 등과 같은 플로팅 영역에서 다양한 컨트롤을 사용하여 높은 수준의 상호 작용을 제공합니다. 이러한 컨트롤은 updatemenu플롯 레이아웃의 속성. 당신은 할 수 있습니다add button 호출 할 메서드를 지정하여 동작.

다음과 같이 버튼과 연결할 수있는 네 가지 방법이 있습니다.

  • restyle − 데이터 또는 데이터 속성 수정

  • relayout − 레이아웃 속성 수정

  • update − 데이터 및 레이아웃 속성 수정

  • animate − 애니메이션 시작 또는 일시 중지

그만큼 restyle 방법은 다음과 같은 경우에 사용되어야합니다. modifying the data and data attributes그래프의. 다음 예에서는 두 개의 버튼이Updatemenu() 레이아웃에 대한 방법 restyle 방법.

go.layout.Updatemenu(
type = "buttons",
direction = "left",
buttons = list([
   dict(args = ["type", "box"], label = "Box", method = "restyle"),
   dict(args = ["type", "violin"], label = "Violin", method = "restyle" )]
))

가치 type 속성은 buttons기본적으로. 버튼 드롭 다운 목록을 렌더링하려면 유형을dropdown. 위와 같이 레이아웃을 업데이트하기 전에 Figure 개체에 추가 된 상자 추적입니다. 렌더링하는 완전한 코드boxplotviolin plot 클릭 한 버튼에 따라 다음과 같습니다.

import plotly.graph_objs as go
fig = go.Figure()
fig.add_trace(go.Box(y = [1140,1460,489,594,502,508,370,200]))
fig.layout.update(
   updatemenus = [
      go.layout.Updatemenu(
         type = "buttons", direction = "left", buttons=list(
            [
               dict(args = ["type", "box"], label = "Box", method = "restyle"),
               dict(args = ["type", "violin"], label = "Violin", method = "restyle")
            ]
         ),
         pad = {"r": 2, "t": 2},
         showactive = True,
         x = 0.11,
         xanchor = "left",
         y = 1.1,
         yanchor = "top"
      ), 
   ]
)
iplot(fig)

코드의 출력은 다음과 같습니다.

클릭 Violin 버튼을 눌러 해당 Violin plot.

위에서 언급했듯이 type 입력 Updatemenu() 방법이 할당 됨 dropdown버튼의 드롭 다운 목록을 표시합니다. 플롯은 다음과 같이 나타납니다.

그만큼 update그래프의 데이터 및 레이아웃 섹션을 수정할 때 메서드를 사용해야합니다. 다음 예는 차트 제목과 같은 레이아웃 속성을 동시에 업데이트하는 동안 업데이트하는 방법과 표시되는 트레이스를 보여줍니다. 에 해당하는 두 개의 Scatter 추적sine and cos wave 추가됩니다 Figure object. 보이는 흔적attribute 같이 True 플롯에 표시되고 다른 트레이스는 숨겨집니다.

import numpy as np
import math #needed for definition of pi

xpoints = np.arange(0, math.pi*2, 0.05)
y1 = np.sin(xpoints)
y2 = np.cos(xpoints)
fig = go.Figure()
# Add Traces
fig.add_trace(
   go.Scatter(
      x = xpoints, y = y1, name = 'Sine'
   )
)
fig.add_trace(
   go.Scatter(
      x = xpoints, y = y2, name = 'cos'
   )
)
fig.layout.update(
   updatemenus = [
      go.layout.Updatemenu(
         type = "buttons", direction = "right", active = 0, x = 0.1, y = 1.2,
         buttons = list(
            [
               dict(
                  label = "first", method = "update",
                  args = [{"visible": [True, False]},{"title": "Sine"} ]
               ),
               dict(
                  label = "second", method = "update", 
                  args = [{"visible": [False, True]},{"title": Cos"}]
               )
            ]
         )
      )
   ]
)
iplot(fig)

처음에는 Sine curve표시됩니다. 두 번째 버튼을 클릭하면cos trace 나타납니다.

참고 chart title 또한 그에 따라 업데이트됩니다.

사용하기 위해 animate 메서드를 하나 이상 추가해야합니다. Frames to the Figure목적. 데이터 및 레이아웃과 함께 프레임을 Figure 개체의 키로 추가 할 수 있습니다. 프레임 키 포인트는 그림 목록을 가리키며, 각 그림은 애니메이션이 트리거 될 때 순환됩니다.

추가, 재생 및 일시 중지 버튼을 추가하여 차트에 애니메이션을 소개 할 수 있습니다. updatemenus array 레이아웃에.

"updatemenus": [{
   "type": "buttons", "buttons": [{
      "label": "Your Label", "method": "animate", "args": [frames]
   }]
}]

다음 예에서 scatter curve트레이스가 먼저 그려집니다. 그런 다음 추가frames 목록입니다 50 Frame objects, 각각은 red marker곡선에. 참고args 버튼의 속성이 없음으로 설정되어 모든 프레임이 애니메이션됩니다.

import numpy as np
t = np.linspace(-1, 1, 100)
x = t + t ** 2
y = t - t ** 2
xm = np.min(x) - 1.5
xM = np.max(x) + 1.5
ym = np.min(y) - 1.5
yM = np.max(y) + 1.5
N = 50
s = np.linspace(-1, 1, N)
#s = np.arange(0, math.pi*2, 0.1)
xx = s + s ** 2
yy = s - s ** 2
fig = go.Figure(
   data = [
      go.Scatter(x = x, y = y, mode = "lines", line = dict(width = 2, color = "blue")),
      go.Scatter(x = x, y = y, mode = "lines", line = dict(width = 2, color = "blue"))
   ],
   layout = go.Layout(
      xaxis=dict(range=[xm, xM], autorange=False, zeroline=False),
      yaxis=dict(range=[ym, yM], autorange=False, zeroline=False),
      title_text="Moving marker on curve",
      updatemenus=[
         dict(type="buttons", buttons=[dict(label="Play", method="animate", args=[None])])
      ]
   ),
   frames = [go.Frame(
      data = [
            go.Scatter(
            x = [xx[k]], y = [yy[k]], mode = "markers", marker = dict(
               color = "red", size = 10
            )
         )
      ]
   )
   for k in range(N)]
)
iplot(fig)

코드의 출력은 다음과 같습니다.

클릭하면 빨간색 마커가 곡선을 따라 움직이기 시작합니다. play 단추.