gpt4 book ai didi

python - Tkinter - 让第二个 Canvas 显示另一个 Canvas 的内容

转载 作者:太空宇宙 更新时间:2023-11-03 11:10:02 27 4
gpt4 key购买 nike

我正在寻找一种方法,使一个 Canvas 显示另一个 Canvas 的内容,而无需复制其中绘制的对象。第二个 Canvas 需要只是一个显示,它将第一个 Canvas 上绘制的内容作为输入。

我知道 .postscript 方法将内容写入文件或变量,但我不知道如何(如果可能的话)让另一个 Canvas 将其显示为图像。

编辑:忘了说了,我的操作系统是windows。如果有人也能告诉我一个跨平台的解决方案,那就太好了。

Edit2:我不想通过复制对象来做到这一点的原因是因为它们在移动,并且在某个时间间隔内,其中一些被破坏并创建了新的。此外,它是一个实时系统,复制对象及其行为可能会减慢速度。

最佳答案

没有内置的方法可以做到这一点。 Canvas 不支持任何类型的对等或复制。但是,如果您没有任何嵌入式小部件,则在第二个 Canvas 中保留所有对象的副本非常简单快捷。

一个简单的方法是继承 Canvas 小部件,然后创建 draw_line、draw_oval、coords 等的新实现以在对等 Canvas 上绘制。以下示例展示了如何以这种方式协调三个 Canvas ,其中有 1000 个以不同速率向下移动的对象:

import Tkinter as tk
import random

class SampleApp(tk.Tk):
def __init__(self, *args, **kwargs):
tk.Tk.__init__(self, *args, **kwargs)
self.canvas1 = PeeredCanvas(self, width=300, height=300, border=1, relief="sunken")
self.canvas2 = PeeredCanvas(self, width=300, height=300, border=1, relief="sunken")
self.canvas3 = PeeredCanvas(self, width=300, height=300, border=1, relief="sunken")
self.canvas1.add_peer(self.canvas2)
self.canvas1.add_peer(self.canvas3)
toolbar = tk.Frame(self)
clear_button = tk.Button(self, text="Refresh", command=self.refresh)
clear_button.pack(in_=toolbar, side="left")
toolbar.pack(side="top", fill="x")
self.canvas1.pack(side="left", fill="both", expand=True)
self.canvas2.pack(side="left", fill="both", expand=True)
self.canvas3.pack(side="left", fill="both", expand=True)
self.animate(10)

def animate(self, delay):
'''Move all items down at a random rate'''
for item in self.canvas1.find_all():
delta_x = 0
delta_y = random.randrange(1, 4)
self.canvas1.move(item, delta_x, delta_y)
self.after(delay, self.animate, delay)

def refresh(self, count=100):
'''Redraw 'count' random circles'''
self.canvas1.delete("all")
width=self.canvas1.winfo_width()
height=self.canvas1.winfo_height()
for i in range(count):
if i%2 == 0:
tags = ("even",)
else:
tags = ("odd",)
x = random.randrange(10, width-10)
y = random.randrange(10, height-10)
radius = random.randrange(10,100, 10)/2
self.canvas1.create_oval([x,y, x+radius, y+radius], tags=tags)
self.canvas1.itemconfigure("even", fill="red", outline="white")
self.canvas1.itemconfigure("odd", fill="white", outline="red")

class PeeredCanvas(tk.Canvas):
'''A class that duplicates all objects on one or more peer canvases'''
def __init__(self, *args, **kwargs):
self.peers = []
tk.Canvas.__init__(self, *args, **kwargs)

def add_peer(self, peer):
if self.peers is None:
self.peers = []
self.peers.append(peer)

def move(self, *args, **kwargs):
tk.Canvas.move(self, *args, **kwargs)
for peer in self.peers:
peer.move(*args, **kwargs)

def itemconfigure(self, *args, **kwargs):
tk.Canvas.itemconfigure(self, *args, **kwargs)
for peer in self.peers:
peer.itemconfigure(*args, **kwargs)

def delete(self, *args, **kwargs):
tk.Canvas.delete(self, *args)
for peer in self.peers:
peer.delete(*args)

def create_oval(self, *args, **kwargs):
tk.Canvas.create_oval(self, *args, **kwargs)
for peer in self.peers:
peer.create_oval(*args, **kwargs)


app = SampleApp()
app.mainloop()

关于python - Tkinter - 让第二个 Canvas 显示另一个 Canvas 的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7214054/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com