2013-07-26 20:38:34 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// STL includes
|
|
|
|
#include <ctime>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
// Local includes
|
2013-11-11 09:00:37 +00:00
|
|
|
#include <utils/ColorRgb.h>
|
2013-07-26 20:38:34 +00:00
|
|
|
|
2016-09-25 21:59:31 +02:00
|
|
|
// QT includes
|
|
|
|
#include <QString>
|
2023-08-26 11:12:43 +02:00
|
|
|
#include <QJsonArray>
|
2016-09-25 21:59:31 +02:00
|
|
|
|
2013-07-26 20:38:34 +00:00
|
|
|
// Forward class declarations
|
|
|
|
namespace Json { class Value; }
|
|
|
|
|
2015-01-01 19:31:04 +01:00
|
|
|
/// Enumeration containing the possible orders of device color byte data
|
2020-06-28 23:05:32 +02:00
|
|
|
enum class ColorOrder
|
2015-01-01 19:31:04 +01:00
|
|
|
{
|
2015-02-23 16:11:33 +01:00
|
|
|
ORDER_RGB, ORDER_RBG, ORDER_GRB, ORDER_BRG, ORDER_GBR, ORDER_BGR
|
2015-01-01 19:31:04 +01:00
|
|
|
};
|
|
|
|
|
2020-08-08 23:12:43 +02:00
|
|
|
inline QString colorOrderToString(ColorOrder colorOrder)
|
2015-02-23 16:11:33 +01:00
|
|
|
{
|
|
|
|
switch (colorOrder)
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_RGB:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "rgb";
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_RBG:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "rbg";
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_GRB:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "grb";
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_BRG:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "brg";
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_GBR:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "gbr";
|
2020-06-28 23:05:32 +02:00
|
|
|
case ColorOrder::ORDER_BGR:
|
2015-02-23 16:11:33 +01:00
|
|
|
return "bgr";
|
|
|
|
default:
|
|
|
|
return "not-a-colororder";
|
|
|
|
}
|
|
|
|
}
|
2020-07-12 09:19:59 +02:00
|
|
|
|
2016-09-25 21:59:31 +02:00
|
|
|
inline ColorOrder stringToColorOrder(const QString & order)
|
2015-02-23 16:11:33 +01:00
|
|
|
{
|
|
|
|
if (order == "rgb")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_RGB;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
else if (order == "bgr")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_BGR;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
else if (order == "rbg")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_RBG;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
else if (order == "brg")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_BRG;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
else if (order == "gbr")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_GBR;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
else if (order == "grb")
|
|
|
|
{
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_GRB;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
|
2016-09-25 21:59:31 +02:00
|
|
|
std::cout << "Unknown color order defined (" << order.toStdString() << "). Using RGB." << std::endl;
|
2020-06-28 23:05:32 +02:00
|
|
|
return ColorOrder::ORDER_RGB;
|
2015-02-23 16:11:33 +01:00
|
|
|
}
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The Led structure contains the definition of the image portion used to determine a single LED's
|
2013-09-06 19:26:58 +00:00
|
|
|
/// color.
|
2013-09-09 20:35:28 +00:00
|
|
|
/// @verbatim
|
2013-09-06 19:26:58 +00:00
|
|
|
/// |--------------------image--|
|
|
|
|
/// | minX maxX |
|
|
|
|
/// | |-----|minY |
|
|
|
|
/// | | | |
|
|
|
|
/// | |-----|maxY |
|
|
|
|
/// | |
|
|
|
|
/// | |
|
|
|
|
/// | |
|
|
|
|
/// |---------------------------|
|
2013-09-09 20:35:28 +00:00
|
|
|
/// @endverbatim
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2013-07-26 20:38:34 +00:00
|
|
|
struct Led
|
|
|
|
{
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The minimum vertical scan line included for this LEDs color
|
2013-07-26 20:38:34 +00:00
|
|
|
double minX_frac;
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The maximum vertical scan line included for this LEDs color
|
2013-07-26 20:38:34 +00:00
|
|
|
double maxX_frac;
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The minimum horizontal scan line included for this LEDs color
|
2013-07-26 20:38:34 +00:00
|
|
|
double minY_frac;
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The maximum horizontal scan line included for this LEDs color
|
2013-07-26 20:38:34 +00:00
|
|
|
double maxY_frac;
|
2023-08-26 11:12:43 +02:00
|
|
|
/// A LEDs at {0,0,0,0} is not visible and therefore treated as blacklisted
|
|
|
|
bool isBlacklisted {false};
|
2015-01-01 19:31:04 +01:00
|
|
|
/// the color order
|
|
|
|
ColorOrder colorOrder;
|
2013-07-26 20:38:34 +00:00
|
|
|
};
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The LedString contains the image integration information of the LEDs
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2013-07-26 20:38:34 +00:00
|
|
|
class LedString
|
|
|
|
{
|
|
|
|
public:
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2023-08-26 11:12:43 +02:00
|
|
|
/// Returns the LED specifications
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// @return The list with led specifications
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
std::vector<Led>& leds();
|
|
|
|
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
2023-08-26 11:12:43 +02:00
|
|
|
/// Returns the LED specifications
|
2013-09-06 19:26:58 +00:00
|
|
|
///
|
|
|
|
/// @return The list with led specifications
|
|
|
|
///
|
2013-07-26 20:38:34 +00:00
|
|
|
const std::vector<Led>& leds() const;
|
|
|
|
|
2023-08-26 11:12:43 +02:00
|
|
|
///
|
|
|
|
/// Returns the IDs of blacklisted LEDs
|
|
|
|
///
|
|
|
|
/// @return ID List of blacklisted LEDs
|
|
|
|
///
|
|
|
|
std::vector<int>& blacklistedLedIds();
|
|
|
|
|
|
|
|
///
|
|
|
|
/// Returns the IDs of blacklisted LEDs
|
|
|
|
///
|
|
|
|
/// @return ID List of blacklisted LEDs
|
|
|
|
///
|
|
|
|
const std::vector<int>& blacklistedLedIds() const;
|
|
|
|
|
|
|
|
///
|
|
|
|
/// Check, if teh layout has blacklisted LEDs configured
|
|
|
|
///
|
|
|
|
/// @return True, if blacklisted LEDs are configured
|
|
|
|
///
|
|
|
|
bool hasBlackListedLeds ();
|
|
|
|
|
|
|
|
static LedString createLedString(const QJsonArray& ledConfigArray, const ColorOrder deviceOrder);
|
|
|
|
|
2013-07-26 20:38:34 +00:00
|
|
|
private:
|
2023-08-26 11:12:43 +02:00
|
|
|
/// The list with LED specifications
|
|
|
|
std::vector<Led> _leds;
|
|
|
|
/// The list containing IDs of blacklisted LED
|
|
|
|
std::vector<int> _blacklistedLedIds;
|
2013-07-26 20:38:34 +00:00
|
|
|
};
|