基于PyQt6實現顏色選擇器小工具
程序流程
1. 界面設計
1.1 整體布局
該應用程序使用了PyQt6框架構建了一個簡單的顏色選擇器界面。整體布局采用了垂直布局(QVBoxLayout)和水平布局(QHBoxLayout)相結合的方式,實現了功能區(qū)與控制區(qū)的合理分布。
功能展示區(qū):位于界面的上部,通過一個標簽(QLabel)展示了所選顏色的預覽,并顯示了當前顏色的RGB值和十六進制值。
控制區(qū):位于界面的下部,包含三個旋鈕(QDial)分別用于調節(jié)紅色、綠色和藍色的強度值,以及兩個按鈕(QPushButton),分別用于復制當前顏色的RGB值和十六進制值到剪貼板。
1.2 控件設計
顏色預覽標簽:通過設置標簽的背景色來實時展示用戶選擇的顏色。
旋鈕控件:每個旋鈕的范圍被設定為0至255,對應了顏色三文素的最大值。旋鈕下方的小標簽用于顯示當前旋鈕的值。
按鈕控件:兩個按鈕分別用于觸發(fā)復制顏色值到剪貼板的操作。
2. 功能實現
2.1 顏色值的動態(tài)更新
當用戶旋轉任一旋鈕時,會觸發(fā)onDialValueChanged方法。此方法首先更新各旋鈕對應的數值標簽,然后根據三個旋鈕的當前值重新設置顏色預覽標簽的背景色,同時更新顏色值顯示區(qū)域的內容。
2.2 復制顏色值
應用程序提供了兩種方式復制顏色值:
復制RGB值:點擊“復制RGB顏色”按鈕時,會將當前顏色的RGB值以字符串形式復制到系統(tǒng)剪貼板。
復制十六進制值:點擊“復制16進制顏色”按鈕時,同樣將顏色值以十六進制的形式復制到剪貼板。
3. 代碼結構
3.1 類定義
MyWidget類繼承自QWidget,是整個應用的核心部分,包含了所有界面元素的初始化及事件處理邏輯。
3.2 初始化方法
在__init__構造函數中,完成了界面元素的創(chuàng)建、布局設置、信號槽連接等操作,確保了應用程序啟動后能夠正確顯示并響應用戶的交互。
3.3 事件處理
onDialValueChanged方法負責處理旋鈕值變化的事件,實現了顏色值的動態(tài)更新。
on_btn_clicked和on_btn_clicked2方法則分別對應了兩個按鈕的點擊事件,實現了顏色值的復制功能。
完整代碼
import sys
import pyperclip
from PyQt6.QtCore import Qt
from PyQt6.QtGui import QFont, QColor
from PyQt6.QtWidgets import QDialog, QPushButton, QVBoxLayout, QApplication, QWidget, QDial, QLabel, QHBoxLayout
class MyWidget(QWidget):
def __init__(self, parent=None):
super(MyWidget, self).__init__(parent)
self.setWindowTitle("顏色選擇器")
self.resize(800,400)
ww_layout = QVBoxLayout(self)
self.labelColor = QLabel()
# 設置標簽的背景色
self.labelColor.setAutoFillBackground(True)
palette = self.labelColor.palette()
palette.setColor(self.labelColor.backgroundRole(), QColor(255, 0, 0)) # 紅色背景
self.labelColor.setPalette(palette,)
self.ltk = QLabel()
self.ltext = QLabel()
self.ltext2 = QLabel()
self.ltext.setText("顏色值RGB:(255, 0, 0)")
# 添加按鈕
self.btn = QPushButton("復制RGB顏色")
self.btn.clicked.connect(self.on_btn_clicked)
self.btn.setFixedSize(100, 30)
self.btn2 = QPushButton("復制16進制顏色")
self.btn2.clicked.connect(self.on_btn_clicked2)
self.btn2.setFixedSize(100, 30)
self.ltext2.setText("顏色值16進制:#FF0000")
textVlayout = QVBoxLayout()
textVlayout.addWidget(self.labelColor)
textVlayout.addWidget(self.ltext)
textVlayout.addWidget(self.ltext2)
# self.bt 設置在 x = 200,y = 100
textVlayout.addWidget(self.btn)
textVlayout.addWidget(self.btn2)
# textVlayout.addWidget(self.btn)
textVlayout.addWidget(self.ltk)
self.dial = QDial()
self.dial.setRange(0,255)
self.dial.setNotchesVisible(True)
self.dial.valueChanged.connect(self.onDialValueChanged)
self.lb = QLabel('0', self)
self.lb.setAlignment(Qt.AlignmentFlag.AlignCenter)
self.lb.setFont(QFont('Arial Black', 16))
self.dial2 = QDial()
self.dial2.setRange(0, 255)
self.dial2.setNotchesVisible(True)
self.dial2.valueChanged.connect(self.onDialValueChanged)
self.lb2 = QLabel('0', self)
self.lb2.setAlignment(Qt.AlignmentFlag.AlignCenter)
self.lb2.setFont(QFont('Arial Black', 16))
self.dial3 = QDial()
self.dial3.setRange(0, 255)
self.dial3.setNotchesVisible(True)
self.dial3.valueChanged.connect(self.onDialValueChanged)
self.lb3=QLabel('0',self)
self.lb3.setAlignment(Qt.AlignmentFlag.AlignCenter)
self.lb3.setFont(QFont('Arial Black',16))
hlayout = QHBoxLayout(self)
vlayout = QVBoxLayout(self)
vlayout.addWidget(self.dial)
vlayout.addWidget(self.lb)
vlayout2 = QVBoxLayout(self)
vlayout2.addWidget(self.dial2)
vlayout2.addWidget(self.lb2)
vlayout3 = QVBoxLayout(self)
vlayout3.addWidget(self.dial3)
vlayout3.addWidget(self.lb3)
hlayout.addLayout(vlayout)
hlayout.addLayout(vlayout2)
hlayout.addLayout(vlayout3)
# self.setLayout(hlayout)
ww_layout.addLayout(textVlayout)
ww_layout.addLayout(hlayout)
self.setLayout(ww_layout)
def onDialValueChanged(self):
self.lb.setText(str(self.dial.value()))
self.lb2.setText(str(self.dial2.value()))
self.lb3.setText(str(self.dial3.value()))
palette = self.labelColor.palette()
palette.setColor(self.labelColor.backgroundRole(), QColor(self.dial.value(), self.dial2.value(), self.dial3.value())) # 紅色背景
self.labelColor.setPalette(palette)
self.ltext.setText("顏色值RGB:(%s, %s, %s)" % (self.dial.value(), self.dial2.value(), self.dial3.value()))
self.ltext2.setText("顏色值16進制:#%02X%02X%02X" % (self.dial.value(), self.dial2.value(), self.dial3.value()))
def on_btn_clicked(self):
# 將RGB顏色值復制到剪貼板
pyperclip.copy("顏色值RGB:(%s, %s, %s)" % (self.dial.value(), self.dial2.value(), self.dial3.value()))
self.ltk.setText("顏色值RGB—復制成功")
def on_btn_clicked2(self):
# 將16進制顏色值復制到剪貼板
pyperclip.copy("顏色值16進制:#%02X%02X%02X" % (self.dial.value(), self.dial2.value(), self.dial3.value()))
self.ltk.setText("顏色值16進制—復制成功")
if __name__=='__main__':
app = QApplication(sys.argv)
w = MyWidget()
w.show()
sys.exit(app.exec())
效果圖

到此這篇關于基于PyQt6實現顏色選擇器小工具的文章就介紹到這了,更多相關PyQt6顏色選擇器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
python 創(chuàng)建一個空dataframe 然后添加行數據的實例
今天小編就為大家分享一篇python 創(chuàng)建一個空dataframe 然后添加行數據的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
python免殺技術shellcode的加載與執(zhí)行
本文主要介紹了python免殺技術shellcode的加載與執(zhí)行,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04

