我們接下來的討論,會基於讀者已經先讀過我 day5 文章 的架構下去進行程式設計
如果還不清楚我程式設計的邏輯 (UI.py、controller.py、start.py 分別在幹麻)
建議先閱讀 day5 文章後再來閱讀此文。
https://www.wongwonggoods.com/python/pyqt5-5/
https://github.com/howarder3/ironman2021_PyQt5_photoshop/tree/main/day14_slider
今天我們要來實作一個簡單的功能,製作可以滑動的滑條
我們在 input Widgets 中找到 Horizontal Slider,將他移進畫面中,
另外加入一個 Qlabel 作為顯示用。
讀者們可以開始自行設計自己的介面囉,以上為我的示範。
一樣的編譯指令,我們加上 -x (也可不加),
我們就可以先檢視看看轉換後的視窗是不是跟我們想像的一樣。
pyuic5 -x day14.ui -o UI.py
一樣,這程式只有介面 (視覺上的呈現),沒有任何互動功能
python UI.py
這樣我們的介面就大致出來囉!
這次的功能很簡單,只有兩個物件
我們繼續修改我們 day12 的程式碼
from PyQt5 import QtCore, QtWidgets
from PyQt5.QtGui import QImage, QPixmap
from PyQt5.QtWidgets import QFileDialog
from PyQt5.QtCore import QThread, pyqtSignal
import time
from UI import Ui_MainWindow
class MainWindow_controller(QtWidgets.QMainWindow):
def __init__(self):
super().__init__() # in python3, super(Class, self).xxx = super().xxx
self.ui = Ui_MainWindow()
self.ui.setupUi(self)
self.setup_control()
def setup_control(self):
self.ui.horizontalSlider.valueChanged.connect(self.getslidervalue)
def getslidervalue(self):
self.ui.label.setText(f"{self.ui.horizontalSlider.value()}")
print(self.ui.horizontalSlider.value())
self.ui.horizontalSlider.valueChanged.connect(self.getslidervalue)
我們一樣將 self.horizontalSlider 連結 getslidervalue() 的功能,
等等我們將取得變化後的實作,製作在此處。
記得要多呼叫 valueChanged 這個方法,
我們才能夠透過偵測滑動條值的變化,直接同步反應數值的改變到畫面上。
我們可以使用 self.ui.horizontalSlider.value() 取得現在滑動條的數值,
而 self.getslidervalue() 已經定義好是有變化才會觸發的功能,
所以我們就藉由 self.ui.label.setText() 把對應的數值寫進 label 當中。
照我們 day5 的程式架構,我們執行
python start.py
(因為我們有寫 print,所以在 terminal 中也會同步印出數據,讓我們能夠觀察變化。)
★ 本文也同步發於我的個人網站(會有內容目錄與顯示各個小節,閱讀起來更流暢):【PyQt5】Day 14 使用 QSlider 製作可拖曳的滑條