rgb_matrix_stuff.c 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #include "drashna.h"
  2. #include "lib/lib8tion/lib8tion.h"
  3. extern led_config_t g_led_config;
  4. static uint32_t hypno_timer;
  5. #if defined(SPLIT_KEYBOARD) || defined(KEYBOARD_ergodox_ez) || defined(KEYBOARD_crkbd)
  6. # define RGB_MATRIX_REST_MODE RGB_MATRIX_CYCLE_OUT_IN_DUAL
  7. #else
  8. # define RGB_MATRIX_REST_MODE RGB_MATRIX_CYCLE_OUT_IN
  9. #endif
  10. void rgb_matrix_layer_helper(uint8_t hue, uint8_t sat, uint8_t val, uint8_t mode, uint8_t speed, uint8_t led_type) {
  11. HSV hsv = {hue, sat, val};
  12. if (hsv.v > rgb_matrix_config.hsv.v) {
  13. hsv.v = rgb_matrix_config.hsv.v;
  14. }
  15. switch (mode) {
  16. case 1: // breathing
  17. {
  18. uint16_t time = scale16by8(g_rgb_counters.tick, speed / 8);
  19. hsv.v = scale8(abs8(sin8(time) - 128) * 2, hsv.v);
  20. RGB rgb = hsv_to_rgb(hsv);
  21. for (uint8_t i = 0; i < DRIVER_LED_TOTAL; i++) {
  22. if (HAS_FLAGS(g_led_config.flags[i], led_type)) {
  23. rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
  24. }
  25. }
  26. break;
  27. }
  28. default: // Solid Color
  29. {
  30. RGB rgb = hsv_to_rgb(hsv);
  31. for (uint8_t i = 0; i < DRIVER_LED_TOTAL; i++) {
  32. if (HAS_FLAGS(g_led_config.flags[i], led_type)) {
  33. rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
  34. }
  35. }
  36. break;
  37. }
  38. }
  39. }
  40. __attribute__((weak)) void rgb_matrix_indicator_keymap(void) {}
  41. void matrix_scan_rgb_matrix(void) {
  42. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  43. if (userspace_config.rgb_matrix_idle_anim && rgb_matrix_get_mode() == RGB_MATRIX_TYPING_HEATMAP && timer_elapsed32(hypno_timer) > 15000) {
  44. rgb_matrix_mode_noeeprom(RGB_MATRIX_REST_MODE);
  45. }
  46. #endif
  47. rgb_matrix_indicator_keymap();
  48. }
  49. void keyboard_post_init_rgb_matrix(void) {
  50. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  51. if (userspace_config.rgb_matrix_idle_anim) {
  52. rgb_matrix_mode_noeeprom(RGB_MATRIX_REST_MODE);
  53. }
  54. #endif
  55. }
  56. bool process_record_user_rgb_matrix(uint16_t keycode, keyrecord_t *record) {
  57. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  58. hypno_timer = timer_read32();
  59. if (userspace_config.rgb_matrix_idle_anim && rgb_matrix_get_mode() == RGB_MATRIX_REST_MODE) {
  60. rgb_matrix_mode_noeeprom(RGB_MATRIX_TYPING_HEATMAP);
  61. }
  62. #endif
  63. switch (keycode) {
  64. case RGB_IDL: // This allows me to use underglow as layer indication, or as normal
  65. #if defined(RGB_MATRIX_ENABLE) && defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS)
  66. if (record->event.pressed) {
  67. userspace_config.rgb_matrix_idle_anim ^= 1;
  68. dprintf("RGB Matrix Idle Animation [EEPROM]: %u\n", userspace_config.rgb_matrix_idle_anim);
  69. eeconfig_update_user(userspace_config.raw);
  70. if (userspace_config.rgb_matrix_idle_anim) {
  71. rgb_matrix_mode_noeeprom(RGB_MATRIX_TYPING_HEATMAP);
  72. }
  73. }
  74. #endif
  75. break;
  76. }
  77. return true;
  78. }