欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于PyQt5制作一個(gè)動(dòng)態(tài)指針時(shí)鐘

 更新時(shí)間:2022年02月24日 08:31:15   作者:Python 集中營(yíng)  
這篇文章主要和大家分享如何利用Python中的PyQt5制作一個(gè)動(dòng)態(tài)指針時(shí)鐘來顯示實(shí)時(shí)時(shí)間,文中的示例代碼講解詳細(xì),需要的可以參考一下

想實(shí)現(xiàn)這樣一個(gè)功能,然后pyqt5中又沒有現(xiàn)成的組件可以使用,于是就想著只能通過繪圖的方式來實(shí)現(xiàn)。說到繪圖的話,turtle框架無疑是最常見的選擇,但其實(shí)通過pyqt5的QPainter組件也是可以實(shí)現(xiàn)的。而且最后呈現(xiàn)出來的效果還是挺漂亮的。

實(shí)現(xiàn)思路:通過使用pyqt5的QPainter組件來繪制好時(shí)鐘的圖表,最后通過定時(shí)器不斷的改變當(dāng)前當(dāng)前時(shí)間在圖表上面的顯示位置。這樣最終就實(shí)現(xiàn)了一個(gè)指針時(shí)鐘在不斷的走動(dòng)的過程。

和前面的UI應(yīng)用一樣,我們用到的UI相關(guān)的組件庫(kù)還是這三個(gè)。

from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

這次新使用了一個(gè)數(shù)學(xué)計(jì)算庫(kù),因?yàn)闋砍兜綌?shù)據(jù)計(jì)算相關(guān)的部分。

from math import *

應(yīng)用操作相關(guān)的模塊

import sys

動(dòng)態(tài)時(shí)鐘的主要實(shí)現(xiàn)過程我放在下面了,有需要的朋友可以自己研究一下。

class PointerClock(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("動(dòng)態(tài)指針時(shí)鐘  公眾號(hào):[Python 集中營(yíng)]")
        self.setWindowIcon(QIcon('clock.ico'))
        self.timer = QTimer()
        # 設(shè)置窗口計(jì)時(shí)器
        self.timer.timeout.connect(self.update)
        self.timer.start(1000)

    def paintEvent(self, event):
        '''
        實(shí)時(shí)刷新指針圖像
        :param event:
        :return:
        '''
        '''分別定義小時(shí)、分鐘、秒鐘的坐標(biāo)點(diǎn)'''
        '''
        QPoint(int x, int y);創(chuàng)建坐標(biāo)點(diǎn),x、y分別代表橫坐標(biāo)、縱坐標(biāo)
        '''
        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)]

        '''定義三種顏色、用于后面設(shè)置三種指針的顏色'''
        hour_color = QColor(182, 98, 0, 182)
        min_color = QColor(0, 130, 130, 155)
        sec_color = QColor(0, 155, 227, 155)

        '''獲取QWidget對(duì)象的寬度和長(zhǎng)度的最小值'''
        min_size = min(self.width(), self.height())

        painter = QPainter(self)  # 創(chuàng)建坐標(biāo)系圖像繪制對(duì)象
        painter.setRenderHint(QPainter.Antialiasing)

        # 將QWidget對(duì)象的中心位置作為繪制的中心坐標(biāo)點(diǎn)
        painter.translate(self.width() / 2, self.height() / 2)

        # 對(duì)尺寸進(jìn)行縮放
        painter.scale(int(min_size / 200), int(min_size / 200))

        # 保存狀態(tài)
        painter.save()

        '''繪制時(shí)鐘表盤的時(shí)間刻度線'''

        for a in range(0, 60):
            if (a % 5) != 0:
                # 每1/60繪制一個(gè)刻度線作為分鐘刻度線
                painter.setPen(min_color)
                painter.drawLine(92, 0, 96, 0)
            else:
                # 每5/60繪制一個(gè)刻度線作為小時(shí)刻度線
                painter.setPen(hour_color)
                painter.drawLine(88, 0, 96, 0)  # 繪制小時(shí)刻度線
            # 每分鐘旋轉(zhuǎn)6度
            painter.rotate(360 / 60)
        # 恢復(fù)狀態(tài)
        painter.restore()

        '''繪制時(shí)鐘表盤上面的數(shù)字'''
        # 保存狀態(tài)
        painter.save()
        # 獲取字體對(duì)象
        font = painter.font()
        # 設(shè)置粗體
        font.setBold(True)
        painter.setFont(font)
        # 獲取字體大小
        font_size = font.pointSize()
        # 設(shè)置之前定義好的顏色
        painter.setPen(hour_color)
        hour_num = 0
        radius = 100
        for i in range(0, 12):
            # 按照12小時(shí)制,每三個(gè)小時(shí)繪制一個(gè)小時(shí)數(shù)字,需要遍歷4次
            hour_num = i + 3  # 按QT-Qpainter的坐標(biāo)系換算,3小時(shí)的刻度線對(duì)應(yīng)坐標(biāo)軸0度
            if hour_num > 12:
                hour_num = hour_num - 12
            # 根據(jù)字體的大小計(jì)算出寫入小時(shí)數(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))
        # 恢復(fù)狀態(tài)
        painter.restore()

        '''繪制時(shí)鐘表盤的時(shí)、分、秒的指針'''

        # 獲取當(dāng)前時(shí)間
        time = QTime.currentTime()

        # 繪制小時(shí)指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置小時(shí)指針的顏色
        painter.setBrush(hour_color)
        # 小時(shí)指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(30 * (time.hour() + time.minute() / 60))
        # 繪制時(shí)鐘指針
        painter.drawConvexPolygon(QPolygonF(hour_point))
        # 恢復(fù)狀態(tài)
        painter.restore()

        # 繪制分鐘指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置分鐘指針的顏色
        painter.setBrush(min_color)
        # 分鐘指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(6 * (time.minute() + time.second() / 60))
        # 繪制分鐘指針
        painter.drawConvexPolygon(QPolygonF(min_point))
        # 恢復(fù)狀態(tài)
        painter.restore()

        # 繪制秒鐘指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置秒針顏色
        painter.setBrush(sec_color)
        # 秒鐘指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(6 * time.second())
        # 繪制秒鐘指針
        painter.drawConvexPolygon(QPolygonF(secn_point))
        # 恢復(fù)狀態(tài)
        painter.restore()

