From 1b48824ef3c2faee9fb41cd893f4aa8c8ae616de Mon Sep 17 00:00:00 2001 From: Evy Bongers Date: Sat, 15 Jun 2024 12:30:41 +0200 Subject: [PATCH] Finalize first draft Signed-off-by: Evy Bongers --- .../src/kaleidoscope/plugin/Colormap-Overlay.h | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h index c20fc9edd..ac41ca3f8 100644 --- a/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h +++ b/plugins/Kaleidoscope-Colormap-Overlay/src/kaleidoscope/plugin/Colormap-Overlay.h @@ -59,15 +59,17 @@ class ColormapOverlay : public kaleidoscope::Plugin { overlay_count_ = 0; for (int layer_ = 0; layer_ < _layer_count; layer_++) { for (int key_index_ = 0; key_index_ < kaleidoscope_internal::device.matrix_rows * kaleidoscope_internal::device.matrix_columns; key_index_++) { - uint8_t color_index_ = overlays[layer_][key_index_]; - // TODO(EvyBongers): validate the color index? - overlays_[overlay_count_] = Overlay(layer_, KeyAddr(key_index_), color_index_); - overlay_count_++; + int8_t color_index_ = overlays[layer_][key_index_]; + if (color_index_ != no_color_overlay) { + overlays_[overlay_count_] = Overlay(layer_, KeyAddr(key_index_), color_index_); + overlay_count_++; + } } } } // A wildcard value for an overlay that applies on every layer. static constexpr int8_t layer_wildcard{-1}; + static constexpr int8_t no_color_overlay{-1}; EventHandlerResult onSetup(); EventHandlerResult beforeSyncingLeds(); @@ -87,7 +89,7 @@ class ColormapOverlay : public kaleidoscope::Plugin { #define COLORMAP_OVERLAYS_MAP(layers...) \ namespace kaleidoscope { \ namespace plugin { \ - const uint8_t overlays_[][kaleidoscope_internal::device.matrix_rows * kaleidoscope_internal::device.matrix_columns] = { \ + const int8_t overlays_[][kaleidoscope_internal::device.matrix_rows * kaleidoscope_internal::device.matrix_columns] = { \ layers \ }; \ ColormapOverlay.configureOverlays(overlays_); \