Dernière fois suite
Drag & drop Je vais résumer grossièrement ce site en japonais.
Simple_drag_and_drop.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtWidgets import (QPushButton, QWidget, 
    QLineEdit, QApplication)
#Hériter de QPushButton
class Button(QPushButton):
  
    def __init__(self, title, parent):
        super().__init__(title, parent)
        
        #Permet de déposer les boutons
        self.setAcceptDrops(True)
        
    def dragEnterEvent(self, e):
        
        #Définir le format de données déplaçables
        if e.mimeData().hasFormat('text/plain'):
            e.accept()
        else:
            e.ignore() 
    def dropEvent(self, e):
        
        #Permuter les libellés des boutons lorsqu'ils sont déposés
        self.setText(e.mimeData().text()) 
class Example(QWidget):
  
    def __init__(self):
        super().__init__()
        
        self.initUI()
        
        
    def initUI(self):
        edit = QLineEdit('', self)
        #Faites-le glisser
        edit.setDragEnabled(True)
        edit.move(30, 65)
        button = Button("Button", self)
        button.move(250, 65)
        
        self.setWindowTitle('Simple drag & drop')
        self.setGeometry(300, 300, 300, 150)
if __name__ == '__main__':
  
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    app.exec_()
Etat initial

Après glisser-déposer

Drag&drop_a_button_widget.py
#!/usr/bin/python3
# -*- 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):
        #Seul le clic droit peut être glissé et déposé
        if e.buttons() != Qt.RightButton:
            return
        #Remplacez le format de données à glisser-déposer
        mimeData = QMimeData()
        drag = QDrag(self)
        drag.setMimeData(mimeData)
        #Réglez le coin supérieur gauche du bouton à la position de chute
        drag.setHotSpot(e.pos() - self.rect().topLeft())
        dropAction = drag.exec_(Qt.MoveAction)
    def mousePressEvent(self, e):
      
        #Changement de couleur du bouton lorsque vous appuyez sur le bouton
        QPushButton.mousePressEvent(self, e)
        
        #Appuyez sur l'affichage sur la console lorsque vous cliquez dessus
        if e.button() == Qt.LeftButton:
            print('press')
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):
        #Placez le bouton à la position de la souris après avoir fait glisser
        position = e.pos()
        self.button.move(position)
        #Eh bien, je ne sais pas
        e.setDropAction(Qt.MoveAction)
        e.accept()
        
if __name__ == '__main__':
  
    app = QApplication(sys.argv)
    ex = Example()
    ex.show()
    app.exec_()  
 
La prochaine fois essaiera approximativement Painting.
Recommended Posts