最后,還是通過main()函數(shù)直接啟動(dòng)整個(gè)App。

if __name__ == "__main__":
    app = QApplication(sys.argv)
    form = PointerClock()
    form.show()
    app.exec_()

完整代碼

# -*- coding:utf-8 -*-
# @author Python 集中營(yíng)
# @date 2022/1/25
# @file test9.py

# done


# 利用pyqt5制作指針鐘表顯示實(shí)施時(shí)間

# 想實(shí)現(xiàn)這樣一個(gè)功能,然后pyqt5中又沒有現(xiàn)成的組件可以使用,于是就想著只能通過繪圖的方式來實(shí)現(xiàn)。
# 說到繪圖的話,turtle框架無疑是最常見的選擇,但其實(shí)通過pyqt5的QPainter組件也是可以實(shí)現(xiàn)的。而且最后呈現(xiàn)出來的
# 效果還是挺漂亮的。

# 實(shí)現(xiàn)思路:通過使用pyqt5的QPainter組件來繪制好時(shí)鐘的圖表,最后通過定時(shí)器不斷的改變當(dāng)前當(dāng)前時(shí)間在圖表上面的顯示位置。
# 這樣最終就實(shí)現(xiàn)了一個(gè)指針時(shí)鐘在不斷的走動(dòng)的過程。

# 和前面的UI應(yīng)用一樣,我們用到的UI相關(guān)的組件庫(kù)還是這三個(gè)。
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

# 這次新使用了一個(gè)數(shù)學(xué)計(jì)算庫(kù),因?yàn)闋砍兜綌?shù)據(jù)計(jì)算相關(guān)的部分。
from math import *

# 應(yīng)用操作相關(guān)的模塊
import sys


