forked from Makuna/NeoPixelBus
functional (#643)
This commit is contained in:
@@ -1,87 +0,0 @@
|
|||||||
// NeoPixelBrightness
|
|
||||||
// This example will cycle brightness from high to low of
|
|
||||||
// three pixels colored Red, Green, Blue.
|
|
||||||
// This demonstrates the use of the NeoPixelBrightnessBus
|
|
||||||
// with integrated brightness support
|
|
||||||
//
|
|
||||||
// There is serial output of the current state so you can
|
|
||||||
// confirm and follow along
|
|
||||||
//
|
|
||||||
|
|
||||||
#include <NeoPixelBrightnessBus.h> // instead of NeoPixelBus.h
|
|
||||||
|
|
||||||
const uint16_t PixelCount = 3; // this example assumes 3 pixels, making it smaller will cause a failure
|
|
||||||
const uint8_t PixelPin = 14; // make sure to set this to the correct pin, ignored for Esp8266
|
|
||||||
|
|
||||||
#define colorSaturation 255 // saturation of color constants
|
|
||||||
RgbColor red(colorSaturation, 0, 0);
|
|
||||||
RgbColor green(0, colorSaturation, 0);
|
|
||||||
RgbColor blue(0, 0, colorSaturation);
|
|
||||||
|
|
||||||
// Make sure to provide the correct color order feature
|
|
||||||
// for your NeoPixels
|
|
||||||
NeoPixelBrightnessBus<NeoRgbFeature, Neo800KbpsMethod> strip(PixelCount, PixelPin);
|
|
||||||
|
|
||||||
// you loose the original color the lower the dim value used
|
|
||||||
// here due to quantization
|
|
||||||
const uint8_t c_MinBrightness = 8;
|
|
||||||
const uint8_t c_MaxBrightness = 255;
|
|
||||||
|
|
||||||
int8_t direction; // current direction of dimming
|
|
||||||
|
|
||||||
void setup()
|
|
||||||
{
|
|
||||||
Serial.begin(115200);
|
|
||||||
while (!Serial); // wait for serial attach
|
|
||||||
|
|
||||||
Serial.println();
|
|
||||||
Serial.println("Initializing...");
|
|
||||||
Serial.flush();
|
|
||||||
|
|
||||||
// this resets all the neopixels to an off state
|
|
||||||
strip.Begin();
|
|
||||||
strip.Show();
|
|
||||||
|
|
||||||
direction = -1; // default to dim first
|
|
||||||
|
|
||||||
Serial.println();
|
|
||||||
Serial.println("Running...");
|
|
||||||
|
|
||||||
// set our three original colors
|
|
||||||
strip.SetPixelColor(0, red);
|
|
||||||
strip.SetPixelColor(1, green);
|
|
||||||
strip.SetPixelColor(2, blue);
|
|
||||||
|
|
||||||
strip.Show();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void loop()
|
|
||||||
{
|
|
||||||
uint8_t brightness = strip.GetBrightness();
|
|
||||||
Serial.println(brightness);
|
|
||||||
|
|
||||||
delay(100);
|
|
||||||
|
|
||||||
// swap diection of dim when limits are reached
|
|
||||||
//
|
|
||||||
if (direction < 0 && brightness <= c_MinBrightness)
|
|
||||||
{
|
|
||||||
direction = 1;
|
|
||||||
}
|
|
||||||
else if (direction > 0 && brightness >= c_MaxBrightness)
|
|
||||||
{
|
|
||||||
direction = -1;
|
|
||||||
}
|
|
||||||
// apply dimming
|
|
||||||
brightness += direction;
|
|
||||||
|
|
||||||
strip.SetPixelColor(0, red);
|
|
||||||
strip.SetPixelColor(1, green);
|
|
||||||
strip.SetPixelColor(2, blue);
|
|
||||||
strip.SetBrightness(brightness);
|
|
||||||
|
|
||||||
// show the results
|
|
||||||
strip.Show();
|
|
||||||
}
|
|
||||||
|
|
105
examples/NeoPixelBusLg/NeoPixelBusLg.ino
Normal file
105
examples/NeoPixelBusLg/NeoPixelBusLg.ino
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
// NeoPixelBusLg
|
||||||
|
//
|
||||||
|
// This example demonstrates the use of the NeoPixelBusLg
|
||||||
|
// with integrated luminance and gamma support
|
||||||
|
//
|
||||||
|
// There is serial output of the current state so you can
|
||||||
|
// confirm and follow along
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <NeoPixelBusLg.h> // instead of NeoPixelBus.h
|
||||||
|
|
||||||
|
const uint16_t PixelCount = 96; // set to the number of pixels in your strip
|
||||||
|
const uint8_t PixelPin = 14; // make sure to set this to the correct pin, ignored for Esp8266
|
||||||
|
|
||||||
|
RgbColor red(255, 0, 0);
|
||||||
|
RgbColor green(0, 255, 0);
|
||||||
|
RgbColor blue(0, 0, 255);
|
||||||
|
RgbColor black(0, 0, 0);
|
||||||
|
RgbColor white(255, 255, 255);
|
||||||
|
|
||||||
|
// Make sure to provide the correct color order feature
|
||||||
|
// for your NeoPixels
|
||||||
|
NeoPixelBusLg<NeoRgbFeature, NeoWs2812xMethod> strip(PixelCount, PixelPin);
|
||||||
|
|
||||||
|
// If speed is an issue and memory is not, then you can use the gama table variant
|
||||||
|
// which is much faster but uses 256 bytes of RAM
|
||||||
|
// NeoPixelBusLg<NeoRgbFeature, NeoWs2812xMethod, NeoGammaTableMethod> strip(PixelCount, PixelPin);
|
||||||
|
|
||||||
|
// If you want to turn gama correction off, then you can use the null gama method
|
||||||
|
// NeoPixelBusLg<NeoRgbFeature, NeoWs2812xMethod, NeoGammaNullMethod> strip(PixelCount, PixelPin);
|
||||||
|
|
||||||
|
void setup()
|
||||||
|
{
|
||||||
|
Serial.begin(115200);
|
||||||
|
while (!Serial); // wait for serial attach
|
||||||
|
|
||||||
|
Serial.println();
|
||||||
|
Serial.println("Initializing...");
|
||||||
|
Serial.flush();
|
||||||
|
|
||||||
|
// this resets all the neopixels to an off state
|
||||||
|
strip.Begin();
|
||||||
|
strip.SetLuminance(128); // (0-255) - initially at half brightness
|
||||||
|
strip.Show();
|
||||||
|
|
||||||
|
Serial.println();
|
||||||
|
Serial.println("Running...");
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop()
|
||||||
|
{
|
||||||
|
static const uint8_t c_MinBrightness = 0;
|
||||||
|
static const uint8_t c_MaxBrightness = 255;
|
||||||
|
|
||||||
|
static int8_t direction = -1; // start with dimming
|
||||||
|
|
||||||
|
uint8_t luminance = strip.GetLuminance();
|
||||||
|
|
||||||
|
Serial.print(direction);
|
||||||
|
Serial.print(" ");
|
||||||
|
Serial.println(luminance);
|
||||||
|
|
||||||
|
delay(200);
|
||||||
|
|
||||||
|
// swap direction of luminance when limits are reached
|
||||||
|
//
|
||||||
|
if (direction < 0 && luminance <= c_MinBrightness)
|
||||||
|
{
|
||||||
|
direction = 1;
|
||||||
|
}
|
||||||
|
else if (direction > 0 && luminance >= c_MaxBrightness)
|
||||||
|
{
|
||||||
|
direction = -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
luminance += direction;
|
||||||
|
}
|
||||||
|
|
||||||
|
strip.SetLuminance(luminance);
|
||||||
|
|
||||||
|
// draw something
|
||||||
|
//
|
||||||
|
uint16_t half = strip.PixelCount() / 2;
|
||||||
|
DrawGradiant(green, black, 0, half - 1);
|
||||||
|
DrawGradiant(black, red, half, strip.PixelCount() - 1);
|
||||||
|
|
||||||
|
// show the results
|
||||||
|
strip.Show();
|
||||||
|
}
|
||||||
|
|
||||||
|
void DrawGradiant(RgbColor startColor,
|
||||||
|
RgbColor finishColor,
|
||||||
|
uint16_t startIndex,
|
||||||
|
uint16_t finishIndex)
|
||||||
|
{
|
||||||
|
uint16_t delta = finishIndex - startIndex;
|
||||||
|
|
||||||
|
for (uint16_t index = startIndex; index < finishIndex; index++)
|
||||||
|
{
|
||||||
|
float progress = static_cast<float>(index - startIndex) / delta;
|
||||||
|
RgbColor color = RgbColor::LinearBlend(startColor, finishColor, progress);
|
||||||
|
strip.SetPixelColor(index, color);
|
||||||
|
}
|
||||||
|
}
|
@@ -7,6 +7,7 @@
|
|||||||
#######################################
|
#######################################
|
||||||
|
|
||||||
NeoPixelBus KEYWORD1
|
NeoPixelBus KEYWORD1
|
||||||
|
NeoPixelBusLg KEYWORD1
|
||||||
NeoPixelSegmentBus KEYWORD1
|
NeoPixelSegmentBus KEYWORD1
|
||||||
RgbwColor KEYWORD1
|
RgbwColor KEYWORD1
|
||||||
RgbColor KEYWORD1
|
RgbColor KEYWORD1
|
||||||
@@ -760,6 +761,9 @@ PixelCount KEYWORD2
|
|||||||
SetPixelColor KEYWORD2
|
SetPixelColor KEYWORD2
|
||||||
GetPixelColor KEYWORD2
|
GetPixelColor KEYWORD2
|
||||||
SwapPixelColor KEYWORD2
|
SwapPixelColor KEYWORD2
|
||||||
|
SetLuminance KEYWORD2
|
||||||
|
GetLuminance KEYWORD2
|
||||||
|
ApplyPostAdjustments KEYWORD2
|
||||||
SetString KEYWORD2
|
SetString KEYWORD2
|
||||||
CalculateBrightness KEYWORD2
|
CalculateBrightness KEYWORD2
|
||||||
Dim KEYWORD2
|
Dim KEYWORD2
|
||||||
|
130
src/NeoPixelBusLg.h
Normal file
130
src/NeoPixelBusLg.h
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
/*-------------------------------------------------------------------------
|
||||||
|
NeoPixelBus library wrapper template class that provides luminance and gamma control
|
||||||
|
|
||||||
|
Written by Michael C. Miller.
|
||||||
|
|
||||||
|
I invest time and resources providing this open source code,
|
||||||
|
please support me by dontating (see https://github.com/Makuna/NeoPixelBus)
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------
|
||||||
|
This file is part of the Makuna/NeoPixelBus library.
|
||||||
|
|
||||||
|
NeoPixelBus is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as
|
||||||
|
published by the Free Software Foundation, either version 3 of
|
||||||
|
the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
NeoPixelBus is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public
|
||||||
|
License along with NeoPixel. If not, see
|
||||||
|
<http://www.gnu.org/licenses/>.
|
||||||
|
-------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "NeoPixelBus.h"
|
||||||
|
|
||||||
|
template<typename T_COLOR_FEATURE, typename T_METHOD, typename T_GAMMA = NeoGammaEquationMethod> class NeoPixelBusLg :
|
||||||
|
public NeoPixelBus<T_COLOR_FEATURE, T_METHOD>
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
typename T_COLOR_FEATURE::ColorObject ConvertColor(typename T_COLOR_FEATURE::ColorObject color)
|
||||||
|
{
|
||||||
|
// dim and then return gamma adjusted
|
||||||
|
color = color.Dim(_luminance);
|
||||||
|
return NeoGamma<T_GAMMA>::Correct(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
NeoPixelBusLg(uint16_t countPixels, uint8_t pin) :
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>(countPixels, pin),
|
||||||
|
_luminance(255)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NeoPixelBusLg(uint16_t countPixels, uint8_t pin, NeoBusChannel channel) :
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>(countPixels, pin, channel),
|
||||||
|
_luminance(255)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NeoPixelBusLg(uint16_t countPixels, uint8_t pinClock, uint8_t pinData) :
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>(countPixels, pinClock, pinData),
|
||||||
|
_luminance(255)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NeoPixelBusLg(uint16_t countPixels, uint8_t pinClock, uint8_t pinData, uint8_t pinLatch, uint8_t pinOutputEnable = NOT_A_PIN) :
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>(countPixels, pinClock, pinData, pinLatch, pinOutputEnable),
|
||||||
|
_luminance(255)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NeoPixelBusLg(uint16_t countPixels) :
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>(countPixels),
|
||||||
|
_luminance(255)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetLuminance(uint8_t luminance)
|
||||||
|
{
|
||||||
|
// does NOT affect current pixel data as there is no safe way
|
||||||
|
// to reconstruct the original color values after being
|
||||||
|
// modified with both luminance and gama without storing them
|
||||||
|
_luminance = luminance;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t GetLuminance() const
|
||||||
|
{
|
||||||
|
return _luminance;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetPixelColor(uint16_t indexPixel, typename T_COLOR_FEATURE::ColorObject color)
|
||||||
|
{
|
||||||
|
color = ConvertColor(color);
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::SetPixelColor(indexPixel, color);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
GetPixelColor is not overloaded as the original will be used
|
||||||
|
to just return the fully adjusted color value directly with
|
||||||
|
no reverse conversion since it is fraught with inaccuracy
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ClearTo(typename T_COLOR_FEATURE::ColorObject color)
|
||||||
|
{
|
||||||
|
color = ConvertColor(color);
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::ClearTo(color);
|
||||||
|
};
|
||||||
|
|
||||||
|
void ClearTo(typename T_COLOR_FEATURE::ColorObject color, uint16_t first, uint16_t last)
|
||||||
|
{
|
||||||
|
color = ConvertColor(color);
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::ClearTo(color, first, last);
|
||||||
|
}
|
||||||
|
|
||||||
|
// if the Pixels buffer is manipulated directly, then this can be called
|
||||||
|
// to apply the luminance and gamma correction to those changes
|
||||||
|
void ApplyPostAdjustments()
|
||||||
|
{
|
||||||
|
if (this->IsDirty())
|
||||||
|
{
|
||||||
|
for (uint16_t indexPixel = 0; indexPixel < NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::PixelCount(); indexPixel++)
|
||||||
|
{
|
||||||
|
typename T_COLOR_FEATURE::ColorObject color = NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::GetPixelColor(indexPixel);
|
||||||
|
color = ConvertColor(color);
|
||||||
|
NeoPixelBus<T_COLOR_FEATURE, T_METHOD>::SetPixelColor(indexPixel, color);
|
||||||
|
}
|
||||||
|
this->Dirty();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
uint8_t _luminance;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
@@ -60,19 +60,32 @@ private:
|
|||||||
static const uint8_t _table[256];
|
static const uint8_t _table[256];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// no gamma correction at all
|
||||||
|
class NeoGammaNullMethod
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static uint8_t Correct(uint8_t value)
|
||||||
|
{
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
static uint16_t Correct(uint16_t value)
|
||||||
|
{
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// use one of the method classes above as a converter for this template class
|
// use one of the method classes above as a converter for this template class
|
||||||
template<typename T_METHOD> class NeoGamma
|
template<typename T_METHOD> class NeoGamma
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RgbColor Correct(const RgbColor& original)
|
static RgbColor Correct(const RgbColor& original)
|
||||||
{
|
{
|
||||||
return RgbColor(T_METHOD::Correct(original.R),
|
return RgbColor(T_METHOD::Correct(original.R),
|
||||||
T_METHOD::Correct(original.G),
|
T_METHOD::Correct(original.G),
|
||||||
T_METHOD::Correct(original.B));
|
T_METHOD::Correct(original.B));
|
||||||
}
|
}
|
||||||
|
|
||||||
RgbwColor Correct(const RgbwColor& original)
|
static RgbwColor Correct(const RgbwColor& original)
|
||||||
{
|
{
|
||||||
return RgbwColor(T_METHOD::Correct(original.R),
|
return RgbwColor(T_METHOD::Correct(original.R),
|
||||||
T_METHOD::Correct(original.G),
|
T_METHOD::Correct(original.G),
|
||||||
@@ -80,14 +93,14 @@ public:
|
|||||||
T_METHOD::Correct(original.W) );
|
T_METHOD::Correct(original.W) );
|
||||||
}
|
}
|
||||||
|
|
||||||
Rgb48Color Correct(const Rgb48Color& original)
|
static Rgb48Color Correct(const Rgb48Color& original)
|
||||||
{
|
{
|
||||||
return Rgb48Color(T_METHOD::Correct(original.R),
|
return Rgb48Color(T_METHOD::Correct(original.R),
|
||||||
T_METHOD::Correct(original.G),
|
T_METHOD::Correct(original.G),
|
||||||
T_METHOD::Correct(original.B));
|
T_METHOD::Correct(original.B));
|
||||||
}
|
}
|
||||||
|
|
||||||
Rgbw64Color Correct(const Rgbw64Color& original)
|
static Rgbw64Color Correct(const Rgbw64Color& original)
|
||||||
{
|
{
|
||||||
return Rgbw64Color(T_METHOD::Correct(original.R),
|
return Rgbw64Color(T_METHOD::Correct(original.R),
|
||||||
T_METHOD::Correct(original.G),
|
T_METHOD::Correct(original.G),
|
||||||
|
Reference in New Issue
Block a user