如何在 PyQt5 中通过拖放来绘制矩形并调整其形状

Posted

技术标签:

【中文标题】如何在 PyQt5 中通过拖放来绘制矩形并调整其形状【英文标题】:How to draw a rectangle and adjust its shape by drag and drop in PyQt5 【发布时间】:2017-06-10 01:51:18 【问题描述】:

我正在尝试通过拖放在 PyQt5 创建的 GUI 上绘制一个矩形。我设法做到了,但是释放鼠标左键时会绘制矩形。

我想做的就是这样link:

当按下鼠标左键时,开始绘制矩形。 拖动时,用鼠标移动调整矩形形状。 释放鼠标左键时,确定矩形形状。

我该如何实现呢?提前致谢。

这是我的代码。

# -*- coding: utf-8 -*-

import sys
from PyQt5 import QtWidgets, QtCore
from PyQt5.QtGui import QPainter

class MyWidget(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        self.setGeometry(30,30,600,400)
        self.pos1 = [0,0]
        self.pos2 = [0,0]
        self.show()

    def paintEvent(self, event):
        width = self.pos2[0]-self.pos1[0]
        height = self.pos2[1] - self.pos1[1]     

        qp = QPainter()
        qp.begin(self)           
        qp.drawRect(self.pos1[0], self.pos1[1], width, height)        
        qp.end()

    def mousePressEvent(self, event):
        self.pos1[0], self.pos1[1] = event.pos().x(), event.pos().y()
        print("clicked")

    def mouseReleaseEvent(self, event):
        self.pos2[0], self.pos2[1] = event.pos().x(), event.pos().y()
        print("released")
        self.update()

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    window = MyWidget()
    window.show()
    app.aboutToQuit.connect(app.deleteLater)
    sys.exit(app.exec_())

【问题讨论】:

【参考方案1】:

您不必使用mouseReleaseEvent 函数,而是每次移动鼠标时调用的mouseMoveEvent 函数,并且我已经修改了代码以使其更简单。

class MyWidget(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        self.setGeometry(30,30,600,400)
        self.begin = QtCore.QPoint()
        self.end = QtCore.QPoint()
        self.show()

    def paintEvent(self, event):
        qp = QtGui.QPainter(self)
        br = QtGui.QBrush(QtGui.QColor(100, 10, 10, 40))  
        qp.setBrush(br)   
        qp.drawRect(QtCore.QRect(self.begin, self.end))       

    def mousePressEvent(self, event):
        self.begin = event.pos()
        self.end = event.pos()
        self.update()

    def mouseMoveEvent(self, event):
        self.end = event.pos()
        self.update()

    def mouseReleaseEvent(self, event):
        self.begin = event.pos()
        self.end = event.pos()
        self.update()

【讨论】:

感谢您的回答和修改我的代码。这正是我一直在寻找的。​​span> 如果我再画一个矩形,前一个矩形就会消失。为什么?

以上是关于如何在 PyQt5 中通过拖放来绘制矩形并调整其形状的主要内容,如果未能解决你的问题,请参考以下文章

有没有办法在 devexpress TreeListControl 中通过拖放重新排列节点时预览元素的位置?

在 django 中通过拖放对项目进行排序

在 Phonegap 中通过拖放使 jQuery Mobile 列表视图可排序

如何通过鼠标拖放来更改布局中小部件的顺序?

在本机反应中绘制拖放矩形

在表格中使用 jQuery 拖放来为每次拖动创建一个副本