Ниже я привожу пример кода, который только что написал, о том, как создавать прямоугольники в холсте tkinter с помощью мыши. Я надеюсь, что это поможет вам понять соответствующие процедуры и методы, которые вам нужны. После этого адаптируйте его для вашей конкретной проблемы. Надеюсь, это поможет вам и с наилучшими пожеланиями.
Пример кода: как создать холст tkinter, который позволяет пользователю рисовать прямоугольные объекты с помощью мыши.
import tkinter as tk
class App(tk.Frame):
def __init__( self, parent):
tk.Frame.__init__(self, parent)
self._createVariables(parent)
self._createCanvas()
self._createCanvasBinding()
def _createVariables(self, parent):
self.parent = parent
self.rectx0 = 0
self.recty0 = 0
self.rectx1 = 0
self.recty1 = 0
self.rectid = None
def _createCanvas(self):
self.canvas = tk.Canvas(self.parent, width = 800, height = 400,
bg = "white" )
self.canvas.grid(row=0, column=0, sticky='nsew')
def _createCanvasBinding(self):
self.canvas.bind( "<Button-1>", self.startRect )
self.canvas.bind( "<ButtonRelease-1>", self.stopRect )
self.canvas.bind( "<B1-Motion>", self.movingRect )
def startRect(self, event):
#Translate mouse screen x0,y0 coordinates to canvas coordinates
self.rectx0 = self.canvas.canvasx(event.x)
self.recty0 = self.canvas.canvasy(event.y)
#Create rectangle
self.rectid = self.canvas.create_rectangle(
self.rectx0, self.recty0, self.rectx0, self.recty0, fill="#4eccde")
print('Rectangle {0} started at {1} {2} {3} {4} '.
format(self.rectid, self.rectx0, self.recty0, self.rectx0,
self.recty0))
def movingRect(self, event):
#Translate mouse screen x1,y1 coordinates to canvas coordinates
self.rectx1 = self.canvas.canvasx(event.x)
self.recty1 = self.canvas.canvasy(event.y)
#Modify rectangle x1, y1 coordinates
self.canvas.coords(self.rectid, self.rectx0, self.recty0,
self.rectx1, self.recty1)
print('Rectangle x1, y1 = ', self.rectx1, self.recty1)
def stopRect(self, event):
#Translate mouse screen x1,y1 coordinates to canvas coordinates
self.rectx1 = self.canvas.canvasx(event.x)
self.recty1 = self.canvas.canvasy(event.y)
#Modify rectangle x1, y1 coordinates
self.canvas.coords(self.rectid, self.rectx0, self.recty0,
self.rectx1, self.recty1)
print('Rectangle ended')
if __name__ == "__main__":
root = tk.Tk()
root.geometry( "600x400" )
app = App(root)
root.mainloop()
Обзор используемых шагов и методов:
- Создайте виджет холста в
Tk()
окне, используя метод tk.Canvas()
- Привяжите события мыши
<Button-1>
, <ButtonRelease-1>
и <B1-Motion>
с их обратными вызовами к виджету tk.Canvas
.
- Для каждого из этих событий:
3.1 Преобразуйте координаты x, y указателя мыши на экране в координаты холста, используя методы .canvasx(event.x)
и .canvasy(event.y)
, и сохраните эти преобразованные координаты в переменных self.rectx0
, self.recty0
, self.rectx1
, self.recty1
. event.x
и event.y
обеспечивают координаты экрана указателя мыши.
3.2 Используйте метод холста .create_rectangle(x0, y0, x1, y1, option, ...)
для создания прямоугольника или используйте метод холста .coords(tagOrId, x0, y0, x1, y1)
для изменения координат прямоугольника. Здесь x0
, y0
, x1
, y1
обозначают верхний левый и нижний правый углы прямоугольника с координатами холста x и y, а tagOrId
обозначает идентификатор прямоугольного объекта.
3.3 Только для <Button-1>
необходимо сохранить идентификатор созданного прямоугольного объекта в переменной. Эта переменная предоставляет значение для tagOrId всякий раз, когда .coords() method
вызывается во время <B1-Motion>
и <ButtonRelease-1>
.
person
Sun Bear
schedule
22.02.2017