mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
Sk6812rgbwfix (#95)
* sk6812rgbw bug fix and rename device to sk6812rgbw-spi * Added white_algorithm support to sk6812rgbw-spi device type
This commit is contained in:
parent
c1cb148f41
commit
d4635bba4e
@ -147,12 +147,13 @@ LedDevice * LedDeviceFactory::construct(const Json::Value & deviceConfig)
|
|||||||
|
|
||||||
device = deviceWs2812SPI;
|
device = deviceWs2812SPI;
|
||||||
}
|
}
|
||||||
else if (type == "sk6812spi")
|
else if (type == "sk6812rgbw-spi")
|
||||||
{
|
{
|
||||||
const std::string output = deviceConfig["output"].asString();
|
const std::string output = deviceConfig["output"].asString();
|
||||||
const unsigned rate = deviceConfig.get("rate",2857143).asInt();
|
const unsigned rate = deviceConfig.get("rate",2857143).asInt();
|
||||||
|
const std::string& whiteAlgorithm = deviceConfig.get("white_algorithm","").asString();
|
||||||
|
|
||||||
LedDeviceSk6812SPI* deviceSk6812SPI = new LedDeviceSk6812SPI(output, rate);
|
LedDeviceSk6812SPI* deviceSk6812SPI = new LedDeviceSk6812SPI(output, rate, whiteAlgorithm);
|
||||||
deviceSk6812SPI->open();
|
deviceSk6812SPI->open();
|
||||||
|
|
||||||
device = deviceSk6812SPI;
|
device = deviceSk6812SPI;
|
||||||
|
@ -11,9 +11,10 @@
|
|||||||
// hyperion local includes
|
// hyperion local includes
|
||||||
#include "LedDeviceSk6812SPI.h"
|
#include "LedDeviceSk6812SPI.h"
|
||||||
|
|
||||||
LedDeviceSk6812SPI::LedDeviceSk6812SPI(const std::string& outputDevice, const unsigned baudrate) :
|
LedDeviceSk6812SPI::LedDeviceSk6812SPI(const std::string& outputDevice, const unsigned baudrate, const std::string& whiteAlgorithm) :
|
||||||
LedSpiDevice(outputDevice, baudrate, 0),
|
LedSpiDevice(outputDevice, baudrate, 0),
|
||||||
mLedCount(0),
|
mLedCount(0),
|
||||||
|
_whiteAlgorithm(whiteAlgorithm),
|
||||||
bitpair_to_byte {
|
bitpair_to_byte {
|
||||||
0b10001000,
|
0b10001000,
|
||||||
0b10001100,
|
0b10001100,
|
||||||
@ -22,7 +23,7 @@ LedDeviceSk6812SPI::LedDeviceSk6812SPI(const std::string& outputDevice, const un
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
// empty
|
Debug( _log, "whiteAlgorithm : %s", whiteAlgorithm.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
||||||
@ -30,7 +31,7 @@ int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
|||||||
mLedCount = ledValues.size();
|
mLedCount = ledValues.size();
|
||||||
|
|
||||||
// 4 colours, 4 spi bytes per colour + 3 frame end latch bytes
|
// 4 colours, 4 spi bytes per colour + 3 frame end latch bytes
|
||||||
#define COLOURS_PER_LED 3
|
#define COLOURS_PER_LED 4
|
||||||
#define SPI_BYTES_PER_COLOUR 4
|
#define SPI_BYTES_PER_COLOUR 4
|
||||||
#define SPI_BYTES_PER_LED COLOURS_PER_LED * SPI_BYTES_PER_COLOUR
|
#define SPI_BYTES_PER_LED COLOURS_PER_LED * SPI_BYTES_PER_COLOUR
|
||||||
|
|
||||||
@ -40,13 +41,14 @@ int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
|||||||
}
|
}
|
||||||
|
|
||||||
unsigned spi_ptr = 0;
|
unsigned spi_ptr = 0;
|
||||||
for (unsigned i=0; i< mLedCount; ++i) {
|
|
||||||
uint8_t white = 0;
|
for (const ColorRgb& color : ledValues) {
|
||||||
|
Rgb_to_Rgbw(color, &_temp_rgbw, _whiteAlgorithm);
|
||||||
uint32_t colorBits =
|
uint32_t colorBits =
|
||||||
((unsigned int)ledValues[i].red << 24) |
|
((uint32_t)_temp_rgbw.red << 24) +
|
||||||
((unsigned int)ledValues[i].green << 16) |
|
((uint32_t)_temp_rgbw.green << 16) +
|
||||||
((unsigned int)ledValues[i].blue << 8) |
|
((uint32_t)_temp_rgbw.blue << 8) +
|
||||||
white;
|
_temp_rgbw.white;
|
||||||
|
|
||||||
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--) {
|
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--) {
|
||||||
_spiBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ];
|
_spiBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ];
|
||||||
|
@ -19,8 +19,8 @@ public:
|
|||||||
/// @param baudrate The used baudrate for writing to the output device
|
/// @param baudrate The used baudrate for writing to the output device
|
||||||
///
|
///
|
||||||
|
|
||||||
LedDeviceSk6812SPI(const std::string& outputDevice,
|
LedDeviceSk6812SPI(const std::string& outputDevice, const unsigned baudrate,
|
||||||
const unsigned baudrate);
|
const std::string& whiteAlgorithm);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Writes the led color values to the led-device
|
/// Writes the led color values to the led-device
|
||||||
@ -39,5 +39,7 @@ private:
|
|||||||
size_t mLedCount;
|
size_t mLedCount;
|
||||||
std::vector<uint8_t> _spiBuffer;
|
std::vector<uint8_t> _spiBuffer;
|
||||||
|
|
||||||
|
std::string _whiteAlgorithm;
|
||||||
uint8_t bitpair_to_byte[4];
|
uint8_t bitpair_to_byte[4];
|
||||||
|
ColorRgbw _temp_rgbw;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user