как использовать blit = true для анимации в сюжете python tkinter - PullRequest
0 голосов
/ 15 апреля 2020

Следующий код является упрощенной версией моего проекта, и он может запускаться и отображаться с анимацией, но мне нужно добавить blit=true в анимацию, чтобы ускорить (мой оригинальный интерфейс намного сложнее и медленнее). Я знаю, что функция анимации должна возвращать последовательность объектов Artist. вот какой объект художника у меня subplot_2? Я пробовал subplot_2,a,f, ни один из них не работает. Большое спасибо

from multiprocessing import Process
import matplotlib
matplotlib.use("TkAgg")
from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg
##, NavigationToolbar2TkAgg
from matplotlib.figure import Figure
import matplotlib.animation as animation
from matplotlib import style
import tkinter as tk
from tkinter import ttk
from tkinter import *
import matplotlib.pyplot as plt
import numpy as np
f = Figure(figsize=(6,6), dpi=100)
subplot_1 = f.add_subplot(211)
subplot_2 = f.add_subplot(212)

LARGE_FONT= ("Verdana", 12)
style.use("ggplot")

def animate(i):
    time = np.random.rand(2, 25)  
    data = np.random.rand(2, 25)   
    a = subplot_2.scatter(time,data,c='blue',s=2)
    #return a

class home(tk.Tk):

def __init__(self, *args, **kwargs):        
    tk.Tk.__init__(self, *args, **kwargs)
    tk.Tk.wm_title(self, "Graph ")       
    self.geometry("1000x1000")

    container = tk.Frame(self)
    container.pack(side="top", fill="both", expand = True)
    container.grid_rowconfigure(0, weight=1)
    container.grid_columnconfigure(0, weight=1)

    self.frames = {}
    F=Graph
    frame=Graph(container, self)
    self.frames[F] = frame
    frame.grid(row=0, column=0, sticky="nsew")
    self.show_frame(Graph)

def show_frame(self, cont):
    frame = self.frames[cont]
    frame.tkraise()
def get_frame(self, frame_class):
    return self.frames[frame_class]
##     
class Graph(tk.Frame):
    def __init__(self, parent, controller):
        global canvas
        tk.Frame.__init__(self, parent)
        label = tk.Label(self, text=" ", font=LARGE_FONT)
        label.pack(pady=120,padx=10)
        collectbtn=Button(self,text='collect',command=self.clickstart)
        collectbtn.place(x=200,y=100)
        canvas = FigureCanvasTkAgg(f, self)
##        canvas.draw()
        canvas.get_tk_widget().pack(side=tk.BOTTOM, fill=tk.BOTH, expand=True)
        canvas._tkcanvas.pack(side=tk.TOP, fill=tk.BOTH, expand=True)
    def clickstart(self):
        animate(0)
        #aniplot_photon = animation.FuncAnimation(f, animate, blit=True,interval=100)
        aniplot_photon = animation.FuncAnimation(f, animate, interval=100)
        canvas.draw()
app = home()
app.mainloop()

Обновления: Благодаря ответу Уильяма все работает. Тем не менее, у меня есть дополнительные вопросы: если этот подзаголовок содержит много кривых "subplot_2.scatter(x1..),subplot_2.scatter(x2..),subplot_2.scatter(x3..),subplot_2.scatter(x1..)...", или некоторые подплоты обновляются из разных потоков (создавать объекты и глобализировать их?), Будет трудно поместить все кривые в список возврата. Тем не менее, я нашел простое решение для перечисленных выше проблем, я мог бы просто использовать return [subplot_2], и он обновит все графики внутри subplot_2, но координаты (x отметок) будут потеряны (запустите, и вы увидите). Есть ли простой способ сохранить координаты при использовании return [suplot_2]?

    def animate(i):
    time = np.random.rand(2, 25)  
    data = np.random.rand(2, 25)   
    a = subplot_2.scatter(time,data,c='blue',s=2)
    return [subplot_2]

1 Ответ

0 голосов
/ 15 апреля 2020

matplotlib.pyplot.scatter возвращает артиста (точнее, PathCollection), поэтому артист, которого необходимо вернуть из animate, сохраняется в a. Однако для FuncAnimation требуется последовательность исполнителей, поэтому

    return a

недостаточно (так как это один исполнитель, а не последовательность). Вы можете использовать один из

    return [a]

или

    return a,

, чтобы удовлетворить « последовательность художников ».

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...