python之matplotlib學習繪製動態更新圖執行個體代碼,pythonmatplotlib

來源:互聯網
上載者:User

python之matplotlib學習繪製動態更新圖執行個體代碼,pythonmatplotlib
簡介

通過定時器Timer觸發事件,定時更新繪圖,可以形成動態更新圖片。下面的執行個體是學習《matplotlib for python developers》一文的筆記。

實現

實現代碼及簡單介紹

通過self.user = self.user[1:] + [temp],每次刪除列表的第一元素,在其尾部添加新的元素。這樣完成user資料的動態更新。其他詳細的解釋見文中的注釋部分。

#-*-coding:utf-8-*- import wx from matplotlib.figure import Figure import matplotlib.font_manager as font_manager import numpy as np from matplotlib.backends.backend_wxagg import \  FigureCanvasWxAgg as FigureCanvas # wxWidgets object ID for the timer TIMER_ID = wx.NewId() # number of data points POINTS = 300  class PlotFigure(wx.Frame):   """Matplotlib wxFrame with animation effect"""   def __init__(self):     wx.Frame.__init__(self, None, wx.ID_ANY, title="CPU Usage Monitor", size=(600, 400))     # Matplotlib Figure     self.fig = Figure((6, 4), 100)     # bind the Figure to the backend specific canvas     self.canvas = FigureCanvas(self, wx.ID_ANY, self.fig)     # add a subplot     self.ax = self.fig.add_subplot(111)     # limit the X and Y axes dimensions     self.ax.set_ylim([0, 100])     self.ax.set_xlim([0, POINTS])          self.ax.set_autoscale_on(False)     self.ax.set_xticks([])     # we want a tick every 10 point on Y (101 is to have 10     self.ax.set_yticks(range(0, 101, 10))     # disable autoscale, since we don't want the Axes to ad     # draw a grid (it will be only for Y)     self.ax.grid(True)     # generates first "empty" plots     self.user = [None] * POINTS     self.l_user,=self.ax.plot(range(POINTS),self.user,label='User %')      # add the legend     self.ax.legend(loc='upper center',               ncol=4,               prop=font_manager.FontProperties(size=10))     # force a draw on the canvas()     # trick to show the grid and the legend     self.canvas.draw()     # save the clean background - everything but the line     # is drawn and saved in the pixel buffer background     self.bg = self.canvas.copy_from_bbox(self.ax.bbox)     # bind events coming from timer with id = TIMER_ID     # to the onTimer callback function     wx.EVT_TIMER(self, TIMER_ID, self.onTimer)    def onTimer(self, evt):     """callback function for timer events"""     # restore the clean background, saved at the beginning     self.canvas.restore_region(self.bg)         # update the data     temp =np.random.randint(10,80)     self.user = self.user[1:] + [temp]     # update the plot     self.l_user.set_ydata(self.user)     # just draw the "animated" objects     self.ax.draw_artist(self.l_user)# It is used to efficiently update Axes data (axis ticks, labels, etc are not updated)     self.canvas.blit(self.ax.bbox) if __name__ == '__main__':   app = wx.PySimpleApp()   frame = PlotFigure()   t = wx.Timer(frame, TIMER_ID)   t.Start(50)   frame.Show()   app.MainLoop() 

運行結果如下所示:

疑問

但程式運行在關閉的時候會出現應用程式錯誤,不知道什麼問題。python不是有記憶體回收機制嗎,難道是記憶體泄露?

猜測的原因可能是在關閉的時候正在繪圖故導致應用程式出錯。通過添加Frame的解構函式,停止更新則不會出現問題。

def __del__( self ):   t.Stop() 
總結

以上就是本文關於python之matplotlib學習繪製動態更新圖執行個體代碼的全部內容,希望對大家有所協助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支援!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.