From 3156488b68abf3c71f8f854207a058e3bfa3a706 Mon Sep 17 00:00:00 2001 From: Robin Kobus Date: Tue, 4 Oct 2016 22:13:29 +0200 Subject: [PATCH] Smoothing Fix (#261) Increase color change for small RGB differences. --- libsrc/hyperion/LinearColorSmoothing.cpp | 22 ++++++++++++++-------- libsrc/hyperion/LinearColorSmoothing.h | 2 ++ 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/libsrc/hyperion/LinearColorSmoothing.cpp b/libsrc/hyperion/LinearColorSmoothing.cpp index 184894b3..79c93d09 100644 --- a/libsrc/hyperion/LinearColorSmoothing.cpp +++ b/libsrc/hyperion/LinearColorSmoothing.cpp @@ -91,15 +91,21 @@ void LinearColorSmoothing::updateLeds() _writeToLedsEnable = true; float k = 1.0f - 1.0f * deltaTime / (_targetTime - _previousTime); - for (size_t i = 0; i < _previousValues.size(); ++i) - { - ColorRgb & prev = _previousValues[i]; - ColorRgb & target = _targetValues[i]; + int reddif = 0, greendif = 0, bluedif = 0; - prev.red += k * (target.red - prev.red); - prev.green += k * (target.green - prev.green); - prev.blue += k * (target.blue - prev.blue); - } + for (size_t i = 0; i < _previousValues.size(); ++i) + { + ColorRgb & prev = _previousValues[i]; + ColorRgb & target = _targetValues[i]; + + reddif = target.red - prev.red; + greendif = target.green - prev.green; + bluedif = target.blue - prev.blue; + + prev.red += (reddif < 0 ? -1:1) * ceil(k * abs(reddif)); + prev.green += (greendif < 0 ? -1:1) * ceil(k * abs(greendif)); + prev.blue += (bluedif < 0 ? -1:1) * ceil(k * abs(bluedif)); + } _previousTime = now; queueColors(_previousValues); diff --git a/libsrc/hyperion/LinearColorSmoothing.h b/libsrc/hyperion/LinearColorSmoothing.h index 7cfc820e..84fad900 100644 --- a/libsrc/hyperion/LinearColorSmoothing.h +++ b/libsrc/hyperion/LinearColorSmoothing.h @@ -3,6 +3,8 @@ // STL includes #include #include +#include +#include // Qt includes #include