class PointerClock(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("動(dòng)態(tài)指針時(shí)鐘  公眾號(hào):[Python 集中營(yíng)]")
        self.setWindowIcon(QIcon('clock.ico'))
        self.timer = QTimer()
        # 設(shè)置窗口計(jì)時(shí)器
        self.timer.timeout.connect(self.update)
        self.timer.start(1000)

    def paintEvent(self, event):
        '''
        實(shí)時(shí)刷新指針圖像
        :param event:
        :return:
        '''
        '''分別定義小時(shí)、分鐘、秒鐘的坐標(biāo)點(diǎn)'''
        '''
        QPoint(int x, int y);創(chuàng)建坐標(biāo)點(diǎn),x、y分別代表橫坐標(biāo)、縱坐標(biāo)
        '''
        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)]

        '''定義三種顏色、用于后面設(shè)置三種指針的顏色'''
        hour_color = QColor(182, 98, 0, 182)
        min_color = QColor(0, 130, 130, 155)
        sec_color = QColor(0, 155, 227, 155)

        '''獲取QWidget對(duì)象的寬度和長(zhǎng)度的最小值'''
        min_size = min(self.width(), self.height())

        painter = QPainter(self)  # 創(chuàng)建坐標(biāo)系圖像繪制對(duì)象
        painter.setRenderHint(QPainter.Antialiasing)

        # 將QWidget對(duì)象的中心位置作為繪制的中心坐標(biāo)點(diǎn)
        painter.translate(self.width() / 2, self.height() / 2)

        # 對(duì)尺寸進(jìn)行縮放
        painter.scale(int(min_size / 200), int(min_size / 200))

        # 保存狀態(tài)
        painter.save()

        '''繪制時(shí)鐘表盤的時(shí)間刻度線'''

        for a in range(0, 60):
            if (a % 5) != 0:
                # 每1/60繪制一個(gè)刻度線作為分鐘刻度線
                painter.setPen(min_color)
                painter.drawLine(92, 0, 96, 0)
            else:
                # 每5/60繪制一個(gè)刻度線作為小時(shí)刻度線
                painter.setPen(hour_color)
                painter.drawLine(88, 0, 96, 0)  # 繪制小時(shí)刻度線
            # 每分鐘旋轉(zhuǎn)6度
            painter.rotate(360 / 60)
        # 恢復(fù)狀態(tài)
        painter.restore()

        '''繪制時(shí)鐘表盤上面的數(shù)字'''
        # 保存狀態(tài)
        painter.save()
        # 獲取字體對(duì)象
        font = painter.font()
        # 設(shè)置粗體
        font.setBold(True)
        painter.setFont(font)
        # 獲取字體大小
        font_size = font.pointSize()
        # 設(shè)置之前定義好的顏色
        painter.setPen(hour_color)
        hour_num = 0
        radius = 100
        for i in range(0, 12):
            # 按照12小時(shí)制,每三個(gè)小時(shí)繪制一個(gè)小時(shí)數(shù)字,需要遍歷4次
            hour_num = i + 3  # 按QT-Qpainter的坐標(biāo)系換算,3小時(shí)的刻度線對(duì)應(yīng)坐標(biāo)軸0度
            if hour_num > 12:
                hour_num = hour_num - 12
            # 根據(jù)字體的大小計(jì)算出寫入小時(shí)數(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))
        # 恢復(fù)狀態(tài)
        painter.restore()

        '''繪制時(shí)鐘表盤的時(shí)、分、秒的指針'''

        # 獲取當(dāng)前時(shí)間
        time = QTime.currentTime()

        # 繪制小時(shí)指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置小時(shí)指針的顏色
        painter.setBrush(hour_color)
        # 小時(shí)指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(30 * (time.hour() + time.minute() / 60))
        # 繪制時(shí)鐘指針
        painter.drawConvexPolygon(QPolygonF(hour_point))
        # 恢復(fù)狀態(tài)
        painter.restore()

        # 繪制分鐘指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置分鐘指針的顏色
        painter.setBrush(min_color)
        # 分鐘指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(6 * (time.minute() + time.second() / 60))
        # 繪制分鐘指針
        painter.drawConvexPolygon(QPolygonF(min_point))
        # 恢復(fù)狀態(tài)
        painter.restore()

        # 繪制秒鐘指針
        painter.save()
        # 取消輪廓線
        painter.setPen(Qt.NoPen)
        # 設(shè)置秒針顏色
        painter.setBrush(sec_color)
        # 秒鐘指針逆時(shí)針旋轉(zhuǎn)
        painter.rotate(6 * time.second())
        # 繪制秒鐘指針
        painter.drawConvexPolygon(QPolygonF(secn_point))
        # 恢復(fù)狀態(tài)
        painter.restore()


