Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
213 / 109 / 46
Регистрация: 12.12.2016
Сообщений: 399
PyQt5

Несколько аналоговых часов

07.10.2022, 10:12. Показов 549. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, форумчане!
Подскажите пожалуйста как можно доработать код, чтобы на выходе получилось 6 видов часов (по списку из tz_list; 3 сверху, 3 снизу).
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
import sys
import pytz
from datetime import datetime
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import QPoint, Qt, QTime, QTimer
from PyQt5.QtGui import QColor, QPainter, QPolygon
from PyQt5.QtWidgets import QApplication, QWidget, QGridLayout
 
 
class AnalogClock(QWidget):
    secondHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -95)
    ])
    hourHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -50)
    ])
    minuteHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -70)
    ])
    hourColor = QColor(127, 0, 127)
    minuteColor = QColor(0, 100, 250, 200)
    secondColor = QColor(195, 0, 0, 150)
 
    def __init__(self, parent=None, timezone=None):
        super(AnalogClock, self).__init__(parent)
        self.timezone = timezone
        timer = QTimer(self)
        timer.timeout.connect(self.update)
        timer.start(1000)
        # self.setWindowTitle("Analog Clock")
 
        self.screen = app.primaryScreen().size()
        self.resize(int(self.screen.height()/2), int(self.screen.height()/2))
        # self.resize(self.screen.width()/2, self.screen.height()/2)
 
    def paintEvent(self, event):
        self.analog_clock(timezone=self.timezone)
 
    def analog_clock(self, timezone):
        side = min(self.width(), self.height())
        # side = min(int(self.screen.height()/2), int(self.screen.height()/2))
        # time = QTime.currentTime()
 
        time = datetime.now(pytz.timezone(timezone)).strftime('%H:%M:%S')
        h, m, s = map(int, time.split(":"))
 
        painter = QPainter(self)
        painter.setRenderHint(QPainter.Antialiasing)
        painter.translate(self.width() / 2, self.height() / 2)
        painter.scale(side / 200, side / 200)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.hourColor)
 
        painter.save()
        # painter.rotate(30.0 * (time.hour() + time.minute() / 60.0))  # 360/12.0 times per hour
        painter.rotate(30.0 * (h + m / 60.0))  # 360/12.0 times per hour
        # print(f'hour:{time.hour()}, minute:{time.minute()}, second:{time.second()}')
        painter.drawConvexPolygon(AnalogClock.hourHand)
        painter.restore()
 
        painter.setPen(AnalogClock.hourColor)
 
        for i in range(12):
            painter.drawLine(88, 0, 96, 0)  # markings for hour hand
            painter.rotate(30.0)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.minuteColor)
 
        painter.save()
        # painter.rotate(6.0 * (time.minute() + time.second() / 60.0))  # 6 times a minute
        painter.rotate(6.0 * (m + s / 60.0))  # 6 times a minute
        painter.drawConvexPolygon(AnalogClock.minuteHand)
        painter.restore()
 
        painter.setPen(AnalogClock.minuteColor)
 
        for j in range(60):
            if (j % 5) != 0:
                painter.drawLine(92, 0, 96, 0)  # markings for minute hand
            painter.rotate(6.0)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.secondColor)
 
        painter.save()
        # painter.rotate(360 * (time.minute() + time.second() / 60.0))  # 360 times in a minute
        painter.rotate(360 * (m + s / 60.0))  # 360 times in a minute
        painter.drawConvexPolygon(AnalogClock.secondHand)
        painter.restore()
 
 
class Dialog(QtWidgets.QDialog):
    def __init__(self, parent=None):
        super(Dialog, self).__init__(parent)
        gridLayoutWidget = QWidget()
        gridLayout = QGridLayout(gridLayoutWidget)
        draw_widget = AnalogClock()
        gridLayout.addWidget(draw_widget, 1, 1, 1, 1)
        # lay = QtWidgets.QVBoxLayout(self)
        # lay.addWidget(scroll_area)
 
 
if __name__ == '__main__':
    tz_list = ["Europe/London", "Europe/Paris", "Europe/Moscow", "Japan", "America/New_York", "Australia/Sydney"]
    app = QApplication(sys.argv)
    # for tz in tz_list:
    clock = AnalogClock(timezone="Europe/London")
    clock.show()
    sys.exit(app.exec_())
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.10.2022, 10:12
Ответы с готовыми решениями:

Циферблат аналоговых часов
Помогите пожалуйста добавить в данный код циферблат часов, а то простой круг не очень выглядит. Private Sub Form_Load() Picture1.Scale...

