Open Lighting Architecture
0.9.6
|
Represents a Ja Rule hardware widget.
Public Member Functions | |
JaRuleWidget (ola::io::SelectServerInterface *ss, AsyncronousLibUsbAdaptor *adaptor, libusb_device *device, const ola::rdm::UID &controller_uid) | |
Create a new Ja Rule widget. | |
bool | Init () |
Initialize the widget. | |
void | SendRDMRequest (ola::rdm::RDMRequest *request, ola::rdm::RDMCallback *on_complete) |
Send a RDM command. | |
void | RunFullDiscovery (ola::rdm::RDMDiscoveryCallback *callback) |
Start a full discovery operation. | |
void | RunIncrementalDiscovery (ola::rdm::RDMDiscoveryCallback *callback) |
Start an incremental discovery operation. | |
bool | SendDMX (const DmxBuffer &buffer) |
Send DMX data from this widget. | |
void | ResetDevice () |
Send a reset message to the hardware widget. |
ola::plugin::usbdmx::JaRuleWidget::JaRuleWidget | ( | ola::io::SelectServerInterface * | ss, |
AsyncronousLibUsbAdaptor * | adaptor, | ||
libusb_device * | device, | ||
const ola::rdm::UID & | controller_uid | ||
) |
Create a new Ja Rule widget.
ss | The SelectServer to run the RDM callbacks on. |
adaptor | The LibUsbAdaptor to use. |
device | the libusb_device for the Ja Rule widget. |
controller_uid | The UID of the controller. This is used for DUB & Mute / Unmute messages. |
TODO(simon): Can we instead read the UID from the hardware device itself?
|
virtual |
Initialize the widget.
Implements ola::plugin::usbdmx::Widget.
|
virtual |
Start a full discovery operation.
callback | The callback run when discovery completes. This may run immediately in some implementations. |
Implements ola::rdm::DiscoverableRDMControllerInterface.
|
virtual |
Start an incremental discovery operation.
callback | The callback run when discovery completes. This may run immediately in some implementations. |
Implements ola::rdm::DiscoverableRDMControllerInterface.
|
virtual |
Send DMX data from this widget.
buffer | The DmxBuffer containing the data to send. |
Implements ola::plugin::usbdmx::Widget.
|
virtual |
Send a RDM command.
request | the RDMRequest, ownership is transferred. |
on_complete | The callback to run when the request completes. |
Implementors much ensure that the callback is always run at some point. In other words, there must be no way that a request can be dropped in such a way that the callback is never run. Doing so will either block all subsequent requests, or leak memory depending on the implementation.
Also the implementor of this class may want to re-write the transaction #, and possibly the UID (changing src UIDs isn't addressed by the RDM spec).
The RDMRequest may be a DISCOVERY_COMMAND, if the implementation does not support DISCOVERY_COMMANDs then the callback should be run with ola::rdm::RDM_PLUGIN_DISCOVERY_NOT_SUPPORTED.
Implements ola::rdm::RDMControllerInterface.