您好,登錄后才能下訂單哦!
小編給大家分享一下PyQt5如何使用mimeData實現(xiàn)拖拽事件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
1、簡要介紹QMimeData
2、QMimeData的用例1:在QT實現(xiàn)輸入框的文字拖拽
3、QMimeData的用例2:在QT實現(xiàn)按鈕拖動
兩個用例的實現(xiàn)效果如下:
用例1:
用例2:
首先是創(chuàng)建QDrag,可以在mousePressEvent、mouseMoveEvent、dragMoveEvent中創(chuàng)建。
QDrag在exec前,一定要設(shè)置QMimeData,否則不會開始拖拽操作。
QMimeData在拖拽中非常有用,可以用來保存拖拽操作附帶的信息,比如字符串、文件或者圖片,同時也可以用來驗證其所保存的信息格式,并以此來判斷是否可接收。
另外要注意,在windows下,QDrag::exec()是個同步操作,要在exec()返回后,才會繼續(xù)執(zhí)行下面的代碼。
首先,當(dāng)需要一個控件接收drag和drop,就要先調(diào)用控件的方法:setAcceptDrops(True)。
qt中一共有三個drag相關(guān)事件,dragEnterEvent、dragMoveEvent、dragLeaveEvent。這三個事件觸發(fā)條件類似鼠標(biāo)移入,鼠標(biāo)移動,鼠標(biāo)移出。當(dāng)鼠標(biāo)拖拽進入控件觸發(fā)dragEnterEvent,在控件內(nèi)拖拽移動觸發(fā)dragMoveEvent,鼠標(biāo)拖拽離開控件觸發(fā)dragLeaveEvent。
當(dāng)drag為accept狀態(tài),然后釋放鼠標(biāo),就會產(chǎn)生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_()
關(guān)鍵解析:
在自定義控件中:
1、我們創(chuàng)建了一個繼承自Qt的QLineEdit的輸入框
2、在dragMoveEvent中創(chuàng)建了QDrag,并且設(shè)置了drag的mimeData,接著對QDrag調(diào)用exec方法
3、在dragEnterEvent中接收了該事件 即對應(yīng)代碼的 event.accept()
4、在dropEvent 中 對事件進行了放的處理
在主窗口中:
1、設(shè)置該窗口可以接收拖拽事件setDragEnabled(True)
這就完美對應(yīng)上面的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_()
關(guān)鍵解析:
在自定義控件中:
1、我們創(chuàng)建了一個繼承自Qt的QPushButton的按鈕
2、在mouseMoveEvent中創(chuàng)建了QDrag,并且設(shè)置了drag的mimeData,接著對QDrag調(diào)用exec方法
在主窗口中:
1、設(shè)置該窗口可以接收拖拽事件setDragEnabled(True)
2、在dropEvent 中 對事件進行了放的處理,改變按鈕的位置
1、在dragEnterEvent中接收了該事件 即對應(yīng)代碼的 event.accept()
第二個例子跟第一個有點不一樣,因為第一個例子中,放的事件給到輸入框 MyLineEdit
而第二個例子中,此時接收放事件的控件是主窗口 Example(QWidget)
以上是“PyQt5如何使用mimeData實現(xiàn)拖拽事件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。