您好,登錄后才能下訂單哦!
小編給大家分享一下PyQt5如何使用mimeData實現拖拽事件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
1、簡要介紹QMimeData
2、QMimeData的用例1:在QT實現輸入框的文字拖拽
3、QMimeData的用例2:在QT實現按鈕拖動
兩個用例的實現效果如下:
用例1:
用例2:
首先是創建QDrag,可以在mousePressEvent、mouseMoveEvent、dragMoveEvent中創建。
QDrag在exec前,一定要設置QMimeData,否則不會開始拖拽操作。
QMimeData在拖拽中非常有用,可以用來保存拖拽操作附帶的信息,比如字符串、文件或者圖片,同時也可以用來驗證其所保存的信息格式,并以此來判斷是否可接收。
另外要注意,在windows下,QDrag::exec()是個同步操作,要在exec()返回后,才會繼續執行下面的代碼。
首先,當需要一個控件接收drag和drop,就要先調用控件的方法:setAcceptDrops(True)。
qt中一共有三個drag相關事件,dragEnterEvent、dragMoveEvent、dragLeaveEvent。這三個事件觸發條件類似鼠標移入,鼠標移動,鼠標移出。當鼠標拖拽進入控件觸發dragEnterEvent,在控件內拖拽移動觸發dragMoveEvent,鼠標拖拽離開控件觸發dragLeaveEvent。
當drag為accept狀態,然后釋放鼠標,就會產生dropEvent。我們可以在這個事件里處理本次拖拽附帶的Mime信息。
# -*- coding: utf-8 -*- import sys from PyQt5.QtCore import Qt, QMimeData from PyQt5.QtGui import QDrag from PyQt5.QtWidgets import QWidget, QLineEdit, QApplication, QSplitter, QHBoxLayout class MyLineEdit(QLineEdit): def __init__(self, parent): super().__init__(parent) self.setAcceptDrops(True) def dragMoveEvent(self, event): drag = QDrag(self) mime = QMimeData() drag.setMimeData(mime) drag.exec(Qt.CopyAction) def dragEnterEvent(self, event): if event.mimeData().hasText(): event.accept() else: event.ignore() def dropEvent(self, event): self.setText(event.mimeData().text()) event.source().setText("") class SimpleDrag(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): hlayout = QHBoxLayout(self) edit1 = MyLineEdit(self) edit1.setDragEnabled(True) edit2 = MyLineEdit(self) edit2.setDragEnabled(True) splitter = QSplitter(Qt.Horizontal) splitter.addWidget(edit1) splitter.addWidget(edit2) hlayout.addWidget(splitter) self.setLayout(hlayout) self.setWindowTitle('簡易的拖動事件') if __name__ == '__main__': app = QApplication(sys.argv) ex = SimpleDrag() ex.show() app.exec_()
關鍵解析:
在自定義控件中:
1、我們創建了一個繼承自Qt的QLineEdit的輸入框
2、在dragMoveEvent中創建了QDrag,并且設置了drag的mimeData,接著對QDrag調用exec方法
3、在dragEnterEvent中接收了該事件 即對應代碼的 event.accept()
4、在dropEvent 中 對事件進行了放的處理
在主窗口中:
1、設置該窗口可以接收拖拽事件setDragEnabled(True)
這就完美對應上面的QMimeData的使用啦
# -*- coding: utf-8 -*- import sys from PyQt5.QtWidgets import QPushButton, QWidget, QApplication from PyQt5.QtCore import Qt, QMimeData from PyQt5.QtGui import QDrag class Button(QPushButton): def __init__(self, title, parent): super().__init__(title, parent) def mouseMoveEvent(self, e): if e.buttons() != Qt.LeftButton: return mimeData = QMimeData() drag = QDrag(self) drag.setMimeData(mimeData) drag.setHotSpot(e.pos() - self.rect().topLeft()) drag.exec_(Qt.MoveAction) class Example(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): self.setAcceptDrops(True) self.button = Button('Button', self) self.button.move(100, 65) self.setWindowTitle('Click or Move') self.setGeometry(300, 300, 280, 150) def dragEnterEvent(self, e): e.accept() def dropEvent(self, e): position = e.pos() self.button.move(position) e.setDropAction(Qt.MoveAction) e.accept() if __name__ == '__main__': app = QApplication(sys.argv) ex = Example() ex.show() app.exec_()
關鍵解析:
在自定義控件中:
1、我們創建了一個繼承自Qt的QPushButton的按鈕
2、在mouseMoveEvent中創建了QDrag,并且設置了drag的mimeData,接著對QDrag調用exec方法
在主窗口中:
1、設置該窗口可以接收拖拽事件setDragEnabled(True)
2、在dropEvent 中 對事件進行了放的處理,改變按鈕的位置
1、在dragEnterEvent中接收了該事件 即對應代碼的 event.accept()
第二個例子跟第一個有點不一樣,因為第一個例子中,放的事件給到輸入框 MyLineEdit
而第二個例子中,此時接收放事件的控件是主窗口 Example(QWidget)
以上是“PyQt5如何使用mimeData實現拖拽事件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。