hyperion.ng/include/hyperion/LedString.h
LordGrey efc2046ab5
Various Cleanups (#1075)
* 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>
2020-11-14 17:58:56 +01:00

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;
};