Device support in OpenRGB can be broken down into three major components.
- Controller
- Detector
- RGBController
A device's Controller class is a free-form class that provides whatever functionality is necessary to communicate with a device. This class should implement functions to send control packets to a device and receive information packets from a device. It should provide the capability to set device colors and modes. The Controller header file should provide defined constants for mode, speed, and other control values specific to the device's protocol. If possible, this class should provide the capability to retrieve firmware version and serial number information from the device. This class can also provide additional device protocol functionality even if it goes unused in OpenRGB currently. For instance, you may provide functions for controlling mouse DPI, polling rate, fan speed, or any other device-specific capability you want. If OpenRGB ever implements these extra functions in the future, having them implemented already in the Controller will make that easier.
The Controller class files are kept in the Controllers/ folder.
A device's Detector function scans the attached devices to see if a particular device (Controller/RGBController) exists. At the moment, two types of detectors exist - I2C and non-I2C. Both detector types are passed (by reference) a vector of RGBController pointers in which to add newly detected controllers. Detectors for I2C devices are also passed a vector of I2C bus pointers to scan. Non-I2C detectors rely on other methods of detection, usually hidapi to scan for USB devices. The REGISTER_DETECTOR macros are used to register a detector function with the OpenRGB Resource Manager which is responsible for calling detector functions at detection time.
REGISTER_DETECTOR("Detector Name", DetectDevicesFunction);
REGISTER_I2C_DETECTOR("I2C Detector Name", DetectI2CDevicesFunction);
The Detector files are kept in the Controllers/ folder.
OpenRGB uses an internal API called RGBController to standardize the interface to RGB devices from multiple vendors and categories. This API uses vectors to describe each device. This API is implemented as an RGBController class that is inherited by each implementation, for example the RGBController_CorsairPeripheral is defined like so:
#include "RGBController.h"
class RGBController_CorsairPeripheral : public RGBController
{
The RGBController files for a controller implementation are kept in the Controllers/ folder alongside the Controller and Detector files.
The RGBController class specification contains the following:
- Device Name
- Device Description
- Device Version
- Device Serial
- Device Location
- Vector of LEDs
- Vector of Zones
- Vector of Modes
- Vector of Colors (32-bit 0x00BBGGRR format)
- Device Type (enum)
- Active mode index
Device Type Value | Description |
---|---|
0 | Motherboard |
1 | DRAM |
2 | GPU |
3 | Cooler |
4 | LED Strip |
5 | Keyboard |
6 | Mouse |
7 | Mousemat |
8 | Headset |
9 | Headset Stand |
The LED structure contains information about an LED.
- LED Name
- LED Value
The Value has no defined functionality in the RGBController API and is provided for implementation-specific use. You can use this field to associate implementation-specific data with an LED.
The Zone structure contains information about a zone. A zone is a logical grouping of LEDs defined by the RGBController implementation. LEDs in a zone must be contiguous in the RGBController's LEDs/Colors vectors.
- Zone Name
- Zone Type
- LED pointer
- Color pointer
- Start Index
- LED Count
- Minimum number of LEDs
- Maximum number of LEDs
- Matrix map pointer
The LED pointer and Color pointer point to the first LED/Color in the RGBController's LEDs/Colors vector associated with this zone. The Start Index is the index to the same LED/Color in the vectors.
The LED count is the number of LEDs in the zone. For zones with a fixed number of LEDs, the count, min, and max values should all be equal. For zones with a user-adjustable number of LEDs, the count should be between the min and max values, inclusively. User-adjustable zones are most commonly used to represent addressable RGB (ARGB) controllers as the number of LEDs depends on what strips/devices are attached to the ARGB headers. The ResizeZone function in the RGBController API is used to resize the number of LEDs in the zone.
The zone type enum defines the zone type. This describes the physical layout of the zone and can be used by software to generate appropriate effects for the zone.
Zone Type Value | Description |
---|---|
0 | Single |
1 | Linear (1D) |
2 | Matrix (2D) |
Each zone has a matrix map pointer which allows an optional matrix map to be associated with the zone. The matrix map is used to provide positioning information about LEDs in a 2D grid. If a matrix map is not provided for a zone, the zone's matrix map pointer must be set to NULL.
A matrix map has the following:
- Height
- Width
- Map data pointer
The height and width determine the size of the map data. The map data pointer should point to a data block of (Height * Width) unsigned 32-bit integers. This data can be accessed as if it were a Map[Y][X] 2D array. The values of the map are LED index values in the zone (so offset by Start Index from the RGBController's LEDs vector). If a spot in the matrix is unused and does not map to an LED, it should be set to 0xFFFFFFFF.
Modes represent internal effects and have a name field that describes the effect. The mode's index in the vector is its ID. The Active Mode variable in the RGBController class specifies which mode is currently selected. A mode contains the following:
- Mode Name
- Mode Value
- Mode Flags
- Minimum Speed
- Maximum Speed
- Minimum number of colors
- Maximum number of colors
- Speed Value
- Direction
- Color Mode
- Colors Vector
The mode value is field is provided to hold an implementation-defined mode value. This is usually the mode's value in the hardware protocol.
The mode flags field is a bitfield that contains information about what features a mode has.
Mode Flags Bit | Description |
---|---|
0 | Mode has speed parameter |
1 | Mode has left/right direction parameter |
2 | Mode has up/down direction parameter |
3 | Mode has horizontal/vertical direction parameter |
4 | Mode has brightness parameter |
5 | Mode has per-LED color settings |
6 | Mode has mode specific color settings |
7 | Mode has random color option |
The mode minimum and maximum speed fields should be set to the implementation-specific minimum and maximum speed values for the given mode if the mode supports speed control. The mode speed value field will be set between the minimum and maximum value, inclusively. The minimum speed may be a greater numerical value than the maximum speed if your device's speed adjustment is inverted (usually because the device takes a delay period rather than a speed value).
The mode minimum and maximum number of colors fields should be used if the mode supports mode-specific color settings. These determine the size range of the mode's Colors vector. If the mode has a fixed number of colors, the minimum and maximum should be equal. Mode-specific colors are used when a mode has one or more configurable colors but these colors do not apply directly to individual LEDs. Example would be a breathing mode that cycles between one or more colors each breath pulse. A mode may have multiple color options available, for instance a breathing mode that can either use one or more defined colors or just cycle through random colors. The available color modes for a given mode are set with the flags. The selected color mode is set using the color mode field, which can be one of the following values.
Color Mode Value | Description |
---|---|
0 | None - this mode does not have configurable colors |
1 | Per-LED - this mode uses the RGBController's colors vector to set each LED to its specified color |
2 | Mode Specific - this mode has one or more configurable colors, but not individual LED control |
3 | Random - this mode can be switched to a random or cycling color palette |
Returns the currently enabled mode of the device. The returned int should line up with the Modes vector.
Sets the mode of the device. The mode should be the index in the Modes vector of the mode you wish to set.
When called, the device should be put into its software-controlled mode. This differs between devices, but generally devices have a direct control or static effect mode. Ideally, this mode should not save to the device's internal Flash. This function sets up a device for software effect control.
Update all LEDs based on the device's colors
vector.
Update all LEDs in the given zone based on the device's colors
vector.
Update a single LED based on the device's colors
vector.