mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
led device cleanup, bug fix and schemas (#304)
* sk6812SPI was buggy cleaned up code - make sk6812spi and ws2812spi more consistent * led device schema updates
This commit is contained in:
parent
080059cbf5
commit
1670ec58a7
@ -20,7 +20,7 @@
|
|||||||
<file alias="schema-rawhid">schemas/schema-rawhid.json</file>
|
<file alias="schema-rawhid">schemas/schema-rawhid.json</file>
|
||||||
<file alias="schema-sedu">schemas/schema-sedu.json</file>
|
<file alias="schema-sedu">schemas/schema-sedu.json</file>
|
||||||
<file alias="schema-dmx">schemas/schema-dmx.json</file>
|
<file alias="schema-dmx">schemas/schema-dmx.json</file>
|
||||||
<file alias="schema-sk6812rgbw-spi">schemas/schema-sk6812rgbw-spi.json</file>
|
<file alias="schema-sk6812spi">schemas/schema-sk6812spi.json</file>
|
||||||
<file alias="schema-tinkerforge">schemas/schema-tinkerforge.json</file>
|
<file alias="schema-tinkerforge">schemas/schema-tinkerforge.json</file>
|
||||||
<file alias="schema-tpm2net">schemas/schema-tpm2net.json</file>
|
<file alias="schema-tpm2net">schemas/schema-tpm2net.json</file>
|
||||||
<file alias="schema-tpm2.json">schemas/schema-tpm2.json</file>
|
<file alias="schema-tpm2.json">schemas/schema-tpm2.json</file>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
LedDeviceSk6812SPI::LedDeviceSk6812SPI(const QJsonObject &deviceConfig)
|
LedDeviceSk6812SPI::LedDeviceSk6812SPI(const QJsonObject &deviceConfig)
|
||||||
: ProviderSpi()
|
: ProviderSpi()
|
||||||
, _whiteAlgorithm(RGBW::INVALID)
|
, _whiteAlgorithm(RGBW::INVALID)
|
||||||
|
, SPI_BYTES_PER_COLOUR(4)
|
||||||
, bitpair_to_byte {
|
, bitpair_to_byte {
|
||||||
0b10001000,
|
0b10001000,
|
||||||
0b10001100,
|
0b10001100,
|
||||||
@ -35,8 +36,8 @@ bool LedDeviceSk6812SPI::init(const QJsonObject &deviceConfig)
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz);
|
||||||
|
|
||||||
const int SPI_BYTES_PER_COLOUR = 4;
|
|
||||||
const int SPI_FRAME_END_LATCH_BYTES = 3;
|
const int SPI_FRAME_END_LATCH_BYTES = 3;
|
||||||
_ledBuffer.resize(_ledRGBWCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00);
|
_ledBuffer.resize(_ledRGBWCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00);
|
||||||
|
|
||||||
@ -46,7 +47,8 @@ bool LedDeviceSk6812SPI::init(const QJsonObject &deviceConfig)
|
|||||||
int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
||||||
{
|
{
|
||||||
unsigned spi_ptr = 0;
|
unsigned spi_ptr = 0;
|
||||||
static const int SPI_BYTES_PER_LED = 4;
|
const int SPI_BYTES_PER_LED = sizeof(ColorRgbw) * SPI_BYTES_PER_COLOUR;
|
||||||
|
|
||||||
|
|
||||||
for (const ColorRgb& color : ledValues)
|
for (const ColorRgb& color : ledValues)
|
||||||
{
|
{
|
||||||
@ -57,7 +59,8 @@ int LedDeviceSk6812SPI::write(const std::vector<ColorRgb> &ledValues)
|
|||||||
((uint32_t)_temp_rgbw.blue << 8) +
|
((uint32_t)_temp_rgbw.blue << 8) +
|
||||||
_temp_rgbw.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--)
|
||||||
|
{
|
||||||
_ledBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ];
|
_ledBuffer[spi_ptr+j] = bitpair_to_byte[ colorBits & 0x3 ];
|
||||||
colorBits >>= 2;
|
colorBits >>= 2;
|
||||||
}
|
}
|
||||||
|
@ -37,6 +37,8 @@ private:
|
|||||||
|
|
||||||
RGBW::WhiteAlgorithm _whiteAlgorithm;
|
RGBW::WhiteAlgorithm _whiteAlgorithm;
|
||||||
|
|
||||||
|
const int SPI_BYTES_PER_COLOUR;
|
||||||
|
|
||||||
uint8_t bitpair_to_byte[4];
|
uint8_t bitpair_to_byte[4];
|
||||||
|
|
||||||
ColorRgbw _temp_rgbw;
|
ColorRgbw _temp_rgbw;
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
LedDeviceWs2812SPI::LedDeviceWs2812SPI(const QJsonObject &deviceConfig)
|
LedDeviceWs2812SPI::LedDeviceWs2812SPI(const QJsonObject &deviceConfig)
|
||||||
: ProviderSpi()
|
: ProviderSpi()
|
||||||
|
, SPI_BYTES_PER_COLOUR(4)
|
||||||
, bitpair_to_byte {
|
, bitpair_to_byte {
|
||||||
0b10001000,
|
0b10001000,
|
||||||
0b10001100,
|
0b10001100,
|
||||||
@ -20,29 +21,28 @@ LedDevice* LedDeviceWs2812SPI::construct(const QJsonObject &deviceConfig)
|
|||||||
bool LedDeviceWs2812SPI::init(const QJsonObject &deviceConfig)
|
bool LedDeviceWs2812SPI::init(const QJsonObject &deviceConfig)
|
||||||
{
|
{
|
||||||
_baudRate_Hz = 3000000;
|
_baudRate_Hz = 3000000;
|
||||||
ProviderSpi::init(deviceConfig);
|
if ( !ProviderSpi::init(deviceConfig) )
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz);
|
WarningIf(( _baudRate_Hz < 2050000 || _baudRate_Hz > 4000000 ), _log, "SPI rate %d outside recommended range (2050000 -> 4000000)", _baudRate_Hz);
|
||||||
|
|
||||||
|
const int SPI_FRAME_END_LATCH_BYTES = 3;
|
||||||
|
_ledBuffer.resize(_ledRGBCount * SPI_BYTES_PER_COLOUR + SPI_FRAME_END_LATCH_BYTES, 0x00);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues)
|
int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues)
|
||||||
{
|
{
|
||||||
// 3 colours, 4 spi bytes per colour + 3 frame end latch bytes
|
|
||||||
const int SPI_BYTES_PER_LED = 3 * 4;
|
|
||||||
unsigned spi_size = _ledCount * SPI_BYTES_PER_LED + 3;
|
|
||||||
|
|
||||||
if(_ledBuffer.size() != spi_size)
|
|
||||||
{
|
|
||||||
_ledBuffer.resize(spi_size, 0x00);
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned spi_ptr = 0;
|
unsigned spi_ptr = 0;
|
||||||
for (unsigned i=0; i<(unsigned)_ledCount; ++i)
|
const int SPI_BYTES_PER_LED = sizeof(ColorRgb) * SPI_BYTES_PER_COLOUR;
|
||||||
|
|
||||||
|
for (const ColorRgb& color : ledValues)
|
||||||
{
|
{
|
||||||
uint32_t colorBits = ((unsigned int)ledValues[i].red << 16)
|
uint32_t colorBits = ((unsigned int)color.red << 16)
|
||||||
| ((unsigned int)ledValues[i].green << 8)
|
| ((unsigned int)color.green << 8)
|
||||||
| ledValues[i].blue;
|
| color.blue;
|
||||||
|
|
||||||
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--)
|
for (int j=SPI_BYTES_PER_LED - 1; j>=0; j--)
|
||||||
{
|
{
|
||||||
@ -51,9 +51,10 @@ int LedDeviceWs2812SPI::write(const std::vector<ColorRgb> &ledValues)
|
|||||||
}
|
}
|
||||||
spi_ptr += SPI_BYTES_PER_LED;
|
spi_ptr += SPI_BYTES_PER_LED;
|
||||||
}
|
}
|
||||||
|
|
||||||
_ledBuffer[spi_ptr++] = 0;
|
_ledBuffer[spi_ptr++] = 0;
|
||||||
_ledBuffer[spi_ptr++] = 0;
|
_ledBuffer[spi_ptr++] = 0;
|
||||||
_ledBuffer[spi_ptr++] = 0;
|
_ledBuffer[spi_ptr++] = 0;
|
||||||
|
|
||||||
return writeBytes(spi_size, _ledBuffer.data());
|
return writeBytes(_ledBuffer.size(), _ledBuffer.data());
|
||||||
}
|
}
|
||||||
|
@ -35,5 +35,7 @@ private:
|
|||||||
///
|
///
|
||||||
virtual int write(const std::vector<ColorRgb> &ledValues);
|
virtual int write(const std::vector<ColorRgb> &ledValues);
|
||||||
|
|
||||||
|
const int SPI_BYTES_PER_COLOUR;
|
||||||
|
|
||||||
uint8_t bitpair_to_byte[4];
|
uint8_t bitpair_to_byte[4];
|
||||||
};
|
};
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
"rate": {
|
"rate": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"title":"Baudrate",
|
"title":"Baudrate",
|
||||||
"default": 2666666,
|
"default": 3000000,
|
||||||
"propertyOrder" : 2
|
"propertyOrder" : 2
|
||||||
},
|
},
|
||||||
"invert": {
|
"invert": {
|
||||||
@ -20,6 +20,13 @@
|
|||||||
"title":"Invert signal",
|
"title":"Invert signal",
|
||||||
"default": false,
|
"default": false,
|
||||||
"propertyOrder" : 3
|
"propertyOrder" : 3
|
||||||
|
},
|
||||||
|
"whiteAlgorithm": {
|
||||||
|
"type": "string",
|
||||||
|
"title":"White LED algorithm",
|
||||||
|
"enum" : ["subtract_minimum","sub_min_warm_adjust","white_off"],
|
||||||
|
"default": "subtract_minimum",
|
||||||
|
"propertyOrder" : 4
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": true
|
"additionalProperties": true
|
@ -11,7 +11,7 @@
|
|||||||
"rate": {
|
"rate": {
|
||||||
"type": "integer",
|
"type": "integer",
|
||||||
"title":"Baudrate",
|
"title":"Baudrate",
|
||||||
"default": 1000000,
|
"default": 3000000,
|
||||||
"propertyOrder" : 2
|
"propertyOrder" : 2
|
||||||
},
|
},
|
||||||
"invert": {
|
"invert": {
|
||||||
|
@ -2,6 +2,39 @@
|
|||||||
"type":"object",
|
"type":"object",
|
||||||
"required":true,
|
"required":true,
|
||||||
"properties":{
|
"properties":{
|
||||||
|
"leds": {
|
||||||
|
"type": "integer",
|
||||||
|
"title":"maximum led count",
|
||||||
|
"default": 256,
|
||||||
|
"propertyOrder" : 1
|
||||||
|
},
|
||||||
|
"gpio": {
|
||||||
|
"type": "integer",
|
||||||
|
"title":"gpio number",
|
||||||
|
"default": 18,
|
||||||
|
"propertyOrder" : 2
|
||||||
|
},
|
||||||
|
"invert": {
|
||||||
|
"type": "boolean",
|
||||||
|
"format": "checkbox",
|
||||||
|
"title":"Invert signal",
|
||||||
|
"default": false,
|
||||||
|
"propertyOrder" : 3
|
||||||
|
},
|
||||||
|
"rgbw": {
|
||||||
|
"type": "boolean",
|
||||||
|
"format": "checkbox",
|
||||||
|
"title":"use rgbw protocol",
|
||||||
|
"default": false,
|
||||||
|
"propertyOrder" : 3
|
||||||
|
},
|
||||||
|
"whiteAlgorithm": {
|
||||||
|
"type": "string",
|
||||||
|
"title":"White LED algorithm",
|
||||||
|
"enum" : ["subtract_minimum","sub_min_warm_adjust","white_off"],
|
||||||
|
"default": "subtract_minimum",
|
||||||
|
"propertyOrder" : 4
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": true
|
"additionalProperties": true
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user