Эмуляция аналоговых часов
всем привет! я не могу разобраться, что и как писать дальше мне нужно написать на СИ с помощью библиотеи графики часы т.е.: 1....

Код аналоговых часов на с++
Проблема с localtime, подскажите, пожалуйста, что не так

1
 Аватар для kapbepucm
1568 / 741 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
10.10.2022, 13:19
Лучший ответ Сообщение было отмечено New Life как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import sys
import pytz
from datetime import datetime
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import QPoint, Qt, QTime, QTimer
from PyQt5.QtGui import QColor, QPainter, QPolygon
from PyQt5.QtWidgets import QApplication, QWidget, QGridLayout
 
class AnalogClock(QWidget):
    secondHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -95)
    ])
    hourHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -50)
    ])
    minuteHand = QPolygon([
        QPoint(7, 8),
        QPoint(-7, 8),
        QPoint(0, -70)
    ])
    hourColor = QColor(127, 0, 127)
    minuteColor = QColor(0, 100, 250, 200)
    secondColor = QColor(195, 0, 0, 150)
 
    def __init__(self, parent=None, timezone=None):
        super(AnalogClock, self).__init__(parent)
        self.timezone = timezone
        timer = QTimer(self)
        timer.timeout.connect(self.update)
        timer.start(1000)
 
    def paintEvent(self, event):
        self.analog_clock(timezone=self.timezone)
 
    def analog_clock(self, timezone):
        side = min(self.width(), self.height()) 
        time = datetime.now(pytz.timezone(timezone)).strftime('%H:%M:%S')
        h, m, s = map(int, time.split(":"))
 
        painter = QPainter(self)
        painter.setRenderHint(QPainter.Antialiasing)
        painter.translate(self.width() / 2, self.height() / 2)
        painter.scale(side / 200, side / 200)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.hourColor)
 
        painter.save()
        painter.rotate(30.0 * (h + m / 60.0))  # 360/12.0 times per hour
        painter.drawConvexPolygon(AnalogClock.hourHand)
        painter.restore()
 
        painter.setPen(AnalogClock.hourColor)
 
        for i in range(12):
            painter.drawLine(88, 0, 96, 0)  # markings for hour hand
            painter.rotate(30.0)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.minuteColor)
 
        painter.save()
        painter.rotate(6.0 * (m + s / 60.0))  # 6 times a minute
        painter.drawConvexPolygon(AnalogClock.minuteHand)
        painter.restore()
 
        painter.setPen(AnalogClock.minuteColor)
 
        for j in range(60):
            if (j % 5) != 0:
                painter.drawLine(92, 0, 96, 0)  # markings for minute hand
            painter.rotate(6.0)
 
        painter.setPen(Qt.NoPen)
        painter.setBrush(AnalogClock.secondColor)
 
        painter.save()
        painter.rotate(360 * (m + s / 60.0))  # 360 times in a minute
        painter.drawConvexPolygon(AnalogClock.secondHand)
        painter.restore()
 
if __name__ == '__main__':
    tz_list = ["Europe/London", "Europe/Paris", "Europe/Moscow", "Japan", "America/New_York", "Australia/Sydney"]
    app = QApplication(sys.argv)
    w = QWidget()
    row = 0
    column = 0
    l = QGridLayout()
    for tz in tz_list:
      clock = AnalogClock(timezone=tz)
      l.addWidget(clock, row, column)
      column = column + 1
      if column==3:
        column = 0
        row = row + 1
    w.setLayout(l)
    screen = app.primaryScreen().size()
    w.resize(int(screen.height()/2), int(screen.height()/2))
    w.show()
    sys.exit(app.exec_())
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.10.2022, 13:19
Помогаю со студенческими работами здесь

Код для аналоговых часов
Помогите с кодом для Action script 2.0!Речь идет об аналоговых часах.Мне нужно чтобы, например, когда минутная стрелка попадает в зону...

Описание создания аналоговых часов
подскажите пожалуйста учебник какой нибудь с приемлимым описанием создания аналоговых часов

Нужен скрипт аналоговых часов
скрипт самых протых часов

Кнопки для аналоговых часов
Здравствуйте. Нужно сделать аналоговые часы с кнопками увеличения/уменьшения часов и минут. Часы работаю, панель с кнопками есть. Но не...

C и OpenGl: реализация аналоговых часов
возникла проблема, когда писала программу, которая должна вывести аналоговые часы,- библиотеки math.h time.h не работают. Добавлено...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru