ORE Studio 0.0.4
Loading...
Searching...
No Matches
RecencyPulseManager.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_QT_RECENCY_PULSE_MANAGER_HPP
21#define ORES_QT_RECENCY_PULSE_MANAGER_HPP
22
23#include <QTimer>
24#include <QObject>
25
26namespace ores::qt {
27
42class RecencyPulseManager final : public QObject {
43 Q_OBJECT
44
45public:
53 explicit RecencyPulseManager(QObject* parent = nullptr,
54 int pulse_interval_ms = 500,
55 int max_pulse_cycles = 6);
56
63 void start_pulsing();
64
73 [[nodiscard]] bool is_pulse_on() const { return pulse_state_; }
74
80 [[nodiscard]] bool is_pulsing() const;
81
85 void stop_pulsing();
86
87signals:
94 void pulse_state_changed(bool is_on);
95
103
104private slots:
105 void on_timer_timeout();
106
107private:
108 QTimer* timer_;
109 bool pulse_state_{false};
110 int pulse_count_{0};
111 int pulse_interval_ms_;
112 int max_pulse_cycles_;
113};
114
115}
116
117#endif
Qt-based graphical user interface for ORE Studio.
Definition AboutDialog.hpp:35
Manages the pulsing animation for recently-changed items in models.
Definition RecencyPulseManager.hpp:42
bool is_pulsing() const
Check if the manager is currently pulsing.
Definition RecencyPulseManager.cpp:43
void pulsing_complete()
Emitted when the pulsing animation completes all cycles.
void start_pulsing()
Start or restart the pulsing animation.
Definition RecencyPulseManager.cpp:35
void pulse_state_changed(bool is_on)
Emitted whenever the pulse state changes.
void stop_pulsing()
Stop the pulsing animation immediately.
Definition RecencyPulseManager.cpp:47
bool is_pulse_on() const
Check if the pulse is currently in the "on" (highlighted) state.
Definition RecencyPulseManager.hpp:73