1. 程式人生 > 程式設計 >python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

本篇,我們學習PyQt5介面中拖放(Drag 和Drop)控制元件。

拖放動作

在GUI中,拖放指的是點選一個物件,並將其拖動到另一個物件上的動作。比如百度雲PC客戶端支援的拖放檔案以快速移動檔案:

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

拖放動作能夠很直觀很方便的在GUI程式中完成一些很複雜或繁瑣的操作。

在PyQt中實現拖放

在PyQt5中,我們也可以很輕鬆地使用拖放功能。

使用Qt設計師或者使用API都可以實現。我們先使用Qt設計師將GUI的圖形設計出來,在之前的GUI的基礎上,我們新建一個選項卡。

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

我們新建了一個選項卡,然後在裡面放置了一個LineEdit部件,一個PushButton部件,兩個ListWidget部件。

對於簡單的拖放效果,我們可以直接使用Qt設計師中的選項進行設定。例如,我們直接可以使用dragEnable屬性、dragDropOverwriteMode屬性、dragDropMode屬性為ListWidget部件設定拖放功能:

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

而一些稍微複雜的拖放功能,就需要編寫Python邏輯處理程式碼來完成了。

我們先將UI檔案儲存並轉換為Python檔案。

pyuic5 -o conplex_window_drag.py conplex_window.ui

然後,新建一個Python文嘉drag.py,在檔案中引入剛剛轉換好的Python檔案:

# coding:utf-8
# 州的先生 zmister.com Python GUI教程

from PyQt5 import QtCore,QtWidgets,QtGui
from GUI import conplex_window_drag
import sys
import time

class MainWindow(object):
  def __init__(self):
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    self.ui = conplex_window_drag.Ui_MainWindow()
    self.ui.setupUi(MainWindow)

    self.update_date()
    self.update_calendar()

    self.set_lcd()
    self.set_dial()

    self.update_progressbar()

    self.set_font()
    MainWindow.show()
    sys.exit(app.exec_())

  # 修改日期修改器數值
  def update_date(self):
    self.ui.dateEdit.setDate(self.ui.calendarWidget.selectedDate())

  # 日曆訊號槽
  def update_calendar(self):
    self.ui.calendarWidget.selectionChanged.connect(self.update_date)

  # 設定LCD數字
  def set_lcd(self):
    self.ui.lcdNumber.display(self.ui.dial.value())

  # 刻度盤訊號槽
  def set_dial(self):
    self.ui.dial.valueChanged['int'].connect(self.set_lcd)

  # 州的先生 zmister.com
  # 按鈕訊號槽
  def update_progressbar(self):
    self.ui.radioButton.clicked.connect(self.start_progressbar)
    self.ui.radioButton_2.clicked.connect(self.stop_progressbar)
    self.ui.radioButton_3.clicked.connect(self.reset_progressbar)
    self.progress_value = 0
    self.stop_progress = False

  def progressbar_counter(self,start_value=0):
    self.run_thread = RunThread(parent=None,counter_start=start_value)
    self.run_thread.start()
    self.run_thread.counter_value.connect(self.set_progressbar)

  def set_progressbar(self,counter):
    if not self.stop_progress:
      self.ui.progressBar.setValue(counter)

  # 啟動進度欄
  def start_progressbar(self):
    self.stop_progress = False
    self.progress_value = self.ui.progressBar.value()
    self.progressbar_counter(self.progress_value)

  # 停止進度欄
  def stop_progressbar(self):
    self.stop_progress = True
    try:
      self.run_thread.stop()
    except:
      pass
  # 重設進度欄
  def reset_progressbar(self):
    self.stop_progressbar()
    self.progress_value = 0
    self.ui.progressBar.reset()
    self.stop_progress = False

  # 字型選擇
  def set_font(self):
    self.ui.fontComboBox.activated['QString'].connect(self.ui.label.setText)

class RunThread(QtCore.QThread):
  # 定義一個新的訊號
  counter_value = QtCore.pyqtSignal(int)

  def __init__(self,parent=None,counter_start=0):
    super(RunThread,self).__init__(parent)
    self.counter = counter_start
    self.is_running = True

  def run(self):
    while self.counter < 100 and self.is_running == True:
      time.sleep(0.1)
      self.counter += 1
      print(self.counter)
      # 發出一個新值的訊號
      self.counter_value.emit(self.counter)

  def stop(self):
    self.is_running = False
    print('執行緒停止中...')
    self.terminate()

if __name__ == "__main__":
  MainWindow()

執行程式碼正常:

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

接著,我們建立一個DragDropButton()類,用來處理按鈕的拖放:

class DragDropButton(QtWidgets.QPushButton):
  
  def __init__(self,text,parent):
    super().__init__(text,parent)    
    self.setAcceptDrops(True)
    
  def dragEnterEvent(self,event):
    if event.mimeData().hasFormat('text/plain'):
      event.accept()
    else:
      event.ignore()
      
  def dropEvent(self,event):
    self.setText(event.mimeData().text())

我們使用setAcceptDrops屬性設定按鈕接收拖放事件,建立一個dragEnterEvent()方法用來設定拖的事件響應,建立一個dropEvent()方法用來設定放的事件響應。

接著我們在MainWindow()主類中,呼叫它:

class MainWindow(object):
  def __init__(self):
    ……
    self.ui.pushButton.hide()
    self.pushButton = DragDropButton("拖放按鈕",MainWindow)
    self.ui.gridLayout_5.addWidget(self.pushButton,1,2)
    ……

最後,執行一下看看:

python GUI庫圖形介面開發之PyQt5拖放控制元件例項詳解

在上面的程式中,我們能夠將文字拖放到按鈕上。

好了python GUI庫圖形介面開發中PyQt5拖放控制元件的例項就是這些,更多關於python PyQt5 GUI庫圖形介面開發請檢視下面的相關連結