2016-02-09 20:21:49 +01:00
|
|
|
|
2014-12-03 09:35:10 +01:00
|
|
|
// STL includes
|
|
|
|
#include <cstring>
|
|
|
|
#include <cstdio>
|
|
|
|
#include <iostream>
|
2016-02-09 20:21:49 +01:00
|
|
|
#include <algorithm>
|
2014-12-03 09:35:10 +01:00
|
|
|
|
|
|
|
// Linux includes
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
|
|
|
|
// hyperion local includes
|
|
|
|
#include "LedDeviceAPA102.h"
|
|
|
|
|
2016-05-10 20:16:19 +10:00
|
|
|
LedDeviceAPA102::LedDeviceAPA102(const std::string& outputDevice, const unsigned baudrate, const unsigned ledcount) :
|
2014-12-03 09:35:10 +01:00
|
|
|
LedSpiDevice(outputDevice, baudrate, 500000),
|
2014-12-11 13:48:14 +01:00
|
|
|
_ledBuffer(0)
|
2014-12-03 09:35:10 +01:00
|
|
|
{
|
2016-05-10 20:16:19 +10:00
|
|
|
_HW_ledcount = ledcount;
|
2014-12-03 09:35:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int LedDeviceAPA102::write(const std::vector<ColorRgb> &ledValues)
|
|
|
|
{
|
2016-05-10 20:16:19 +10:00
|
|
|
_mLedCount = ledValues.size();
|
|
|
|
const unsigned int max_leds = std::max(_mLedCount, _HW_ledcount);
|
2016-02-09 20:21:49 +01:00
|
|
|
const unsigned int startFrameSize = 4;
|
2016-05-10 20:16:19 +10:00
|
|
|
const unsigned int endFrameSize = std::max<unsigned int>(((max_leds + 15) / 16), 4);
|
|
|
|
const unsigned int APAbufferSize = (max_leds * 4) + startFrameSize + endFrameSize;
|
|
|
|
|
|
|
|
//printf ("_mLedCount %d _HW_ledcount %d max_leds %d APAbufferSize %d\n",
|
|
|
|
// _mLedCount, _HW_ledcount, max_leds, APAbufferSize);
|
|
|
|
|
|
|
|
if(_ledBuffer.size() != APAbufferSize){
|
|
|
|
_ledBuffer.resize(APAbufferSize, 0xFF);
|
2016-02-09 20:21:49 +01:00
|
|
|
_ledBuffer[0] = 0x00;
|
|
|
|
_ledBuffer[1] = 0x00;
|
|
|
|
_ledBuffer[2] = 0x00;
|
|
|
|
_ledBuffer[3] = 0x00;
|
2016-02-07 17:40:24 +01:00
|
|
|
}
|
2016-02-09 20:21:49 +01:00
|
|
|
|
2016-05-10 20:16:19 +10:00
|
|
|
unsigned iLed=0;
|
|
|
|
for (iLed=0; iLed < _mLedCount; ++iLed) {
|
|
|
|
const ColorRgb& rgb = ledValues[iLed];
|
|
|
|
_ledBuffer[4+iLed*4] = 0xFF;
|
|
|
|
_ledBuffer[4+iLed*4+1] = rgb.red;
|
|
|
|
_ledBuffer[4+iLed*4+2] = rgb.green;
|
|
|
|
_ledBuffer[4+iLed*4+3] = rgb.blue;
|
2014-12-11 13:48:14 +01:00
|
|
|
}
|
2014-12-03 09:35:10 +01:00
|
|
|
|
2016-05-10 20:16:19 +10:00
|
|
|
for ( ; iLed < max_leds; ++iLed) {
|
|
|
|
_ledBuffer[4+iLed*4] = 0xFF;
|
|
|
|
_ledBuffer[4+iLed*4+1] = 0x00;
|
|
|
|
_ledBuffer[4+iLed*4+2] = 0x00;
|
|
|
|
_ledBuffer[4+iLed*4+3] = 0x00;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
for (unsigned i=0; i< _ledBuffer.size(); i+=4) {
|
|
|
|
printf ("i %2d led %2d RGB 0x0%02x%02x%02x%02x\n",i, i/4-1,
|
|
|
|
_ledBuffer[i+0],
|
|
|
|
_ledBuffer[i+1],
|
|
|
|
_ledBuffer[i+2],
|
|
|
|
_ledBuffer[i+3]);
|
|
|
|
}
|
|
|
|
*/
|
2014-12-11 13:48:14 +01:00
|
|
|
return writeBytes(_ledBuffer.size(), _ledBuffer.data());
|
2014-12-03 09:35:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
int LedDeviceAPA102::switchOff()
|
|
|
|
{
|
2016-05-10 20:16:19 +10:00
|
|
|
return write(std::vector<ColorRgb>(_mLedCount, ColorRgb{0,0,0}));
|
2016-02-07 17:40:24 +01:00
|
|
|
}
|