प्लॉटली - बटन्स ड्रॉपडाउन जोड़ना

प्लॉटिंग क्षेत्र पर विभिन्न नियंत्रणों के उपयोग द्वारा प्लॉटली उच्च स्तर की अन्तरक्रियाशीलता प्रदान करता है - जैसे बटन, ड्रॉपडाउन और स्लाइडर्स आदि। इन नियंत्रणों के साथ शामिल किया जाता है। 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। उपरोक्त के रूप में इसके लेआउट को अपडेट करने से पहले एक बॉक्स ट्रेस को चित्र ऑब्जेक्ट में जोड़ा गया। पूरा कोड जो प्रदान करता हैboxplot तथा violin 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विधि का उपयोग ग्राफ के डेटा और लेआउट अनुभागों को संशोधित करते समय किया जाना चाहिए। उदाहरण के बाद प्रदर्शित करता है कि कैसे अद्यतन करना है और लेआउट विशेषताओं को अद्यतन करते समय कौन से निशान प्रदर्शित होते हैं, जैसे कि, चार्ट शीर्षक। दो स्कैटर से संबंधित निशान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वस्तु। डेटा और लेआउट के साथ, फ़्रेम को एक ऑब्जेक्ट ऑब्जेक्ट में एक कुंजी के रूप में जोड़ा जा सकता है। फ़्रेम कुंजी आंकड़ों की एक सूची को इंगित करता है, जिनमें से प्रत्येक को एनीमेशन के ट्रिगर होने के दौरान चक्रित किया जाएगा।

आप एक जोड़कर चार्ट में एनीमेशन शुरू करने के लिए बटन जोड़ सकते हैं, खेल सकते हैं और रोक सकते हैं 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 बटन।