PyQt - 拖放


拖放功能对于用户来说非常直观。它存在于许多桌面应用程序中,用户可以将对象从一个窗口复制或移动到另一个窗口。

基于 MIME 的拖放数据传输基于 QDrag 类。QMimeData对象将数据与其相应的 MIME 类型相关联。它存储在剪贴板上,然后在拖放过程中使用。

下面的QMimeData类函数可以方便地检测和使用MIME类型。

测试员 吸气剂 塞特 MIME 类型
有文本() 文本() 设置文本() 文本/纯文本
hasHtml() html() 设置Html() 文本/html
hasUrls() 网址() 设置网址() 文本/uri-列表
有图像() 图像数据() 设置图像数据() 图像/ *
有颜色() 颜色数据() 设置颜色数据() 应用程序/x-颜色

许多 QWidget 对象支持拖放活动。那些允许拖动数据的 setDragEnabled() 必须设置为 true。另一方面,小部件应该响应拖放事件,以便存储拖入其中的数据。

  • DragEnterEvent提供了一个事件,当拖动操作进入目标窗口小部件时,该事件会发送到目标窗口小部件。

  • DragMoveEvent在拖放操作正在进行时使用。

  • 当拖放操作离开小部件时,会生成DragLeaveEvent 。

  • 另一方面,DropEvent在放置完成时发生。事件提议的行动可以有条件地接受或拒绝。

例子

在以下代码中,DragEnterEvent 验证事件的 MIME 数据是否包含文本。如果是,则接受事件建议的操作,并将文本作为新项目添加到组合框中。

import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *

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("Type some text in textbox and drag it into combo box"))
		
      edit = QLineEdit()
      edit.setDragEnabled(True)
      com = combo("Button", self)
      lo.addRow(edit,com)
      self.setLayout(lo)
      self.setWindowTitle('Simple drag & drop')
		
def main():
   app = QApplication(sys.argv)
   ex = Example()
   ex.show()
   app.exec_()
	
if __name__ == '__main__':
   main()

上面的代码产生以下输出 -

拖放输出