From 705f79654e57238a65a25917828e7cecc282c1b7 Mon Sep 17 00:00:00 2001 From: InfraredAces <44279698+InfraredAces@users.noreply.github.com> Date: Thu, 7 Mar 2024 16:55:47 -0700 Subject: [PATCH] Add Fade animation info and RGB corrections (#35) --- docs/rgb-leds.mdx | 110 ++++++++++++++++++++++++++++------- src/components/LEDColors.tsx | 78 +++++++++++++++++++++++++ 2 files changed, 167 insertions(+), 21 deletions(-) create mode 100644 src/components/LEDColors.tsx diff --git a/docs/rgb-leds.mdx b/docs/rgb-leds.mdx index b906d6a..20bdf91 100644 --- a/docs/rgb-leds.mdx +++ b/docs/rgb-leds.mdx @@ -10,6 +10,7 @@ description: "How to use addressable RGB LEDs to your controller. Hotkeys and an import InputLabelSelector, { Hotkey, } from "@site/src/components/LabelSelector.tsx"; +import { ColorBlock } from "@site/src/components/LEDColors"; # RGB LEDs @@ -21,38 +22,105 @@ Select the button labels to be displayed in the usage guide: GP2040-CE requires that addressable RGB LEDs be used for nearly all LED functions. -The exception to this are [Player LEDs](./add-ons/player-number.mdx), which can use pulse width modulation (PWM) to vary the brightness of the LEDs. +The exception to this are [Player LEDs](./add-ons/player-number.mdx), which can use pulse width modulation (PWM) to vary +the brightness of the LEDs. ## RGB LED Hotkeys -| Hotkey | Description | -| -------------------------------------- | ---------------------- | -| | Next Animation | -| | Previous Animation | -| | Brightness Up | -| | Brightness Down | -| | LED Parameter Up | -| | LED Parameter Down | -| | Pressed Parameter Up | -| | Pressed Parameter Down | +| Hotkey | Description | +| -------------------------------------- | -------------------------- | +| | Next Animation | +| | Previous Animation | +| | Brightness Up | +| | Brightness Down | +| | LED Parameter Up | +| | LED Parameter Down | +| | Pressed Parameter Up | +| | Pressed Parameter Down | +| | Decrease LED Fade Duration | +| | Increase LED Fade Duration | :::note -The `LED Parameter` hotkeys may affect color, speed or theme depending on the current RGB LED animation. The `Pressed Parameter` options will change the colors/effects for the on-press animations. +The `LED Parameter` hotkeys may affect color, speed or theme depending on the current RGB LED animation. + +The `Pressed Parameter` options will change the colors/effects for the on-press animations. + +::: + +### RGB LED Animations + +Using these hotkeys will cycle through the animation modes. The following animations are available: + +| Name | Description | +| ------------- | ------------------------------------------------------------------------------------------------------------------------------ | +| Rainbow Chase | A fading, rainbow cycling lines travels across the LED chain | +| Static Theme | Set the LEDs to a pre-defined static theme | +| Custom Theme | Set the LEDs to a custom theme set up in [WebConfig - Custom LED Theme](./web-configurator/menu-pages/06-custom-led-theme.mdx) | +| Static Color | Sets all LEDs to the same color | +| Rainbow Cycle | All LEDs cycle through the color wheel displaying the same color | + +### RGB LED Brightness + +These hotkeys will increase or decrease the brightness of the controller LEDs based on the `Brightness Steps` and +`Max Brightness` settings in [LED Configuration](/docs/web-configurator/menu-pages/05-led-configuration.mdx#rgb-led-configuration). + +### RGB LED Parameter + +Depending on the specific animation, changing the LED parameter will result in different behavior. + +| Name | LED Parameter | +| ------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| Rainbow Chase | Adjust animation speed | +| Static Theme | Cycle through themes, see [RGB LED Static Themes](#rgb-led-static-themes) for details. | +| Static Color | Cycle through colors: Black, White, Red, Orange, Yellow, Lime Green, Green, Seafoam, Aqua, Sky Blue, Blue, Purple, Pink, Magenta | +| Rainbow Cycle | Adjust animation speed | + +:::note Custom LED Theme + +When using a custom LED theme, these hotkeys will not affect the settings in any other animation mode. + +::: + +### RGB LED Pressed Parameter + + + +Changes the color the LED changes to when the button is pressed + +Cycle through colors: Black, White, Red, +Orange, Yellow, Lime Green, +Green, Seafoam, Aqua, +Sky Blue, Blue, Purple, +Pink, Magenta + +:::note Custom LED Theme + +When using a custom LED theme, these hotkeys will not affect the settings in any other animation mode. ::: -## RGB LED Animations +### RGB LED Fade Duration -The following animations are available: +Using these hotkeys will affect the duration for the fade animation on the LED after a button press. + +:::note -| Name | Description | LED Parameter | -| ------------- | ---------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------ | -| Off | Turn off per-button RGB LEDs | - | -| Static Color | Sets all LEDs to the same color | Cycle through colors: _Red_, _Orange_, _Yellow_, _Lime Green_, _Green_, _Seafoam_, _Aqua_, _Sky Blue_, _Blue_, _Purple_, _Pink_, _Magenta_ | -| Rainbow Cycle | All LEDs cycle through the color wheel displaying the same color | Adjust animation speed | -| Rainbow Chase | A fading, rainbow cycling lines travels across the LED chain | Adjust animation speed | -| Static Theme | Set the LEDs to a pre-defined static theme | Cycle through themes, see [RGB LED Static Themes](#rgb-led-static-themes) for details. | +This duration is shared across all themes and buttons and cannot be set individually per theme nor per button. + +::: + +| Parameter | Description | +| ---------------- | ----------- | +| Default Duration | 500ms | +| Duration Range | 0ms - 500ms | +| Hotkey Increment | 500ms | + +:::tip + +If you want to disable the Fade animation, set the duration to 0ms. + +::: ## RGB LED Static Themes diff --git a/src/components/LEDColors.tsx b/src/components/LEDColors.tsx new file mode 100644 index 0000000..ea940d6 --- /dev/null +++ b/src/components/LEDColors.tsx @@ -0,0 +1,78 @@ +import React from "react"; + +// Convert a number to hex +const intToHex = (d) => { + return ("0" + Number(d).toString(16)).slice(-2).toLowerCase(); +}; + +// Takes an array of 8-bit RGB values and returns the hex value +const rgbArrayToHex = (values) => { + let [r, g, b] = values; + + if (!(r >= 0 && r <= 255)) r = 0; + if (!(g >= 0 && g <= 255)) g = 0; + if (!(b >= 0 && b <= 255)) r = 0; + + return `#${intToHex(r)}${intToHex(g)}${intToHex(b)}`; +}; + +const Black = rgbArrayToHex([0, 0, 0]); +const White = rgbArrayToHex([255, 255, 255]); +const Red = rgbArrayToHex([255, 0, 0]); +const Orange = rgbArrayToHex([255, 128, 0]); +const Yellow = rgbArrayToHex([255, 255, 0]); +const LimeGreen = rgbArrayToHex([128, 255, 0]); +const Green = rgbArrayToHex([0, 255, 0]); +const Seafoam = rgbArrayToHex([0, 255, 128]); +const Aqua = rgbArrayToHex([0, 255, 255]); +const SkyBlue = rgbArrayToHex([0, 128, 255]); +const Blue = rgbArrayToHex([0, 0, 255]); +const Purple = rgbArrayToHex([128, 0, 255]); +const Pink = rgbArrayToHex([255, 0, 255]); +const Magenta = rgbArrayToHex([255, 0, 128]); + +const LEDColors = [ + { name: "Black", value: Black }, + { name: "White", value: White }, + { name: "Red", value: Red }, + { name: "Orange", value: Orange }, + { name: "Yellow", value: Yellow }, + { name: "LimeGreen", value: LimeGreen }, + { name: "Green", value: Green }, + { name: "Seafoam", value: Seafoam }, + { name: "Aqua", value: Aqua }, + { name: "SkyBlue", value: SkyBlue }, + { name: "Blue", value: Blue }, + { name: "Purple", value: Purple }, + { name: "Pink", value: Pink }, + { name: "Magenta", value: Magenta }, +]; + +export function ColorBlock({ color }) { + let cleanColor = color.trim().split(" ").join(""); + try { + let colorValue = LEDColors.find( + (ledColor) => ledColor.name.toLowerCase() === cleanColor.toLowerCase() + ).value; + + return ( + + ■ + + ); + } catch (error) { + return ( + + ■ + + ); + } +}