diff --git a/plugins/Kaleidoscope-Colormap-Overlay/README.md b/plugins/Kaleidoscope-Colormap-Overlay/README.md new file mode 100644 index 0000000000..8585344891 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/README.md @@ -0,0 +1,77 @@ +# Colormap-Overlay + +The `ColormapOverlay` extension provides an easier way to apply color to +specific combinations of keys and layers, regardless of the active LED mode. +Colors are picked from a 16-color palette, provided by the +[LED-Palette-Theme][plugin:l-p-t] plugin. The overlays are stored in `EEPROM`, +and can be easily changed via the [FocusSerial][plugin:focusserial] plugin, +which also provides palette editing capabilities. + + [plugin:focusserial]: Kaleidoscope-FocusSerial.md + [plugin:l-p-t]: Kaleidoscope-LED-Palette-Theme.md + +It is also possible to set up a default palette and overrides, using the +`PALETTE` macro provided by the LED-Palette-Theme package and the +`COLORMAP_OVERLAYS` provided by this package. See below for its documentation. + + +## Using the extension + +To use the extension, include the headers and, optionally, register the `Focus` +hooks. Use the macros mentioned above to set up a default for both the palette +and colormap overlays. Note that layers and key addresses are all zero-indexed, +and key addresses rows are top to bottom and columns are left to right. For the +key coordinates refer to the relevant header file: + +- [Model 01][Model01.h] +- [Model 100][Model100.h] +- [Atreus][Atreus2.h] +- [Imago][Imago.h] + + [Model01.h]: https://github.com/keyboardio/Kaleidoscope/blob/master/plugins/Kaleidoscope-Hardware-Keyboardio-Model01/src/kaleidoscope/device/keyboardio/Model01.h#L153 + [Model100.h]: https://github.com/keyboardio/Kaleidoscope/blob/master/plugins/Kaleidoscope-Hardware-Keyboardio-Model100/src/kaleidoscope/device/keyboardio/Model100.h#L175 + [Atreus2.h]: https://github.com/keyboardio/Kaleidoscope/blob/master/plugins/Kaleidoscope-Hardware-Keyboardio-Atreus/src/kaleidoscope/device/keyboardio/Atreus2.h#66 + [Imago.h]: https://github.com/keyboardio/Kaleidoscope/blob/master/plugins/Kaleidoscope-Hardware-Keyboardio-Imago/src/kaleidoscope/device/keyboardio/Imago.h#116 + +```c++ +#include +#include +#include +#include // DefaultColorMap +#include +#include + +PALETTE( + /* A list of 16 cRGB colors... */ +) + +KALEIDOSCOPE_INIT_PLUGINS(EEPROMSettings, + LEDControl, + ColormapOverlay, + DefaultColormap, + Focus); + +void setup() { + Kaleidoscope.setup(); + + COLORMAP_OVERLAYS( + // List of overlays, using kaleidoscope::plugin::Overlay + // kaleidoscope::plugin::Overlay({layer}, {key address}, {palette index}) + // A special value `ColormapOverlay::layer_wildcard` can be used in place of + // a layer number to apply the color overlay on all layers + ) + + ColormapOverlay.setup(); + DefaultColormap.setup(); +} +``` + + +## Plugin methods + +The extension only has a single method: + +### `.setup()` + +> Intended to be called from the `setup()` method of the sketch, it reserves the +> required space in EEPROM. diff --git a/plugins/Kaleidoscope-Colormap-Overlay/examples/Colormap-Overlay/Colormap-Overlay.ino b/plugins/Kaleidoscope-Colormap-Overlay/examples/Colormap-Overlay/Colormap-Overlay.ino new file mode 100644 index 0000000000..bb1c521175 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/examples/Colormap-Overlay/Colormap-Overlay.ino @@ -0,0 +1,110 @@ +// -*- mode: c++ -*- +/* Kaleidoscope - Firmware for computer input devices + * Copyright (C) 2017-2020 Bart Nagel + * + * This program is free software: you can redistribute it and/or modify it under + * the terms of the GNU General Public License as published by the Free Software + * Foundation, version 3. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more + * details. + * + * You should have received a copy of the GNU General Public License along with + * this program. If not, see . + */ + +#include +#include +#include +#include // DefaultColorMap +#include + +// clang-format off + +KEYMAPS( + [0] = KEYMAP_STACKED + (XXX, Key_1, Key_2, Key_3, Key_4, Key_5, Key_LEDEffectNext, + Key_Backtick, Key_Q, Key_W, Key_E, Key_R, Key_T, Key_Tab, + Key_PageUp, Key_A, Key_S, Key_D, Key_F, Key_G, + Key_PageDown, Key_Z, Key_X, Key_C, Key_V, Key_B, Key_Escape, + + Key_LeftControl, Key_Backspace, Key_LeftGui, Key_LeftShift, + XXX, + + XXX, Key_6, Key_7, Key_8, Key_9, Key_0, XXX, + Key_Enter, Key_Y, Key_U, Key_I, Key_O, Key_P, Key_Equals, + Key_H, Key_J, Key_K, Key_L, Key_Semicolon, Key_Quote, + Key_RightAlt, Key_N, Key_M, Key_Comma, Key_Period, Key_Slash, Key_Minus, + + Key_RightShift, Key_LeftAlt, Key_Spacebar, Key_RightControl, + XXX) +) // KEYMAPS( + +// clang-format on + +enum { + PALETTE_RED, + PALETTE_GREEN, + PALETTE_BLUE, + PALETTE_BLACK, + PALETTE_UNUSED_1, + PALETTE_UNUSED_2, + PALETTE_UNUSED_3, + PALETTE_UNUSED_4, + PALETTE_UNUSED_5, + PALETTE_UNUSED_6, + PALETTE_UNUSED_7, + PALETTE_UNUSED_8, + PALETTE_UNUSED_9, + PALETTE_UNUSED_10, + PALETTE_UNUSED_11, + PALETTE_UNUSED_12, +}; + +PALETTE( + [PALETTE_RED] = CRGB(0xff, 0x00, 0x00), + [PALETTE_GREEN] = CRGB(0x00, 0xff, 0x00), + [PALETTE_YELLOW] = CRGB(0x00, 0x00, 0xff), + [PALETTE_BLACK] = CRGB(0x00, 0x00, 0x00), + // unused + [PALETTE_UNUSED_1] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_2] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_3] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_4] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_5] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_6] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_7] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_8] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_9] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_10] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_11] = CRGB(0x00, 0x00, 0x00), + [PALETTE_UNUSED_12] = CRGB(0x00, 0x00, 0x00)) + +KALEIDOSCOPE_INIT_PLUGINS(EEPROMSettings, + LEDControl, + ColormapOverlay, + DefaultColormap); + +void setup() { + Kaleidoscope.setup(); + + COLORMAP_OVERLAYS( + // Make the any key green + kaleidoscope::plugin::Overlay(0, KeyAddr(0, 9), PALETTE_GREEN), + // Make numlock red + kaleidoscope::plugin::Overlay(0, KeyAddr(0, 15), PALETTE_RED), + // Make escape yellow + kaleidoscope::plugin::Overlay(0, KeyAddr(2, 6), PALETTE_YELLOW), + // Disable leds on the palm keys + kaleidoscope::plugin::Overlay(0, KeyAddr(3, 6), PALETTE_BLACK), + kaleidoscope::plugin::Overlay(0, KeyAddr(3, 9), PALETTE_BLACK)) + + ColormapOverlay.setup(); + DefaultColormap.setup(); +} + +void loop() { + Kaleidoscope.loop(); +} diff --git a/plugins/Kaleidoscope-Colormap-Overlay/library.properties b/plugins/Kaleidoscope-Colormap-Overlay/library.properties new file mode 100644 index 0000000000..c6a1d8dac0 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/library.properties @@ -0,0 +1,7 @@ +name=Kaleidoscope-Colormap-Overlay +version=0.0.0 +sentence=Per key colors overlaying active LED effect +maintainer=Kaleidoscope's Developers +url=https://github.com/keyboardio/Kaleidoscope +author=Keyboardio +paragraph= diff --git a/plugins/Kaleidoscope-Colormap-Overlay/src/Kaleidoscope-Colormap-Overlay.h b/plugins/Kaleidoscope-Colormap-Overlay/src/Kaleidoscope-Colormap-Overlay.h new file mode 100644 index 0000000000..bc3bbc3b67 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/src/Kaleidoscope-Colormap-Overlay.h @@ -0,0 +1,19 @@ +/* Kaleidoscope-Colormap-Overlay -- A LED plugin for Kaleidoscope. + * Copyright (C) 2017-2018 Keyboard.io, Inc. + * + * This program is free software: you can redistribute it and/or modify it under + * the terms of the GNU General Public License as published by the Free Software + * Foundation, version 3. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more + * details. + * + * You should have received a copy of the GNU General Public License along with + * this program. If not, see . + */ + +#pragma once + +#include "kaleidoscope/plugin/Colormap-Overlay.h" // IWYU pragma: export diff --git a/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.cpp b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.cpp new file mode 100644 index 0000000000..d0cda221f4 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.cpp @@ -0,0 +1,79 @@ +/* Kaleidoscope-Colormap-Overlay - A LED plugin for Kaleidoscope. + * Copyright (C) 2017-2018 Keyboard.io, Inc. + * + * This program is free software: you can redistribute it and/or modify it under + * the terms of the GNU General Public License as published by the Free Software + * Foundation, version 3. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more + * details. + * + * You should have received a copy of the GNU General Public License along with + * this program. If not, see . + */ + +#include "kaleidoscope/plugin/Colormap-Overlay.h" + +#include // for uint8_t + +#include "kaleidoscope/KeyAddr.h" // for KeyAddr, MatrixAddr, MatrixAddr<>::... +#include "kaleidoscope/device/device.h" // for cRGB, CRGB +#include "kaleidoscope/event_handler_result.h" // for EventHandlerResult, EventHandlerRes... +#include "kaleidoscope/key_defs.h" // for Key, KEY_FLAGS, Key_NoKey, LockLayer +#include "kaleidoscope/layers.h" // for Layer, Layer_ +#include "kaleidoscope/plugin/LEDControl.h" // for LEDControl +#include // for LEDPaletteTheme + +namespace kaleidoscope { +namespace plugin { +uint16_t ColormapOverlay::map_base_; + +void ColormapOverlay::setup() { + map_base_ = ::LEDPaletteTheme.reserveThemes(1); +} + +bool ColormapOverlay::hasOverlay(KeyAddr k) { + uint8_t layer_index = Layer.lookupActiveLayer(k); + for (uint8_t i{0}; i < overlay_count_; ++i) { + Overlay overlay = overlays_[i]; + if (overlay.addr == k) { + if ((overlay.layer == layer_index) || + (overlay.layer == layer_wildcard)) { + selectedColor = ::LEDPaletteTheme.lookupPaletteColor(overlay.palette_index); + return true; + } + } + } + + return false; +} + +EventHandlerResult ColormapOverlay::onSetup() { + return EventHandlerResult::OK; +} + +void ColormapOverlay::setLEDOverlayColors() { + if (!Runtime.has_leds) + return; + + for (auto key_addr : KeyAddr::all()) { + if (ColormapOverlay::hasOverlay(key_addr)) { + ::LEDControl.setCrgbAt(KeyAddr(key_addr), selectedColor); + } else { + ::LEDControl.refreshAt(KeyAddr(key_addr)); + } + } +} + +EventHandlerResult ColormapOverlay::beforeSyncingLeds() { + setLEDOverlayColors(); + + return EventHandlerResult::OK; +} + +} // namespace plugin +} // namespace kaleidoscope + +kaleidoscope::plugin::ColormapOverlay ColormapOverlay; diff --git a/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h new file mode 100644 index 0000000000..949eaaf9d5 --- /dev/null +++ b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h @@ -0,0 +1,81 @@ +/* Kaleidoscope-Colormap-Overlay - A LED plugin for Kaleidoscope. + * Copyright (C) 2017-2018 Keyboard.io, Inc. + * + * This program is free software: you can redistribute it and/or modify it under + * the terms of the GNU General Public License as published by the Free Software + * Foundation, version 3. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more + * details. + * + * You should have received a copy of the GNU General Public License along with + * this program. If not, see . + */ + +#pragma once + +#include // for uint8_t + +#include "kaleidoscope/KeyAddr.h" // for KeyAddr +#include "kaleidoscope/device/device.h" // for cRGB +#include "kaleidoscope/event_handler_result.h" // for EventHandlerResult +#include "kaleidoscope/key_defs.h" // for Key, KEY_FLAGS, Key_NoKey, LockLayer +#include "kaleidoscope/layers.h" // for Layer, Layer_ +#include "kaleidoscope/plugin/LEDControl.h" // for LEDControl + +namespace kaleidoscope { +namespace plugin { + +// Data structure for an individual qukey +struct Overlay { + int8_t layer; + KeyAddr addr; + uint8_t palette_index; + + // This is the constructor that should be used when creating a Overlay that + // will be used by ColormapOverlay + constexpr Overlay(int8_t layer, KeyAddr k, uint8_t palette_index) + : layer(layer), addr(k), palette_index(palette_index) {} +}; + +class ColormapOverlay : public kaleidoscope::Plugin { + public: + static void setup(); + // Function for defining the array of overlays. It's a template function that + // takes as its sole argument an array reference of size `_overlay_count`, so + // there's no need to use `sizeof` to calculate the correct size, and pass it + // as a separate parameter. + template + void configureOverlays(Overlay const (&overlays)[_overlay_count]) { + overlays_ = overlays; + overlay_count_ = _overlay_count; + } + + // A wildcard value for a qukey that exists on every layer. + static constexpr int8_t layer_wildcard{-1}; + + EventHandlerResult onSetup(); + EventHandlerResult beforeSyncingLeds(); + + private: + static uint16_t map_base_; + Overlay const *overlays_; + uint8_t overlay_count_; + cRGB selectedColor; + + bool hasOverlay(KeyAddr k); + void setLEDOverlayColors(); +}; + +} // namespace plugin +} // namespace kaleidoscope + +extern kaleidoscope::plugin::ColormapOverlay ColormapOverlay; + +#define COLORMAP_OVERLAYS(overlays...) \ + { \ + static kaleidoscope::plugin::Overlay const overlays_[] = {overlays}; \ + ColormapOverlay.configureOverlays(overlays_); \ + }