2013-08-13 11:10:45 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// STL includes
|
|
|
|
#include <vector>
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
// QT includes
|
|
|
|
#include <QMap>
|
2017-06-17 23:29:04 +02:00
|
|
|
#include <QObject>
|
|
|
|
#include <QTimer>
|
2017-09-01 08:50:37 +02:00
|
|
|
#include <QMap>
|
|
|
|
#include <QVector>
|
2013-08-13 11:10:45 +02:00
|
|
|
|
|
|
|
// Utils includes
|
2013-11-11 09:00:37 +00:00
|
|
|
#include <utils/ColorRgb.h>
|
2016-10-10 18:29:54 +02:00
|
|
|
#include <utils/Components.h>
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2017-08-04 12:01:45 +02:00
|
|
|
// global defines
|
|
|
|
#define SMOOTHING_MODE_DEFAULT 0
|
|
|
|
#define SMOOTHING_MODE_PAUSE 1
|
|
|
|
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// The PriorityMuxer handles the priority channels. Led values input is written to the priority map
|
|
|
|
/// and the muxer keeps track of all active priorities. The current priority can be queried and per
|
|
|
|
/// priority the led colors.
|
|
|
|
///
|
2017-06-17 23:29:04 +02:00
|
|
|
class PriorityMuxer : public QObject
|
2013-08-13 11:10:45 +02:00
|
|
|
{
|
2017-06-17 23:29:04 +02:00
|
|
|
Q_OBJECT
|
2013-08-13 11:10:45 +02:00
|
|
|
public:
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// The information structure for a single priority channel
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
struct InputInfo
|
|
|
|
{
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The priority of this channel
|
2013-08-13 11:10:45 +02:00
|
|
|
int priority;
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The absolute timeout of the channel
|
2013-08-13 11:10:45 +02:00
|
|
|
int64_t timeoutTime_ms;
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The colors for each led of the channel
|
2013-11-11 09:00:37 +00:00
|
|
|
std::vector<ColorRgb> ledColors;
|
2017-02-28 17:53:41 +01:00
|
|
|
/// The component
|
2016-10-10 18:29:54 +02:00
|
|
|
hyperion::Components componentId;
|
2017-02-28 17:53:41 +01:00
|
|
|
/// Who set it
|
|
|
|
QString origin;
|
2017-08-04 12:01:45 +02:00
|
|
|
/// id fo smoothing config
|
|
|
|
unsigned smooth_cfg;
|
2013-08-13 11:10:45 +02:00
|
|
|
};
|
|
|
|
|
2016-08-06 08:28:42 +02:00
|
|
|
/// The lowest possible priority, which is used when no priority channels are active
|
2017-09-01 08:50:37 +02:00
|
|
|
const static int LOWEST_PRIORITY;
|
2016-08-06 08:28:42 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Constructs the PriorityMuxer for the given number of leds (used to switch to black when
|
|
|
|
/// there are no priority channels
|
|
|
|
///
|
|
|
|
/// @param ledCount The number of leds
|
|
|
|
///
|
2013-08-18 13:33:56 +02:00
|
|
|
PriorityMuxer(int ledCount);
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Destructor
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
~PriorityMuxer();
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Returns the current priority
|
|
|
|
///
|
|
|
|
/// @return The current priority
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
int getCurrentPriority() const;
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Returns the state (enabled/disabled) of a specific priority channel
|
|
|
|
/// @param priority The priority channel
|
|
|
|
/// @return True if the priority channel exists else false
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
bool hasPriority(const int priority) const;
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Returns the number of active priorities
|
|
|
|
///
|
|
|
|
/// @return The list with active priorities
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
QList<int> getPriorities() const;
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Returns the information of a specified priority channel
|
|
|
|
///
|
|
|
|
/// @param priority The priority channel
|
|
|
|
///
|
|
|
|
/// @return The information for the specified priority channel
|
|
|
|
///
|
|
|
|
/// @throws std::runtime_error if the priority channel does not exist
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
const InputInfo& getInputInfo(const int priority) const;
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Sets/Updates the data for a priority channel
|
|
|
|
///
|
|
|
|
/// @param[in] priority The priority of the channel
|
|
|
|
/// @param[in] ledColors The led colors of the priority channel
|
|
|
|
/// @param[in] timeoutTime_ms The absolute timeout time of the channel
|
2017-02-28 17:53:41 +01:00
|
|
|
/// @param[in] component The component of the channel
|
|
|
|
/// @param[in] origin Who set the channel
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2017-08-04 12:01:45 +02:00
|
|
|
void setInput(const int priority, const std::vector<ColorRgb>& ledColors, const int64_t timeoutTime_ms=-1, hyperion::Components component=hyperion::COMP_INVALID, const QString origin="System", unsigned smooth_cfg=SMOOTHING_MODE_DEFAULT);
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Clears the specified priority channel
|
|
|
|
///
|
|
|
|
/// @param[in] priority The priority of the channel to clear
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void clearInput(const int priority);
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Clears all priority channels
|
|
|
|
///
|
2017-08-12 07:55:32 +02:00
|
|
|
void clearAll(bool forceClearAll=false);
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// Updates the current time. Channels with a configured time out will be checked and cleared if
|
|
|
|
/// required.
|
|
|
|
///
|
|
|
|
/// @param[in] now The current time
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void setCurrentTime(const int64_t& now);
|
|
|
|
|
2017-06-17 23:29:04 +02:00
|
|
|
signals:
|
|
|
|
///
|
|
|
|
/// Signal which is called, when a effect or color with timeout is running, once per second
|
|
|
|
///
|
|
|
|
void timerunner();
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
///
|
|
|
|
/// Slots which is called to adapt to 1s interval for signal timerunner()
|
|
|
|
///
|
|
|
|
void emitReq();
|
|
|
|
|
2013-08-13 11:10:45 +02:00
|
|
|
private:
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The current priority (lowest value in _activeInputs)
|
2013-08-18 13:33:56 +02:00
|
|
|
int _currentPriority;
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The mapping from priority channel to led-information
|
2013-08-18 13:33:56 +02:00
|
|
|
QMap<int, InputInfo> _activeInputs;
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
/// The information of the lowest priority channel
|
2013-08-18 13:33:56 +02:00
|
|
|
InputInfo _lowestPriorityInfo;
|
|
|
|
|
2017-06-17 23:29:04 +02:00
|
|
|
QTimer _timer;
|
|
|
|
QTimer _blockTimer;
|
2013-08-13 11:10:45 +02:00
|
|
|
};
|