Python PyQt5實(shí)現(xiàn)拖拽與剪貼板功能詳解
拖拽
基于MIME類型的拖拽數(shù)據(jù)傳輸時基于QDrag類的QMimeData對象管理的數(shù)據(jù)與其對應(yīng)的MIME類型相關(guān)聯(lián)。
MimeData類函數(shù)允許檢測和使用方法的MIME類型
判斷函數(shù) | 設(shè)置函數(shù) | 獲取函數(shù) | MIME類型 |
---|---|---|---|
hasText() | text() | setText() | text/plain |
hasHtml() | html() | setHtml() | text/html |
hasUrls() | urls() | setUrls() | text/uri-list |
hasImage() | imageData() | setImageData() | image/* |
hasColor() | colorData() | setColorData() | application/x-color |
常用拖拽事件
事件 | 描述 |
---|---|
DragEnterEvent | 當(dāng)執(zhí)行一個拖拽控件操作,并且鼠標(biāo)指針進(jìn)入該控件時被觸發(fā) |
DragMoveEvent | 在拖拽操作進(jìn)行時會觸發(fā)該事件 |
DragLeaveEvent | 當(dāng)執(zhí)行一個拖拽控件操作,并且鼠標(biāo)指針離開該控件時被觸發(fā) |
DropEvent | 當(dāng)拖拽操作在目標(biāo)控件上被釋放時,觸發(fā)該事件 |
import sys from PyQt5.QtGui import * from PyQt5.QtCore import * from PyQt5.QtWidgets import * from PyQt5.QtCore import Qt class Combo(QComboBox): def __init__(self, title, parent): super(Combo, self).__init__(parent) self.setAcceptDrops(True) def dragEnterEvent(self, e): print(e) if e.mimeData().hasText(): e.accept() else: e.ignore() def dropEvent(self, e): self.addItem(e.mimeData().text()) class Example(QWidget): def __init__(self): super(Example, self).__init__() self.initUI() def initUI(self): lo = QFormLayout() lo.addRow(QLabel("請把左邊的文本拖拽到右邊的下拉菜單中")) edit = QLineEdit() edit.setDragEnabled(True) com = Combo("Button", self) lo.addRow(edit, com) self.setLayout(lo) self.setWindowTitle("簡單的拖拽例子") if __name__ == "__main__": app = QApplication(sys.argv) win = Example() win.show() sys.exit(app.exec_())
剪貼板
QClipboard類提供了對系統(tǒng)剪貼板的訪問,可以在應(yīng)用程序之間復(fù)制和粘貼數(shù)據(jù)。它的操作類似于QDrag類,并使用類似的數(shù)據(jù)類型。
QApplication類有一個靜態(tài)方法clipboard(),返回剪貼板對象的引用。任何類型的MimeData都可以從剪貼板復(fù)制或粘貼。
QClipboard常用方法
方法 | 描述 |
---|---|
clear() | 清除剪貼板的內(nèi)容 |
setImage() | 將QImage對象復(fù)制到剪貼板中 |
setMimeData() | 將MIME數(shù)據(jù)設(shè)置為剪貼板 |
setPixmap() | 從剪貼板中復(fù)制Pixmap對象 |
setText() | 從剪貼板中復(fù)制文本 |
text() | 從剪貼板中檢索文本 |
QClipboard類中的常用信號
信號 | 含義 |
---|---|
dataChanged | 當(dāng)剪貼板內(nèi)容發(fā)生變化時觸發(fā)該信號 |
import os import sys from PyQt5.QtCore import QMimeData from PyQt5.QtWidgets import (QApplication, QDialog, QGridLayout, QLabel, QPushButton) from PyQt5.QtGui import QPixmap class Form(QDialog): def __init__(self, parent=None): super(Form, self).__init__(parent) textCopyButton = QPushButton("&Copy Text") textPasteButton = QPushButton("Paste &Text") htmlCopyButton = QPushButton("C&opy HTML") htmlPasteButton = QPushButton("Paste &HTML") imageCopyButton = QPushButton("Co&py Image") imagePasteButton = QPushButton("Paste &Image") self.textLabel = QLabel("Original text") self.imageLabel = QLabel() self.imageLabel.setPixmap(QPixmap(os.path.join(os.path.dirname(__file__), "images/clock.png"))) layout = QGridLayout() layout.addWidget(textCopyButton, 0, 0) layout.addWidget(imageCopyButton, 0, 1) layout.addWidget(htmlCopyButton, 0, 2) layout.addWidget(textPasteButton, 1, 0) layout.addWidget(imagePasteButton, 1, 1) layout.addWidget(htmlPasteButton, 1, 2) layout.addWidget(self.textLabel, 2, 0, 1, 2) layout.addWidget(self.imageLabel, 2, 2) self.setLayout(layout) textCopyButton.clicked.connect(self.copyText) textPasteButton.clicked.connect(self.pasteText) imageCopyButton.clicked.connect(self.copyImage) imagePasteButton.clicked.connect(self.pasteImage) htmlCopyButton.clicked.connect(self.copyHtml) htmlPasteButton.clicked.connect(self.pasteHtml) def copyText(self): print(os.path.join(os.path.dirname(__file__))) clipboard = QApplication.clipboard() clipboard.setText("I've been clipped") def pasteText(self): clipboard = QApplication.clipboard() self.textLabel.setText(clipboard.text()) def copyImage(self): clipboard = QApplication.clipboard() clipboard.setPixmap(QPixmap(os.path.join(os.path.dirname(__file__), "images/python.jpg"))) def pasteImage(self): clipboard = QApplication.clipboard() self.imageLabel.setPixmap(clipboard.pixmap()) def copyHtml(self): mimeData = QMimeData() mimeData.setHtml("<b>Bold and<font color=red>Red</font></b>") clipboard = QApplication.clipboard() clipboard.setMimeData(mimeData) def pasteHtml(self): clipboard = QApplication.clipboard() mimeData = clipboard.mimeData() if mimeData.hasHtml(): self.textLabel.setText(mimeData.html()) if __name__ == "__main__": app = QApplication(sys.argv) win = Form() win.show() sys.exit(app.exec_())
到此這篇關(guān)于Python PyQt5實(shí)現(xiàn)拖拽與剪貼板功能詳解的文章就介紹到這了,更多相關(guān)PyQt5拖拽 剪貼板內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python的xpath獲取div標(biāo)簽內(nèi)html內(nèi)容,實(shí)現(xiàn)innerhtml功能的方法
今天小編就為大家分享一篇python的xpath獲取div標(biāo)簽內(nèi)html內(nèi)容,實(shí)現(xiàn)innerhtml功能的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01基于Python實(shí)現(xiàn)評論區(qū)抽獎功能詳解
這篇文章主要為大家介紹了基于Python如何實(shí)現(xiàn)評論區(qū)抽獎的功能,文章的示例代碼講解詳細(xì),對我們學(xué)習(xí)Python有一定幫助,需要的朋友可以學(xué)習(xí)一下2021-12-12python實(shí)現(xiàn)京東訂單推送到測試環(huán)境,提供便利操作示例
這篇文章主要介紹了python實(shí)現(xiàn)京東訂單推送到測試環(huán)境,提供便利操作,涉及Python基于requests模塊的網(wǎng)絡(luò)請求操作相關(guān)使用技巧,需要的朋友可以參考下2019-08-08Python下實(shí)現(xiàn)的RSA加密/解密及簽名/驗(yàn)證功能示例
這篇文章主要介紹了Python下實(shí)現(xiàn)的RSA加密/解密及簽名/驗(yàn)證功能,結(jié)合具體實(shí)例形式分析了Python中RSA加密、解密的實(shí)現(xiàn)方法及簽名、驗(yàn)證功能的使用技巧,需要的朋友可以參考下2017-07-07在主機(jī)商的共享服務(wù)器上部署Django站點(diǎn)的方法
這篇文章主要介紹了在主機(jī)商的共享服務(wù)器上部署Django站點(diǎn)的方法,Django是最具人氣的Python框架,需要的朋友可以參考下2015-07-07Python中JSON常見用法(json.load()、json.loads()、json.dump()、json.du
本文主要介紹了Python中JSON常見用法(json.load()、json.loads()、json.dump()、json.dumps()),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06將數(shù)據(jù)集制作成VOC數(shù)據(jù)集格式的實(shí)例
今天小編就為大家分享一篇將數(shù)據(jù)集制作成VOC數(shù)據(jù)集格式的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02