if __name__ == "__main__":
    app = QApplication(sys.argv)
    form = PointerClock()
    form.show()
    app.exec_()

以上就是基于PyQt5制作一個(gè)動(dòng)態(tài)指針時(shí)鐘的詳細(xì)內(nèi)容,更多關(guān)于PyQt5動(dòng)態(tài)時(shí)鐘的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python Socket編程詳細(xì)介紹

    Python Socket編程詳細(xì)介紹

    這篇文章主要介紹了Python Socket編程詳細(xì)介紹,socket可以建立連接,傳遞數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-03-03
  • Matplotlib.pyplot 三維繪圖的實(shí)現(xiàn)示例

    Matplotlib.pyplot 三維繪圖的實(shí)現(xiàn)示例

    這篇文章主要介紹了Matplotlib.pyplot 三維繪圖的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • python3 adb 獲取設(shè)備序列號(hào)的實(shí)現(xiàn)

    python3 adb 獲取設(shè)備序列號(hào)的實(shí)現(xiàn)

    這篇文章主要介紹了python3 adb 獲取設(shè)備序列號(hào)的實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 進(jìn)行數(shù)據(jù)處理的6個(gè)?Python?代碼塊分享

    進(jìn)行數(shù)據(jù)處理的6個(gè)?Python?代碼塊分享

    這篇文章主要介紹了進(jìn)行數(shù)據(jù)處理6個(gè)Python代碼塊的分享,分享內(nèi)容有選取有空值的行、快速替換列值、對(duì)列進(jìn)行分區(qū)、將一列分為多列等內(nèi)容,需要的朋友可以參考一下
    2022-04-04
  • python使用 HTMLTestRunner.py生成測(cè)試報(bào)告

    python使用 HTMLTestRunner.py生成測(cè)試報(bào)告

    這篇文章主要介紹了python使用 HTMLTestRunner.py生成測(cè)試報(bào)告 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • tensorflow 中對(duì)數(shù)組元素的操作方法

    tensorflow 中對(duì)數(shù)組元素的操作方法

    今天小編就為大家分享一篇tensorflow 中對(duì)數(shù)組元素的操作方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python實(shí)現(xiàn)矩陣和array數(shù)組之間的轉(zhuǎn)換

    python實(shí)現(xiàn)矩陣和array數(shù)組之間的轉(zhuǎn)換

    今天小編就為大家分享一篇python實(shí)現(xiàn)矩陣和array數(shù)組之間的轉(zhuǎn)換,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python裝飾器結(jié)合遞歸原理解析

    Python裝飾器結(jié)合遞歸原理解析

    這篇文章主要介紹了Python裝飾器結(jié)合遞歸原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Python 語(yǔ)句的表達(dá)式和縮進(jìn)

    Python 語(yǔ)句的表達(dá)式和縮進(jìn)

    本篇文章將會(huì)使大家了解Python 語(yǔ)句、表達(dá)式以及它們之間的區(qū)別。還包含幾個(gè)示例來更清楚地解釋這個(gè)概念。接下來,我們將解釋如何在 Python 編程中使用多行語(yǔ)句和縮進(jìn),需要的朋友可以參考一下
    2021-09-09
  • Python實(shí)現(xiàn)單例模式的四種方法

    Python實(shí)現(xiàn)單例模式的四種方法

    在Python中實(shí)現(xiàn)單例模式,意味著一個(gè)類只能創(chuàng)建一個(gè)實(shí)例,單例模式在某些場(chǎng)景下非常有用,比如當(dāng)你需要控制資源的訪問,或者當(dāng)你想確保全局只有一個(gè)對(duì)象實(shí)例時(shí),本文給大家介紹了幾種在Python中實(shí)現(xiàn)單例模式的方法,需要的朋友可以參考下
    2024-03-03

最新評(píng)論