2013-11-01 23:48:39 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// Local hyperion incluse
|
|
|
|
#include "LedSpiDevice.h"
|
|
|
|
|
|
|
|
///
|
|
|
|
/// Implementation of the LedDevice interface for writing to LDP6803 led device.
|
|
|
|
///
|
2013-11-02 06:51:41 +01:00
|
|
|
/// 00000000 00000000 00000000 00000000 1XXXXXYY YYYZZZZZ 1XXXXXYY YYYZZZZZ ...
|
|
|
|
/// |---------------------------------| |---------------| |---------------|
|
|
|
|
/// 32 zeros to start the frame Led1 Led2 ...
|
|
|
|
///
|
|
|
|
/// For each led, the first bit is always 1, and then you have 5 bits each for red, green and blue
|
|
|
|
/// (X, Y and Z in the above illustration) making 16 bits per led. Total bits = 32 + (16 x number of
|
|
|
|
/// leds)
|
|
|
|
///
|
|
|
|
class LedDeviceLdp6803 : public LedSpiDevice
|
2013-11-01 23:48:39 +01:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
///
|
|
|
|
/// Constructs the LedDevice for a string containing leds of the type LDP6803
|
|
|
|
///
|
|
|
|
/// @param[in] outputDevice The name of the output device (eg '/etc/SpiDev.0.0')
|
|
|
|
/// @param[in] baudrate The used baudrate for writing to the output device
|
|
|
|
///
|
2013-11-02 06:51:41 +01:00
|
|
|
LedDeviceLdp6803(const std::string& outputDevice, const unsigned baudrate);
|
2013-11-01 23:48:39 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Writes the led color values to the led-device
|
|
|
|
///
|
|
|
|
/// @param ledValues The color-value per led
|
|
|
|
/// @return Zero on succes else negative
|
|
|
|
///
|
|
|
|
virtual int write(const std::vector<RgbColor> &ledValues);
|
|
|
|
|
|
|
|
/// Switch the leds off
|
|
|
|
virtual int switchOff();
|
|
|
|
|
|
|
|
private:
|
2013-11-02 06:56:14 +01:00
|
|
|
/// The buffer containing the packed RGB values
|
2013-11-02 06:51:41 +01:00
|
|
|
std::vector<unsigned short> _ledBuffer;
|
2013-11-01 23:48:39 +01:00
|
|
|
};
|