2013-11-13 20:15:53 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// stl includes
|
|
|
|
#include <cstdint>
|
|
|
|
|
|
|
|
// libusb include
|
|
|
|
#include <libusb.h>
|
|
|
|
|
|
|
|
// Hyperion includes
|
2013-12-17 18:50:15 +00:00
|
|
|
#include <leddevice/LedDevice.h>
|
2013-11-13 20:15:53 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// LedDevice implementation for a lightpack device (http://code.google.com/p/light-pack/)
|
|
|
|
///
|
|
|
|
class LedDeviceLightpack : public LedDevice
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
///
|
|
|
|
/// Constructs the LedDeviceLightpack
|
|
|
|
///
|
2016-07-13 11:18:12 +02:00
|
|
|
/// @param serialNumber serial output device
|
|
|
|
///
|
2017-03-04 22:17:42 +01:00
|
|
|
LedDeviceLightpack(const QString & serialNumber = "");
|
2016-08-23 20:07:12 +02:00
|
|
|
///
|
|
|
|
/// Constructs specific LedDevice
|
|
|
|
///
|
|
|
|
/// @param deviceConfig json device config
|
|
|
|
///
|
2020-02-10 15:21:58 +01:00
|
|
|
explicit LedDeviceLightpack(const QJsonObject &deviceConfig);
|
2016-08-23 20:07:12 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Sets configuration
|
|
|
|
///
|
|
|
|
/// @param deviceConfig the json device config
|
|
|
|
/// @return true if success
|
2020-02-10 15:21:58 +01:00
|
|
|
bool init(const QJsonObject &deviceConfig) override;
|
2016-08-23 20:07:12 +02:00
|
|
|
|
|
|
|
/// constructs leddevice
|
2016-10-13 21:59:58 +02:00
|
|
|
static LedDevice* construct(const QJsonObject &deviceConfig);
|
2013-11-13 20:15:53 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Destructor of the LedDevice; closes the output device if it is open
|
|
|
|
///
|
2020-02-10 15:21:58 +01:00
|
|
|
virtual ~LedDeviceLightpack() override;
|
2013-11-13 20:15:53 +01:00
|
|
|
|
|
|
|
///
|
2013-11-17 15:51:42 +01:00
|
|
|
/// Opens and configures the output device
|
2013-11-13 20:15:53 +01:00
|
|
|
///
|
|
|
|
/// @return Zero on succes else negative
|
|
|
|
///
|
2020-02-10 15:21:58 +01:00
|
|
|
int open() override;
|
2013-11-17 15:51:42 +01:00
|
|
|
|
|
|
|
///
|
|
|
|
/// Writes the RGB-Color values to the leds.
|
|
|
|
///
|
|
|
|
/// @param[in] ledValues Array of RGB values
|
|
|
|
/// @param[in] size The number of RGB values
|
|
|
|
///
|
|
|
|
/// @return Zero on success else negative
|
|
|
|
///
|
|
|
|
int write(const ColorRgb * ledValues, int size);
|
|
|
|
|
2013-11-13 23:16:09 +01:00
|
|
|
///
|
|
|
|
/// Switch the leds off
|
|
|
|
///
|
|
|
|
/// @return Zero on success else negative
|
|
|
|
///
|
2020-02-10 15:21:58 +01:00
|
|
|
virtual int switchOff() override;
|
2013-11-13 20:15:53 +01:00
|
|
|
|
2013-11-17 15:51:42 +01:00
|
|
|
/// Get the serial of the Lightpack
|
2017-03-04 22:17:42 +01:00
|
|
|
const QString & getSerialNumber() const;
|
2013-11-17 15:51:42 +01:00
|
|
|
|
2020-02-10 15:21:58 +01:00
|
|
|
public slots:
|
|
|
|
///
|
|
|
|
/// Closes the output device.
|
|
|
|
/// Includes switching-off the device and stopping refreshes
|
|
|
|
///
|
|
|
|
virtual void close() override;
|
|
|
|
|
|
|
|
protected:
|
2013-11-13 20:15:53 +01:00
|
|
|
|
2013-11-17 15:51:42 +01:00
|
|
|
private:
|
2016-09-23 08:49:22 +02:00
|
|
|
///
|
|
|
|
/// Writes the RGB-Color values to the leds.
|
|
|
|
///
|
|
|
|
/// @param[in] ledValues The RGB-color per led
|
|
|
|
///
|
|
|
|
/// @return Zero on success else negative
|
|
|
|
///
|
|
|
|
virtual int write(const std::vector<ColorRgb>& ledValues);
|
|
|
|
|
2013-11-20 20:54:04 +01:00
|
|
|
///
|
|
|
|
/// Test if the device is a (or the) lightpack we are looking for
|
|
|
|
///
|
|
|
|
/// @return Zero on succes else negative
|
|
|
|
///
|
2017-03-04 22:17:42 +01:00
|
|
|
int testAndOpen(libusb_device * device, const QString & requestedSerialNumber);
|
2013-11-20 20:54:04 +01:00
|
|
|
|
2013-11-13 20:15:53 +01:00
|
|
|
/// write bytes to the device
|
|
|
|
int writeBytes(uint8_t *data, int size);
|
|
|
|
|
|
|
|
/// Disable the internal smoothing on the Lightpack device
|
|
|
|
int disableSmoothing();
|
|
|
|
|
2013-11-17 15:51:42 +01:00
|
|
|
struct Version
|
|
|
|
{
|
|
|
|
int majorVersion;
|
|
|
|
int minorVersion;
|
|
|
|
};
|
|
|
|
|
2013-11-13 20:15:53 +01:00
|
|
|
static libusb_device_handle * openDevice(libusb_device * device);
|
2017-03-04 22:17:42 +01:00
|
|
|
static QString getString(libusb_device * device, int stringDescriptorIndex);
|
2013-11-13 20:15:53 +01:00
|
|
|
|
|
|
|
/// libusb context
|
|
|
|
libusb_context * _libusbContext;
|
|
|
|
|
|
|
|
/// libusb device handle
|
|
|
|
libusb_device_handle * _deviceHandle;
|
|
|
|
|
|
|
|
/// harware bus number
|
|
|
|
int _busNumber;
|
|
|
|
|
|
|
|
/// hardware address number
|
|
|
|
int _addressNumber;
|
|
|
|
|
|
|
|
/// device serial number
|
2017-03-04 22:17:42 +01:00
|
|
|
QString _serialNumber;
|
2013-11-13 20:15:53 +01:00
|
|
|
|
|
|
|
/// firmware version of the device
|
|
|
|
Version _firmwareVersion;
|
|
|
|
|
|
|
|
/// the number of bits per channel
|
|
|
|
int _bitsPerChannel;
|
2016-09-23 08:49:22 +02:00
|
|
|
|
|
|
|
/// count of real hardware leds
|
|
|
|
int _hwLedCount;
|
2013-11-13 20:15:53 +01:00
|
|
|
};
|