rgb_matrix_stuff.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. // Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
  2. // SPDX-License-Identifier: GPL-2.0-or-later
  3. #include "drashna.h"
  4. #include "rgb_matrix.h"
  5. #include "lib/lib8tion/lib8tion.h"
  6. extern led_config_t g_led_config;
  7. static uint32_t hypno_timer;
  8. void rgb_matrix_layer_helper(uint8_t hue, uint8_t sat, uint8_t val, uint8_t mode, uint8_t speed, uint8_t led_type, uint8_t led_min, uint8_t led_max) {
  9. HSV hsv = {hue, sat, val};
  10. if (hsv.v > rgb_matrix_get_val()) {
  11. hsv.v = rgb_matrix_get_val();
  12. }
  13. switch (mode) {
  14. case 1: // breathing
  15. {
  16. uint16_t time = scale16by8(g_rgb_timer, speed / 8);
  17. hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
  18. RGB rgb = hsv_to_rgb(hsv);
  19. for (uint8_t i = 0; i < RGB_MATRIX_LED_COUNT; i++) {
  20. if (HAS_FLAGS(g_led_config.flags[i], led_type)) {
  21. RGB_MATRIX_INDICATOR_SET_COLOR(i, rgb.r, rgb.g, rgb.b);
  22. }
  23. }
  24. break;
  25. }
  26. default: // Solid Color
  27. {
  28. RGB rgb = hsv_to_rgb(hsv);
  29. for (uint8_t i = 0; i < RGB_MATRIX_LED_COUNT; i++) {
  30. if (HAS_FLAGS(g_led_config.flags[i], led_type)) {
  31. RGB_MATRIX_INDICATOR_SET_COLOR(i, rgb.r, rgb.g, rgb.b);
  32. }
  33. }
  34. break;
  35. }
  36. }
  37. }
  38. __attribute__((weak)) void rgb_matrix_indicator_keymap(void) {}
  39. void matrix_scan_rgb_matrix(void) {
  40. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  41. if (userspace_config.rgb_matrix_idle_anim && rgb_matrix_get_mode() == RGB_MATRIX_TYPING_HEATMAP && sync_timer_elapsed32(hypno_timer) > 15000) {
  42. rgb_matrix_mode_noeeprom(RGB_MATRIX_REST_MODE);
  43. }
  44. #endif
  45. rgb_matrix_indicator_keymap();
  46. }
  47. void keyboard_post_init_rgb_matrix(void) {
  48. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  49. if (userspace_config.rgb_matrix_idle_anim) {
  50. rgb_matrix_mode_noeeprom(RGB_MATRIX_REST_MODE);
  51. }
  52. #endif
  53. if (userspace_config.rgb_layer_change) {
  54. rgb_matrix_set_flags(LED_FLAG_UNDERGLOW | LED_FLAG_KEYLIGHT | LED_FLAG_INDICATOR);
  55. } else {
  56. rgb_matrix_set_flags(LED_FLAG_ALL);
  57. }
  58. }
  59. bool process_record_user_rgb_matrix(uint16_t keycode, keyrecord_t *record) {
  60. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  61. hypno_timer = sync_timer_read32();
  62. if (userspace_config.rgb_matrix_idle_anim && rgb_matrix_get_mode() == RGB_MATRIX_REST_MODE) {
  63. rgb_matrix_mode_noeeprom(RGB_MATRIX_TYPING_HEATMAP);
  64. }
  65. #endif
  66. switch (keycode) {
  67. case RGB_IDL: // This allows me to use underglow as layer indication, or as normal
  68. #if defined(RGB_MATRIX_ENABLE) && defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  69. if (record->event.pressed) {
  70. userspace_config.rgb_matrix_idle_anim ^= 1;
  71. dprintf("RGB Matrix Idle Animation [EEPROM]: %u\n", userspace_config.rgb_matrix_idle_anim);
  72. eeconfig_update_user(userspace_config.raw);
  73. if (userspace_config.rgb_matrix_idle_anim) {
  74. rgb_matrix_mode_noeeprom(RGB_MATRIX_TYPING_HEATMAP);
  75. }
  76. }
  77. #endif
  78. break;
  79. }
  80. return true;
  81. }
  82. __attribute__((weak)) bool rgb_matrix_indicators_advanced_keymap(uint8_t led_min, uint8_t led_max) {
  83. return true;
  84. }
  85. bool rgb_matrix_indicators_advanced_user(uint8_t led_min, uint8_t led_max) {
  86. if (!rgb_matrix_indicators_advanced_keymap(led_min, led_max)) {
  87. return false;
  88. }
  89. #if defined(RGBLIGHT_ENABLE)
  90. if (!userspace_config.rgb_layer_change)
  91. #else
  92. if (userspace_config.rgb_layer_change)
  93. #endif
  94. {
  95. switch (get_highest_layer(layer_state & ~((layer_state_t)1 << _MOUSE))) {
  96. case _GAMEPAD:
  97. rgb_matrix_layer_helper(HSV_ORANGE, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  98. break;
  99. case _DIABLO:
  100. rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed * 8, LED_FLAG_MODIFIER, led_min, led_max);
  101. break;
  102. case _RAISE:
  103. rgb_matrix_layer_helper(HSV_YELLOW, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  104. break;
  105. case _LOWER:
  106. rgb_matrix_layer_helper(HSV_GREEN, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  107. break;
  108. case _ADJUST:
  109. rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  110. break;
  111. default:
  112. if (layer_state_is(_MOUSE)) {
  113. rgb_matrix_layer_helper(HSV_PURPLE, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  114. } else {
  115. switch (get_highest_layer(default_layer_state)) {
  116. case _DEFAULT_LAYER_1:
  117. rgb_matrix_layer_helper(DEFAULT_LAYER_1_HSV, 0, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  118. break;
  119. case _DEFAULT_LAYER_2:
  120. rgb_matrix_layer_helper(DEFAULT_LAYER_2_HSV, 0, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  121. break;
  122. case _DEFAULT_LAYER_3:
  123. rgb_matrix_layer_helper(DEFAULT_LAYER_3_HSV, 0, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  124. break;
  125. case _DEFAULT_LAYER_4:
  126. rgb_matrix_layer_helper(DEFAULT_LAYER_4_HSV, 0, rgb_matrix_config.speed, LED_FLAG_MODIFIER, led_min, led_max);
  127. break;
  128. }
  129. }
  130. break;
  131. }
  132. }
  133. return false;
  134. }
  135. __attribute__((weak)) bool rgb_matrix_indicators_keymap(void) {
  136. return true;
  137. }
  138. bool rgb_matrix_indicators_user(void) {
  139. return rgb_matrix_indicators_keymap();
  140. }