mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
efc2046ab5
* LedDevice - Address clang findings * Fix Windows Warnings * Ensure newInput is initialised * Clean-up unused elements for Plaform Capture * Fix initialization problem and spellings * Address clang findings and spelling corrections * LedDevice clean-ups * Cleanups * Align that getLedCount is int * Have "display" as default for Grabbers * Fix config during start-up for missing elements * Framegrabber Clean-up - Remove non supported grabbers from selection, filter valid options * Typo * Framegrabber.json - Fix property numbering * Preselect active Grabbertype * Sort Grabbernames * Align options with selected element * Fix deletion of pointer to incomplete type 'BonjourBrowserWrapper' * Address macOS compile warnings * Have default layout = 1 LED only to avoid errors as in #673 * Address lgtm findings * Address finding that params passed to LedDevice discovery were not considered * Cleanups after merging with latest master * Update Changelog * Address lgtm findings * Fix comment * Test Fix * Fix Python Warning * Handle Dummy Device assignment correctly * Address delete called on non-final 'commandline::Option' that has virtual functions but non-virtual destructor * Correct that QTimer.start accepts only int * Have Release Python GIL & reset threat state chnage downward compatible * Correct format specifier * LedDevice - add assertions * Readonly DB - Fix merge issue * Smoothing - Fix wrong defaults * LedDevice - correct assertion * Show smoothing config set# in debug and related values. * Suppress error on windows, if default file is "/dev/null" * CMAKE - Allow to define QT_BASE_DIR dynamically via environment-variable * Ignore Visual Studio specific files Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com>
128 lines
2.6 KiB
C++
128 lines
2.6 KiB
C++
|
|
#pragma once
|
|
|
|
// STL includes
|
|
#include <ctime>
|
|
#include <vector>
|
|
|
|
// Local includes
|
|
#include <utils/ColorRgb.h>
|
|
|
|
// QT includes
|
|
#include <QString>
|
|
|
|
// Forward class declarations
|
|
namespace Json { class Value; }
|
|
|
|
/// Enumeration containing the possible orders of device color byte data
|
|
enum class ColorOrder
|
|
{
|
|
ORDER_RGB, ORDER_RBG, ORDER_GRB, ORDER_BRG, ORDER_GBR, ORDER_BGR
|
|
};
|
|
|
|
inline QString colorOrderToString(ColorOrder colorOrder)
|
|
{
|
|
switch (colorOrder)
|
|
{
|
|
case ColorOrder::ORDER_RGB:
|
|
return "rgb";
|
|
case ColorOrder::ORDER_RBG:
|
|
return "rbg";
|
|
case ColorOrder::ORDER_GRB:
|
|
return "grb";
|
|
case ColorOrder::ORDER_BRG:
|
|
return "brg";
|
|
case ColorOrder::ORDER_GBR:
|
|
return "gbr";
|
|
case ColorOrder::ORDER_BGR:
|
|
return "bgr";
|
|
default:
|
|
return "not-a-colororder";
|
|
}
|
|
}
|
|
|
|
inline ColorOrder stringToColorOrder(const QString & order)
|
|
{
|
|
if (order == "rgb")
|
|
{
|
|
return ColorOrder::ORDER_RGB;
|
|
}
|
|
else if (order == "bgr")
|
|
{
|
|
return ColorOrder::ORDER_BGR;
|
|
}
|
|
else if (order == "rbg")
|
|
{
|
|
return ColorOrder::ORDER_RBG;
|
|
}
|
|
else if (order == "brg")
|
|
{
|
|
return ColorOrder::ORDER_BRG;
|
|
}
|
|
else if (order == "gbr")
|
|
{
|
|
return ColorOrder::ORDER_GBR;
|
|
}
|
|
else if (order == "grb")
|
|
{
|
|
return ColorOrder::ORDER_GRB;
|
|
}
|
|
|
|
std::cout << "Unknown color order defined (" << order.toStdString() << "). Using RGB." << std::endl;
|
|
return ColorOrder::ORDER_RGB;
|
|
}
|
|
|
|
///
|
|
/// The Led structure contains the definition of the image portion used to determine a single led's
|
|
/// color.
|
|
/// @verbatim
|
|
/// |--------------------image--|
|
|
/// | minX maxX |
|
|
/// | |-----|minY |
|
|
/// | | | |
|
|
/// | |-----|maxY |
|
|
/// | |
|
|
/// | |
|
|
/// | |
|
|
/// |---------------------------|
|
|
/// @endverbatim
|
|
///
|
|
struct Led
|
|
{
|
|
/// The minimum vertical scan line included for this leds color
|
|
double minX_frac;
|
|
/// The maximum vertical scan line included for this leds color
|
|
double maxX_frac;
|
|
/// The minimum horizontal scan line included for this leds color
|
|
double minY_frac;
|
|
/// The maximum horizontal scan line included for this leds color
|
|
double maxY_frac;
|
|
/// the color order
|
|
ColorOrder colorOrder;
|
|
};
|
|
|
|
///
|
|
/// The LedString contains the image integration information of the leds
|
|
///
|
|
class LedString
|
|
{
|
|
public:
|
|
///
|
|
/// Returns the led specifications
|
|
///
|
|
/// @return The list with led specifications
|
|
///
|
|
std::vector<Led>& leds();
|
|
|
|
///
|
|
/// Returns the led specifications
|
|
///
|
|
/// @return The list with led specifications
|
|
///
|
|
const std::vector<Led>& leds() const;
|
|
|
|
private:
|
|
/// The list with led specifications
|
|
std::vector<Led> mLeds;
|
|
};
|