2016-04-02 00:04:11 +02:00
|
|
|
// Hyperion includes
|
2016-07-01 23:20:41 +02:00
|
|
|
#include <utils/Logger.h>
|
2018-12-27 23:11:32 +01:00
|
|
|
#include <hyperion/MultiColorAdjustment.h>
|
2016-04-02 00:04:11 +02:00
|
|
|
|
2020-08-08 13:09:15 +02:00
|
|
|
MultiColorAdjustment::MultiColorAdjustment(unsigned ledCnt)
|
2016-07-01 23:20:41 +02:00
|
|
|
: _ledAdjustments(ledCnt, nullptr)
|
2018-12-27 23:11:32 +01:00
|
|
|
, _log(Logger::getInstance("ADJUSTMENT"))
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
MultiColorAdjustment::~MultiColorAdjustment()
|
|
|
|
{
|
|
|
|
// Clean up all the transforms
|
|
|
|
for (ColorAdjustment * adjustment : _adjustment)
|
|
|
|
{
|
|
|
|
delete adjustment;
|
2020-06-28 23:05:32 +02:00
|
|
|
// BUG: Calling pop_back while iterating is invalid
|
2020-02-10 15:21:58 +01:00
|
|
|
_adjustment.pop_back();
|
2016-04-02 00:04:11 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void MultiColorAdjustment::addAdjustment(ColorAdjustment * adjustment)
|
|
|
|
{
|
|
|
|
_adjustmentIds.push_back(adjustment->_id);
|
|
|
|
_adjustment.push_back(adjustment);
|
|
|
|
}
|
|
|
|
|
2020-08-08 13:09:15 +02:00
|
|
|
void MultiColorAdjustment::setAdjustmentForLed(const QString& id, unsigned startLed, unsigned endLed)
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
2018-12-27 23:11:32 +01:00
|
|
|
// abort
|
2020-02-10 15:21:58 +01:00
|
|
|
if(startLed > endLed)
|
2018-12-27 23:11:32 +01:00
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
Error(_log,"startLed > endLed -> %d > %d", startLed, endLed);
|
2018-12-27 23:11:32 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
// catch wrong values
|
2020-02-10 15:21:58 +01:00
|
|
|
if(endLed > _ledAdjustments.size()-1)
|
2018-12-27 23:11:32 +01:00
|
|
|
{
|
|
|
|
Warning(_log,"The color calibration 'LED index' field has leds specified which aren't part of your led layout");
|
2020-02-10 15:21:58 +01:00
|
|
|
endLed = _ledAdjustments.size()-1;
|
2018-12-27 23:11:32 +01:00
|
|
|
}
|
2016-04-02 00:04:11 +02:00
|
|
|
|
|
|
|
// Get the identified adjustment (don't care if is nullptr)
|
|
|
|
ColorAdjustment * adjustment = getAdjustment(id);
|
2020-02-10 15:21:58 +01:00
|
|
|
|
|
|
|
//Debug(_log,"ColorAdjustment Profile [%s], startLed[%u], endLed[%u]", QSTRING_CSTR(id), startLed, endLed);
|
2016-04-02 00:04:11 +02:00
|
|
|
for (unsigned iLed=startLed; iLed<=endLed; ++iLed)
|
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
//Debug(_log,"_ledAdjustments [%u] -> [%p]", iLed, adjustment);
|
2016-04-02 00:04:11 +02:00
|
|
|
_ledAdjustments[iLed] = adjustment;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool MultiColorAdjustment::verifyAdjustments() const
|
|
|
|
{
|
2018-12-27 23:11:32 +01:00
|
|
|
bool ok = true;
|
2016-04-02 00:04:11 +02:00
|
|
|
for (unsigned iLed=0; iLed<_ledAdjustments.size(); ++iLed)
|
|
|
|
{
|
2017-01-06 14:25:55 +01:00
|
|
|
ColorAdjustment * adjustment = _ledAdjustments[iLed];
|
|
|
|
|
|
|
|
if (adjustment == nullptr)
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
2018-12-27 23:11:32 +01:00
|
|
|
Warning(_log, "No calibration set for led %d", iLed);
|
|
|
|
ok = false;
|
2016-04-02 00:04:11 +02:00
|
|
|
}
|
|
|
|
}
|
2018-12-27 23:11:32 +01:00
|
|
|
return ok;
|
2016-04-02 00:04:11 +02:00
|
|
|
}
|
|
|
|
|
2017-03-04 22:17:42 +01:00
|
|
|
const QStringList & MultiColorAdjustment::getAdjustmentIds()
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
|
|
|
return _adjustmentIds;
|
|
|
|
}
|
|
|
|
|
2017-03-04 22:17:42 +01:00
|
|
|
ColorAdjustment* MultiColorAdjustment::getAdjustment(const QString& id)
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
|
|
|
// Iterate through the unique adjustments until we find the one with the given id
|
|
|
|
for (ColorAdjustment* adjustment : _adjustment)
|
|
|
|
{
|
|
|
|
if (adjustment->_id == id)
|
|
|
|
{
|
|
|
|
return adjustment;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The ColorAdjustment was not found
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2017-02-11 22:52:47 +01:00
|
|
|
void MultiColorAdjustment::setBacklightEnabled(bool enable)
|
|
|
|
{
|
|
|
|
for (ColorAdjustment* adjustment : _adjustment)
|
|
|
|
{
|
|
|
|
adjustment->_rgbTransform.setBackLightEnabled(enable);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-01 23:20:41 +02:00
|
|
|
void MultiColorAdjustment::applyAdjustment(std::vector<ColorRgb>& ledColors)
|
2016-04-02 00:04:11 +02:00
|
|
|
{
|
2017-08-04 12:01:45 +02:00
|
|
|
const size_t itCnt = qMin(_ledAdjustments.size(), ledColors.size());
|
2016-04-02 00:04:11 +02:00
|
|
|
for (size_t i=0; i<itCnt; ++i)
|
|
|
|
{
|
|
|
|
ColorAdjustment* adjustment = _ledAdjustments[i];
|
|
|
|
if (adjustment == nullptr)
|
|
|
|
{
|
2020-02-10 15:21:58 +01:00
|
|
|
//std::cout << "MultiColorAdjustment::applyAdjustment() - No transform set for this led : " << i << std::endl;
|
2016-04-02 00:04:11 +02:00
|
|
|
// No transform set for this led (do nothing)
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
ColorRgb& color = ledColors[i];
|
2017-01-06 14:25:55 +01:00
|
|
|
|
|
|
|
uint8_t ored = color.red;
|
|
|
|
uint8_t ogreen = color.green;
|
|
|
|
uint8_t oblue = color.blue;
|
2019-07-09 23:07:31 +02:00
|
|
|
uint8_t B_RGB = 0, B_CMY = 0, B_W = 0;
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2017-01-06 14:25:55 +01:00
|
|
|
adjustment->_rgbTransform.transform(ored,ogreen,oblue);
|
2017-04-03 05:19:05 +02:00
|
|
|
adjustment->_rgbTransform.getBrightnessComponents(B_RGB, B_CMY, B_W);
|
2017-01-06 14:25:55 +01:00
|
|
|
|
|
|
|
uint32_t nrng = (uint32_t) (255-ored)*(255-ogreen);
|
|
|
|
uint32_t rng = (uint32_t) (ored) *(255-ogreen);
|
|
|
|
uint32_t nrg = (uint32_t) (255-ored)*(ogreen);
|
|
|
|
uint32_t rg = (uint32_t) (ored) *(ogreen);
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2017-01-06 14:25:55 +01:00
|
|
|
uint8_t black = nrng*(255-oblue)/65025;
|
|
|
|
uint8_t red = rng *(255-oblue)/65025;
|
|
|
|
uint8_t green = nrg *(255-oblue)/65025;
|
|
|
|
uint8_t blue = nrng*(oblue) /65025;
|
|
|
|
uint8_t cyan = nrg *(oblue) /65025;
|
|
|
|
uint8_t magenta = rng *(oblue) /65025;
|
|
|
|
uint8_t yellow = rg *(255-oblue)/65025;
|
|
|
|
uint8_t white = rg *(oblue) /65025;
|
2018-12-27 23:11:32 +01:00
|
|
|
|
2017-04-03 05:19:05 +02:00
|
|
|
uint8_t OR, OG, OB, RR, RG, RB, GR, GG, GB, BR, BG, BB;
|
|
|
|
uint8_t CR, CG, CB, MR, MG, MB, YR, YG, YB, WR, WG, WB;
|
|
|
|
|
|
|
|
adjustment->_rgbBlackAdjustment.apply (black , 255 , OR, OG, OB);
|
|
|
|
adjustment->_rgbRedAdjustment.apply (red , B_RGB, RR, RG, RB);
|
|
|
|
adjustment->_rgbGreenAdjustment.apply (green , B_RGB, GR, GG, GB);
|
|
|
|
adjustment->_rgbBlueAdjustment.apply (blue , B_RGB, BR, BG, BB);
|
|
|
|
adjustment->_rgbCyanAdjustment.apply (cyan , B_CMY, CR, CG, CB);
|
|
|
|
adjustment->_rgbMagentaAdjustment.apply(magenta, B_CMY, MR, MG, MB);
|
|
|
|
adjustment->_rgbYellowAdjustment.apply (yellow , B_CMY, YR, YG, YB);
|
|
|
|
adjustment->_rgbWhiteAdjustment.apply (white , B_W , WR, WG, WB);
|
2017-01-10 19:58:41 +01:00
|
|
|
|
2016-12-29 17:02:37 +01:00
|
|
|
color.red = OR + RR + GR + BR + CR + MR + YR + WR;
|
|
|
|
color.green = OG + RG + GG + BG + CG + MG + YG + WG;
|
|
|
|
color.blue = OB + RB + GB + BB + CB + MB + YB + WB;
|
2016-04-02 00:04:11 +02:00
|
|
|
}
|
|
|
|
}
|