基于PyQt5制作一個動態(tài)指針時鐘

想實現(xiàn)這樣一個功能,然后pyqt5中又沒有現(xiàn)成的組件可以使用,于是就想著只能通過繪圖的方式來實現(xiàn)。說到繪圖的話,turtle框架無疑是最常見的選擇,但其實通過pyqt5的QPainter組件也是可以實現(xiàn)的。而且最后呈現(xiàn)出來的效果還是挺漂亮的。
實現(xiàn)思路:通過使用pyqt5的QPainter組件來繪制好時鐘的圖表,最后通過定時器不斷的改變當前當前時間在圖表上面的顯示位置。這樣最終就實現(xiàn)了一個指針時鐘在不斷的走動的過程。
和前面的UI應用一樣,我們用到的UI相關的組件庫還是這三個。
from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import *
這次新使用了一個數(shù)學計算庫,因為牽扯到數(shù)據(jù)計算相關的部分。
from math import *
應用操作相關的模塊
import sys
動態(tài)時鐘的主要實現(xiàn)過程我放在下面了,有需要的朋友可以自己研究一下。
class PointerClock(QWidget):
def __init__(self):
super().__init__()
self.setWindowTitle("動態(tài)指針時鐘 公眾號:[Python 集中營]")
self.setWindowIcon(QIcon('clock.ico'))
self.timer = QTimer()
# 設置窗口計時器
self.timer.timeout.connect(self.update)
self.timer.start(1000)
def paintEvent(self, event):
'''
實時刷新指針圖像
:param event:
:return:
'''
'''分別定義小時、分鐘、秒鐘的坐標點'''
'''
QPoint(int x, int y);創(chuàng)建坐標點,x、y分別代表橫坐標、縱坐標
'''
hour_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -30)]
min_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -65)]
secn_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -80)]
'''定義三種顏色、用于后面設置三種指針的顏色'''
hour_color = QColor(182, 98, 0, 182)
min_color = QColor(0, 130, 130, 155)
sec_color = QColor(0, 155, 227, 155)
'''獲取QWidget對象的寬度和長度的最小值'''
min_size = min(self.width(), self.height())
painter = QPainter(self) # 創(chuàng)建坐標系圖像繪制對象
painter.setRenderHint(QPainter.Antialiasing)
# 將QWidget對象的中心位置作為繪制的中心坐標點
painter.translate(self.width() / 2, self.height() / 2)
# 對尺寸進行縮放
painter.scale(int(min_size / 200), int(min_size / 200))
# 保存狀態(tài)
painter.save()
'''繪制時鐘表盤的時間刻度線'''
for a in range(0, 60):
if (a % 5) != 0:
# 每1/60繪制一個刻度線作為分鐘刻度線
painter.setPen(min_color)
painter.drawLine(92, 0, 96, 0)
else:
# 每5/60繪制一個刻度線作為小時刻度線
painter.setPen(hour_color)
painter.drawLine(88, 0, 96, 0) # 繪制小時刻度線
# 每分鐘旋轉6度
painter.rotate(360 / 60)
# 恢復狀態(tài)
painter.restore()
'''繪制時鐘表盤上面的數(shù)字'''
# 保存狀態(tài)
painter.save()
# 獲取字體對象
font = painter.font()
# 設置粗體
font.setBold(True)
painter.setFont(font)
# 獲取字體大小
font_size = font.pointSize()
# 設置之前定義好的顏色
painter.setPen(hour_color)
hour_num = 0
radius = 100
for i in range(0, 12):
# 按照12小時制,每三個小時繪制一個小時數(shù)字,需要遍歷4次
hour_num = i + 3 # 按QT-Qpainter的坐標系換算,3小時的刻度線對應坐標軸0度
if hour_num > 12:
hour_num = hour_num - 12
# 根據(jù)字體的大小計算出寫入小時數(shù)字的x、y的位置
x = radius * 0.8 * cos(i * 30 * pi / 180.0) - font_size
y = radius * 0.8 * sin(i * 30 * pi / 180.0) - font_size / 2.0
width = font_size * 2
height = font_size
painter.drawText(QRectF(x, y, width, height), Qt.AlignCenter, str(hour_num))
# 恢復狀態(tài)
painter.restore()
'''繪制時鐘表盤的時、分、秒的指針'''
# 獲取當前時間
time = QTime.currentTime()
# 繪制小時指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置小時指針的顏色
painter.setBrush(hour_color)
# 小時指針逆時針旋轉
painter.rotate(30 * (time.hour() + time.minute() / 60))
# 繪制時鐘指針
painter.drawConvexPolygon(QPolygonF(hour_point))
# 恢復狀態(tài)
painter.restore()
# 繪制分鐘指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置分鐘指針的顏色
painter.setBrush(min_color)
# 分鐘指針逆時針旋轉
painter.rotate(6 * (time.minute() + time.second() / 60))
# 繪制分鐘指針
painter.drawConvexPolygon(QPolygonF(min_point))
# 恢復狀態(tài)
painter.restore()
# 繪制秒鐘指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置秒針顏色
painter.setBrush(sec_color)
# 秒鐘指針逆時針旋轉
painter.rotate(6 * time.second())
# 繪制秒鐘指針
painter.drawConvexPolygon(QPolygonF(secn_point))
# 恢復狀態(tài)
painter.restore()
最后,還是通過main()函數(shù)直接啟動整個App。
if __name__ == "__main__":
app = QApplication(sys.argv)
form = PointerClock()
form.show()
app.exec_()完整代碼
# -*- coding:utf-8 -*-
# @author Python 集中營
# @date 2022/1/25
# @file test9.py
# done
# 利用pyqt5制作指針鐘表顯示實施時間
# 想實現(xiàn)這樣一個功能,然后pyqt5中又沒有現(xiàn)成的組件可以使用,于是就想著只能通過繪圖的方式來實現(xiàn)。
# 說到繪圖的話,turtle框架無疑是最常見的選擇,但其實通過pyqt5的QPainter組件也是可以實現(xiàn)的。而且最后呈現(xiàn)出來的
# 效果還是挺漂亮的。
# 實現(xiàn)思路:通過使用pyqt5的QPainter組件來繪制好時鐘的圖表,最后通過定時器不斷的改變當前當前時間在圖表上面的顯示位置。
# 這樣最終就實現(xiàn)了一個指針時鐘在不斷的走動的過程。
# 和前面的UI應用一樣,我們用到的UI相關的組件庫還是這三個。
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
# 這次新使用了一個數(shù)學計算庫,因為牽扯到數(shù)據(jù)計算相關的部分。
from math import *
# 應用操作相關的模塊
import sys
class PointerClock(QWidget):
def __init__(self):
super().__init__()
self.setWindowTitle("動態(tài)指針時鐘 公眾號:[Python 集中營]")
self.setWindowIcon(QIcon('clock.ico'))
self.timer = QTimer()
# 設置窗口計時器
self.timer.timeout.connect(self.update)
self.timer.start(1000)
def paintEvent(self, event):
'''
實時刷新指針圖像
:param event:
:return:
'''
'''分別定義小時、分鐘、秒鐘的坐標點'''
'''
QPoint(int x, int y);創(chuàng)建坐標點,x、y分別代表橫坐標、縱坐標
'''
hour_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -30)]
min_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -65)]
secn_point = [QPoint(7, 8), QPoint(-7, 8), QPoint(0, -80)]
'''定義三種顏色、用于后面設置三種指針的顏色'''
hour_color = QColor(182, 98, 0, 182)
min_color = QColor(0, 130, 130, 155)
sec_color = QColor(0, 155, 227, 155)
'''獲取QWidget對象的寬度和長度的最小值'''
min_size = min(self.width(), self.height())
painter = QPainter(self) # 創(chuàng)建坐標系圖像繪制對象
painter.setRenderHint(QPainter.Antialiasing)
# 將QWidget對象的中心位置作為繪制的中心坐標點
painter.translate(self.width() / 2, self.height() / 2)
# 對尺寸進行縮放
painter.scale(int(min_size / 200), int(min_size / 200))
# 保存狀態(tài)
painter.save()
'''繪制時鐘表盤的時間刻度線'''
for a in range(0, 60):
if (a % 5) != 0:
# 每1/60繪制一個刻度線作為分鐘刻度線
painter.setPen(min_color)
painter.drawLine(92, 0, 96, 0)
else:
# 每5/60繪制一個刻度線作為小時刻度線
painter.setPen(hour_color)
painter.drawLine(88, 0, 96, 0) # 繪制小時刻度線
# 每分鐘旋轉6度
painter.rotate(360 / 60)
# 恢復狀態(tài)
painter.restore()
'''繪制時鐘表盤上面的數(shù)字'''
# 保存狀態(tài)
painter.save()
# 獲取字體對象
font = painter.font()
# 設置粗體
font.setBold(True)
painter.setFont(font)
# 獲取字體大小
font_size = font.pointSize()
# 設置之前定義好的顏色
painter.setPen(hour_color)
hour_num = 0
radius = 100
for i in range(0, 12):
# 按照12小時制,每三個小時繪制一個小時數(shù)字,需要遍歷4次
hour_num = i + 3 # 按QT-Qpainter的坐標系換算,3小時的刻度線對應坐標軸0度
if hour_num > 12:
hour_num = hour_num - 12
# 根據(jù)字體的大小計算出寫入小時數(shù)字的x、y的位置
x = radius * 0.8 * cos(i * 30 * pi / 180.0) - font_size
y = radius * 0.8 * sin(i * 30 * pi / 180.0) - font_size / 2.0
width = font_size * 2
height = font_size
painter.drawText(QRectF(x, y, width, height), Qt.AlignCenter, str(hour_num))
# 恢復狀態(tài)
painter.restore()
'''繪制時鐘表盤的時、分、秒的指針'''
# 獲取當前時間
time = QTime.currentTime()
# 繪制小時指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置小時指針的顏色
painter.setBrush(hour_color)
# 小時指針逆時針旋轉
painter.rotate(30 * (time.hour() + time.minute() / 60))
# 繪制時鐘指針
painter.drawConvexPolygon(QPolygonF(hour_point))
# 恢復狀態(tài)
painter.restore()
# 繪制分鐘指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置分鐘指針的顏色
painter.setBrush(min_color)
# 分鐘指針逆時針旋轉
painter.rotate(6 * (time.minute() + time.second() / 60))
# 繪制分鐘指針
painter.drawConvexPolygon(QPolygonF(min_point))
# 恢復狀態(tài)
painter.restore()
# 繪制秒鐘指針
painter.save()
# 取消輪廓線
painter.setPen(Qt.NoPen)
# 設置秒針顏色
painter.setBrush(sec_color)
# 秒鐘指針逆時針旋轉
painter.rotate(6 * time.second())
# 繪制秒鐘指針
painter.drawConvexPolygon(QPolygonF(secn_point))
# 恢復狀態(tài)
painter.restore()
if __name__ == "__main__":
app = QApplication(sys.argv)
form = PointerClock()
form.show()
app.exec_()
以上就是基于PyQt5制作一個動態(tài)指針時鐘的詳細內容,更多關于PyQt5動態(tài)時鐘的資料請關注腳本之家其它相關文章!
相關文章
Matplotlib.pyplot 三維繪圖的實現(xiàn)示例
這篇文章主要介紹了Matplotlib.pyplot 三維繪圖的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
進行數(shù)據(jù)處理的6個?Python?代碼塊分享
這篇文章主要介紹了進行數(shù)據(jù)處理6個Python代碼塊的分享,分享內容有選取有空值的行、快速替換列值、對列進行分區(qū)、將一列分為多列等內容,需要的朋友可以參考一下2022-04-04
python使用 HTMLTestRunner.py生成測試報告
這篇文章主要介紹了python使用 HTMLTestRunner.py生成測試報告 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
python實現(xiàn)矩陣和array數(shù)組之間的轉換
今天小編就為大家分享一篇python實現(xiàn)矩陣和array數(shù)組之間的轉換,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11

