345 lines
13 KiB
C++
345 lines
13 KiB
C++
/*---------------------------------------------------------*\
|
|
| RGBController_JGINYUEInternalUSB.cpp |
|
|
| |
|
|
| RGBController for JGINYUE USB motherboard |
|
|
| |
|
|
| Tong R (tcr020) 09 Aug 2023 |
|
|
| Liu ShiMeng(Moon dream stars) 09 Aug 2023 |
|
|
| Dongguan Yonghang Electronic Technology Co., Ltd |
|
|
| |
|
|
| This file is part of the OpenRGB project |
|
|
| SPDX-License-Identifier: GPL-2.0-only |
|
|
\*---------------------------------------------------------*/
|
|
|
|
#include <string.h>
|
|
#include "RGBController_JGINYUEInternalUSB.h"
|
|
|
|
#define JGINYUE_MAX_ZONES 2
|
|
#define JGINYUE_ADDRESSABLE_MAX_LEDS 100
|
|
|
|
/**------------------------------------------------------------------*\
|
|
@name JGINYUEInternalUSB
|
|
@category MotherBoard
|
|
@type USB
|
|
@save :x:
|
|
@direct :white_check_mark:
|
|
@effects :white_check_mark:
|
|
@detectors DetectJGINYUEInternalUSB
|
|
@comment Insert multiline JGINYUEInternalUSB comment here
|
|
\*--------------------------------------------------------------------*/
|
|
|
|
RGBController_JGINYUEInternalUSB::RGBController_JGINYUEInternalUSB(JGINYUEInternalUSBController* controller_ptr)
|
|
{
|
|
controller = controller_ptr;
|
|
|
|
name = controller->GetDeviceName();
|
|
description = "JGINYUE USB ARGB Device";
|
|
vendor = "JGINYUE";
|
|
type = DEVICE_TYPE_MOTHERBOARD;
|
|
location = controller->GetDeviceLocation();
|
|
version = controller->GetDeviceFWVersion();
|
|
|
|
mode Off;
|
|
Off.name = "Off";
|
|
Off.value = JGINYUE_USB_MODE_OFF;
|
|
Off.flags = 0;
|
|
Off.color_mode = MODE_COLORS_NONE;
|
|
modes.push_back(Off);
|
|
|
|
mode Static;
|
|
Static.name = "Static";
|
|
Static.value = JGINYUE_USB_MODE_STATIC;
|
|
Static.flags = MODE_FLAG_HAS_MODE_SPECIFIC_COLOR;
|
|
Static.color_mode = MODE_COLORS_MODE_SPECIFIC;
|
|
Static.colors_max = 1;
|
|
Static.colors_min = 1;
|
|
Static.colors.resize(1);
|
|
modes.push_back(Static);
|
|
|
|
mode Breathing;
|
|
Breathing.name = "Breathing";
|
|
Breathing.value = JGINYUE_USB_MODE_BREATHING;
|
|
Breathing.flags = MODE_FLAG_HAS_MODE_SPECIFIC_COLOR | MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS;
|
|
Breathing.color_mode = MODE_COLORS_MODE_SPECIFIC;
|
|
Breathing.colors_max = 1;
|
|
Breathing.colors_min = 1;
|
|
Breathing.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
Breathing.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
Breathing.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
Breathing.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Breathing.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Breathing.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
Breathing.colors.resize(1);
|
|
modes.push_back(Breathing);
|
|
|
|
mode Strobe;
|
|
Strobe.name = "Strobe";
|
|
Strobe.value = JGINYUE_USB_MODE_STROBE;
|
|
Strobe.flags = MODE_FLAG_HAS_MODE_SPECIFIC_COLOR | MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS;
|
|
Strobe.color_mode = MODE_COLORS_MODE_SPECIFIC;
|
|
Strobe.colors_max = 1;
|
|
Strobe.colors_min = 1;
|
|
Strobe.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
Strobe.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
Strobe.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
Strobe.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Strobe.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Strobe.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
Strobe.colors.resize(1);
|
|
modes.push_back(Strobe);
|
|
|
|
mode Cycling;
|
|
Cycling.name = "Cycling";
|
|
Cycling.value = JGINYUE_USB_MODE_CYCLING;
|
|
Cycling.flags = MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS;
|
|
Cycling.color_mode = MODE_COLORS_NONE;
|
|
Cycling.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
Cycling.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
Cycling.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
Cycling.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Cycling.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Cycling.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
modes.push_back(Cycling);
|
|
|
|
mode Random;
|
|
Random.name = "Random";
|
|
Random.value = JGINYUE_USB_MODE_RANDOM;
|
|
Random.flags = MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS;
|
|
Random.color_mode = MODE_COLORS_NONE;
|
|
Random.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
Random.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
Random.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
Random.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Random.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Random.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
modes.push_back(Random);
|
|
|
|
mode Wave;
|
|
Wave.name = "Wave";
|
|
Wave.value = JGINYUE_USB_MODE_WAVE;
|
|
Wave.flags = MODE_FLAG_HAS_SPEED;
|
|
Wave.color_mode = MODE_COLORS_NONE;
|
|
Wave.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Wave.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Wave.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
modes.push_back(Wave);
|
|
|
|
//mode Spring;
|
|
//Spring.name = "Spring";
|
|
//Spring.value = JGINYUE_USB_MODE_SPRING;
|
|
//Spring.flags = MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS | MODE_FLAG_HAS_DIRECTION_LR;
|
|
//Spring.color_mode = MODE_COLORS_NONE;
|
|
//Spring.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
//Spring.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
//Spring.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
//Spring.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
//Spring.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
//Spring.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
//Spring.direction = 0x00;
|
|
//modes.push_back(Spring);
|
|
|
|
mode Water;
|
|
Water.name = "Water";
|
|
Water.value = JGINYUE_USB_MODE_WATER;
|
|
Water.flags = MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS | MODE_FLAG_HAS_DIRECTION_LR;
|
|
Water.color_mode = MODE_COLORS_NONE;
|
|
Water.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
Water.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
Water.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
Water.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
Water.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
Water.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
Water.direction = MODE_DIRECTION_RIGHT;
|
|
modes.push_back(Water);
|
|
|
|
//mode Rainbow;
|
|
//Rainbow.name = "Rainbow";
|
|
//Rainbow.value = JGINYUE_USB_MODE_RAINBOW;
|
|
//Rainbow.flags = MODE_FLAG_HAS_SPEED | MODE_FLAG_HAS_BRIGHTNESS | MODE_FLAG_HAS_DIRECTION_LR;
|
|
//Rainbow.color_mode = MODE_COLORS_NONE;
|
|
//Rainbow.brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
//Rainbow.brightness_max = JGINYUE_USB_BRIGHTNESS_MAX;
|
|
//Rainbow.brightness_min = JGINYUE_USB_BRIGHTNESS_MIN;
|
|
//Rainbow.speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
//Rainbow.speed_max = JGINYUE_USB_SPEED_MAX;
|
|
//Rainbow.speed_min = JGINYUE_USB_SPEED_MIN;
|
|
//Rainbow.direction = MODE_DIRECTION_RIGHT;
|
|
//modes.push_back(Rainbow);
|
|
|
|
mode Direct;
|
|
Direct.name = "Direct";
|
|
Direct.value = JGINYUE_USB_MODE_DIRECT;
|
|
Direct.flags = MODE_FLAG_HAS_PER_LED_COLOR;
|
|
Direct.color_mode = MODE_COLORS_PER_LED;
|
|
modes.push_back(Direct);
|
|
|
|
SetupZones();
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::SetupZones()
|
|
{
|
|
/*-------------------------------------------------*\
|
|
| Only set LED count on the first run |
|
|
\*-------------------------------------------------*/
|
|
bool first_run = false;
|
|
|
|
if(zones.size() == 0)
|
|
{
|
|
first_run = true;
|
|
}
|
|
|
|
/*-------------------------------------------------*\
|
|
| Clear any existing color/LED configuration |
|
|
\*-------------------------------------------------*/
|
|
leds.clear();
|
|
colors.clear();
|
|
zones.resize(JGINYUE_MAX_ZONES);
|
|
|
|
/*-------------------------------------------------*\
|
|
| Set zones and leds |
|
|
\*-------------------------------------------------*/
|
|
zones[0].name = "ARGB Header 1";
|
|
zones[0].type = ZONE_TYPE_LINEAR;
|
|
zones[0].leds_min = 0;
|
|
zones[0].leds_max = 100;
|
|
zones[0].matrix_map = NULL;
|
|
|
|
zones[1].name = "ARGB Header 2";
|
|
zones[1].type = ZONE_TYPE_LINEAR;
|
|
zones[1].leds_min = 0;
|
|
zones[1].leds_max = 100;
|
|
zones[1].matrix_map = NULL;
|
|
|
|
if(first_run)
|
|
{
|
|
zones[0].leds_count = 0;
|
|
zones[1].leds_count = 0;
|
|
}
|
|
|
|
for(unsigned int zone_idx = 0; zone_idx < JGINYUE_MAX_ZONES; zone_idx++)
|
|
{
|
|
for(unsigned int led_idx = 0; led_idx < zones[zone_idx].leds_count; led_idx++)
|
|
{
|
|
led new_led;
|
|
new_led.name = "ARGB Header " + std::to_string(zone_idx + 1) + " LED " + std::to_string(led_idx + 1);
|
|
new_led.value = 0;
|
|
leds.push_back(new_led);
|
|
}
|
|
}
|
|
|
|
SetupColors();
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::ResizeZone(int zone, int new_size)
|
|
{
|
|
unsigned char area;
|
|
|
|
switch(zone)
|
|
{
|
|
case 0:
|
|
area = 0x01;
|
|
break;
|
|
case 1:
|
|
area = 0x02;
|
|
break;
|
|
default:
|
|
area = 0x01;
|
|
break;
|
|
}
|
|
|
|
zones[zone].leds_count = new_size;
|
|
|
|
SetupZones();
|
|
|
|
controller->Area_resize(new_size, area);
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::DeviceUpdateLEDs()
|
|
{
|
|
for(int i = 0; i < JGINYUE_MAX_ZONES; i++)
|
|
{
|
|
UpdateZoneLEDs(i);
|
|
}
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::UpdateZoneLEDs(int zone)
|
|
{
|
|
unsigned char area;
|
|
|
|
switch(zone)
|
|
{
|
|
case 0:
|
|
area = 0x01;
|
|
break;
|
|
case 1:
|
|
area = 0x02;
|
|
break;
|
|
default:
|
|
area = 0x01;
|
|
break;
|
|
}
|
|
|
|
controller->DirectLEDControl(zones[zone].colors,area);
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::UpdateSingleLED(int led)
|
|
{
|
|
int zone;
|
|
zone = leds[led].value;
|
|
UpdateZoneLEDs(zone);
|
|
}
|
|
|
|
void RGBController_JGINYUEInternalUSB::DeviceUpdateMode()
|
|
{
|
|
unsigned char area;
|
|
|
|
if(modes[active_mode].value == JGINYUE_USB_MODE_DIRECT)
|
|
{
|
|
DeviceUpdateLEDs();
|
|
}
|
|
else
|
|
{
|
|
unsigned char aim_direction = JGINYUE_DIRECTION_RIGHT;
|
|
unsigned char aim_speed = JGINYUE_USB_SPEED_DEFAULT;
|
|
unsigned char aim_brightness = JGINYUE_USB_BRIGHTNESS_DEFAULT;
|
|
RGBColor aim_rgb = 0x00FFFFFF;
|
|
|
|
if(modes[active_mode].flags & MODE_FLAG_HAS_DIRECTION_LR)
|
|
{
|
|
aim_direction = modes[active_mode].direction;
|
|
}
|
|
|
|
if(modes[active_mode].flags & MODE_FLAG_HAS_SPEED)
|
|
{
|
|
aim_speed = modes[active_mode].speed;
|
|
}
|
|
|
|
if(modes[active_mode].flags & MODE_FLAG_HAS_BRIGHTNESS)
|
|
{
|
|
aim_brightness = modes[active_mode].brightness;
|
|
}
|
|
|
|
if(modes[active_mode].flags & MODE_FLAG_HAS_MODE_SPECIFIC_COLOR)
|
|
{
|
|
aim_rgb = modes[active_mode].colors[0];
|
|
}
|
|
|
|
for(int zone_index = 0; zone_index < JGINYUE_MAX_ZONES; zone_index++)
|
|
{
|
|
switch(zone_index)
|
|
{
|
|
case 0:
|
|
area = 0x01;
|
|
break;
|
|
case 1:
|
|
area = 0x02;
|
|
break;
|
|
default:
|
|
area = 0x01;
|
|
break;
|
|
}
|
|
|
|
controller->WriteZoneMode(area, modes[active_mode].value, aim_rgb, aim_speed, aim_brightness, aim_direction);
|
|
}
|
|
}
|
|
}
|