如何利用PyQt5美化你的GUI界面
1 圓點(diǎn)選擇選項(xiàng)設(shè)置
效果展示
代碼參考
#!/usr/bin/python # -*- coding:utf-8 -*- import sys from PyQt5 import QtWidgets, QtCore from PyQt5.QtWidgets import * class qt_view(QWidget): def __init__(self): super(qt_view, self).__init__() self.resize(600, 250) self.setWindowTitle("圓點(diǎn)選擇") self.radioButton_1 = QtWidgets.QRadioButton(self) self.radioButton_1.setGeometry(QtCore.QRect(230, 100, 89, 16)) self.radioButton_1.setStyleSheet("font-family:微軟雅黑; color:black;") self.radioButton_1.setObjectName("radioButton_1") self.radioButton_2 = QtWidgets.QRadioButton(self) self.radioButton_2.setGeometry(QtCore.QRect(310, 100, 89, 16)) self.radioButton_2.setStyleSheet("font-family:微軟雅黑; color:black;") self.radioButton_2.setObjectName("radioButton_2") translate = QtCore.QCoreApplication.translate self.radioButton_1.setText(translate("Form", "選項(xiàng)1")) self.radioButton_2.setText(translate("Form", "選項(xiàng)2")) if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) my = qt_view() my.show() app.exec_()
2 選項(xiàng)按鈕設(shè)置
效果展示
代碼參考
import sys from PyQt5 import QtWidgets, QtCore from PyQt5.QtWidgets import * class qt_view(QWidget): def __init__(self): super(qt_view, self).__init__() self.resize(600, 250) self.setWindowTitle("圓灰按鈕") button_open_img = QPushButton(self) button_open_img.setText("打開(kāi)圖片") button_open_img.move(250, 100) button_open_img.setFixedSize(150, 50) button_open_img.setStyleSheet("QPushButton{\n" " background:orange;\n" " color:white;\n" " box-shadow: 1px 1px 3px;font-size:18px;border-radius: 24px;font-family: 微軟雅黑;\n" "}\n" "QPushButton:pressed{\n" " background:black;\n" "}") if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) my = qt_view() my.show() app.exec_()
3 關(guān)閉彈窗設(shè)置
效果展示
代碼參考
import sys from PyQt5 import QtWidgets, QtCore from PyQt5.QtWidgets import * class qt_view(QWidget): def __init__(self): super(qt_view, self).__init__() print("關(guān)閉彈窗") result = QMessageBox.question(self, "注意!", "您真的要關(guān)閉嗎?", QMessageBox.Yes | QMessageBox.No, QMessageBox.No) if result == QMessageBox.Yes: QMessageBox.information(self, "消息", "謝謝使用!") quit() else: QMessageBox.information(self, "消息", "正在返回...") quit() if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) my = qt_view() my.show() app.exec_()
4 關(guān)閉程序彈窗
效果展示
代碼參考
from PyQt5 import QtWidgets import sys class Ui_Dialog(object): def setupUi(self, Dialog): Dialog.setObjectName("Dialog") Dialog.resize(600, 320) class Dialog(QtWidgets.QMainWindow): def closeEvent(self, event): reply = QtWidgets.QMessageBox.question(self, '本程序', "是否要退出程序?", QtWidgets.QMessageBox.Yes | QtWidgets.QMessageBox.No, QtWidgets.QMessageBox.No) if reply == QtWidgets.QMessageBox.Yes: event.accept() else: event.ignore() if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) dialog = Dialog() ui = Ui_Dialog() ui.setupUi(dialog) dialog.show() sys.exit(app.exec_())
5 設(shè)置關(guān)閉按鈕
效果展示
代碼參考
import sys from PyQt5 import QtWidgets, QtCore from PyQt5.QtWidgets import * from PyQt5.QtCore import * class gui_view(QWidget): def __init__(self): super(gui_view, self).__init__() self.resize(500, 350) self.setWindowFlags(Qt.FramelessWindowHint) # 去邊框 # # self.setAttribute(Qt.WA_TranslucentBackground) # 設(shè)置窗口背景透明 button_red = QPushButton(self) button_red.move(20, 20) button_red.setFixedSize(20, 20) button_red.setStyleSheet("QPushButton{\n" " background:#CE0000;\n" " color:white;\n" " box-shadow: 1px 1px 3px;border-radius: 10px;\n" "}\n" "QPushButton:hover{ \n" " background:red;\n" "}\n" "QPushButton:pressed{\n" " border: 1px solid #3C3C3C!important;\n" " background:black;\n" "}") button_red.clicked.connect(self.quit_button) button_orange = QPushButton(self) button_orange.move(50, 20) button_orange.setFixedSize(20, 20) button_orange.setStyleSheet("QPushButton{\n" " background:orange;\n" " color:white;\n" " box-shadow: 1px 1px 3px;border-radius: 10px;\n" "}\n" "QPushButton:hover{ \n" " background:yellow;\n" "}\n" "QPushButton:pressed{\n" " border: 1px solid #3C3C3C!important;\n" " background:black;\n" "}") button_green = QPushButton(self) button_green.move(80, 20) button_green.setFixedSize(20, 20) button_green.setStyleSheet("QPushButton{\n" " background:green;\n" " color:white;\n" " box-shadow: 1px 1px 3px;border-radius: 10px;\n" "}\n" "QPushButton:hover{ \n" " background:#08BF14;\n" "}\n" "QPushButton:pressed{\n" " border: 1px solid #3C3C3C!important;\n" " background:black;\n" "}") def quit_button(self): quit() if __name__ == '__main__': app2 = QtWidgets.QApplication(sys.argv) my = gui_view() my.show() app2.exec_()
6 設(shè)置背景
效果展示
代碼參考
import sys from PyQt5 import QtWidgets, QtCore from PyQt5.QtWidgets import * from PyQt5 import QtGui class gui_view(QWidget): def __init__(self): super(gui_view, self).__init__() self.resize(1200, 750) # self.setStyleSheet("background-image: url(:F:/background.jpg);") self.setWindowTitle("設(shè)置背景圖片") window_pale = QtGui.QPalette() window_pale.setBrush(self.backgroundRole(), QtGui.QBrush(QtGui.QPixmap("F:/background.jpg"))) self.setPalette(window_pale) if __name__ == '__main__': app2 = QtWidgets.QApplication(sys.argv) my = gui_view() my.show() app2.exec_()
7 下拉列表框設(shè)置
效果展示
代碼參考
import sys from PyQt5.QtWidgets import QWidget, QComboBox, QApplication class ComboxDemo(QWidget): def __init__(self): super().__init__() self.setWindowTitle('下拉列表框') self.resize(700, 400) # 實(shí)例化QComBox對(duì)象 self.cb = QComboBox(self) self.cb.move(100, 20) # 單個(gè)添加條目 self.cb.addItem('選項(xiàng)1') self.cb.addItem('選項(xiàng)2') # 多個(gè)添加條目 self.cb.addItems(['選項(xiàng)3', '選項(xiàng)4', '選項(xiàng)5']) self.cb.currentIndexChanged[str].connect(self.print_value) def print_value(self, value): print(value) if __name__ == '__main__': app = QApplication(sys.argv) comboxDemo = ComboxDemo() comboxDemo.show() sys.exit(app.exec_())
8 等待時(shí)顯示進(jìn)度條
效果展示
代碼參考
from PyQt5.QtWidgets import QMainWindow, QProgressBar, QApplication, QLabel, QStatusBar, QPushButton import sys class SampleBar(QMainWindow): def __init__(self, parent=None): super(SampleBar, self).__init__(parent) self.setMinimumSize(400, 100) self.statusBar = QStatusBar() self.statusBar.setStyleSheet('QStatusBar::item {border: none;}') self.setStatusBar(self.statusBar) self.progressBar = QProgressBar() self.label = QLabel() self.label.setText("加載中,請(qǐng)稍后... ") self.statusBar.addPermanentWidget(self.label, stretch=2) self.statusBar.addPermanentWidget(self.progressBar, stretch=4) self.progressBar.setRange(0, 100) self.progressBar.setMinimum(0) self.progressBar.setMaximum(0) if __name__ == '__main__': app = QApplication(sys.argv) main = SampleBar() main.show() sys.exit(app.exec_())
總結(jié)
到此這篇關(guān)于如何利用PyQt5美化你的GUI界面的文章就介紹到這了,更多相關(guān)PyQt5美化GUI界面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
教你用Python查看茅臺(tái)股票交易數(shù)據(jù)的詳細(xì)代碼
CSV是以逗號(hào)分隔數(shù)據(jù)項(xiàng)(也被稱為字段)的數(shù)據(jù)交換格式,主要應(yīng)用于電子表格和數(shù)據(jù)庫(kù)之間的數(shù)據(jù)交換,本文給大家介紹下用Python查看茅臺(tái)股票交易數(shù)據(jù)的詳細(xì)代碼,感興趣的朋友一起看看吧2022-03-03django中url映射規(guī)則和服務(wù)端響應(yīng)順序的實(shí)現(xiàn)
這篇文章主要介紹了django中url映射規(guī)則和服務(wù)端響應(yīng)順序的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04解決Keyerror ''''acc'''' KeyError: ''''val_acc''''問(wèn)題
這篇文章主要介紹了解決Keyerror 'acc' KeyError: 'val_acc'問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06通過(guò)python爬蟲(chóng)mechanize庫(kù)爬取本機(jī)ip地址的方法
python中的mechanize算是一個(gè)比較古老的庫(kù)了,在python2的時(shí)代中,使用的多一些,在python3以后就很少使用了,現(xiàn)在已經(jīng)是2202年了,可能很多人都沒(méi)聽(tīng)說(shuō)過(guò)mechanize,這不要緊,我們先來(lái)簡(jiǎn)單的講解一下,如何使用mechanize,感興趣的朋友一起看看吧2022-08-08Python使用xlrd和xlwt批量讀寫excel文件的示例代碼
這篇文章主要介紹了Python使用xlrd和xlwt批量讀寫excel文件,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03使用python制作游戲下載進(jìn)度條的代碼(程序說(shuō)明見(jiàn)注釋)
這篇文章主要介紹了用python制作游戲下載進(jìn)度條的代碼(程序說(shuō)明見(jiàn)注釋),代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10Python插件virtualenv搭建虛擬環(huán)境
這篇文章主要為大家詳細(xì)介紹了Python插件virtualenv搭建虛擬環(huán)境,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11