typing_heatmap_anim.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #pragma once
  2. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS) && !defined(DISABLE_RGB_MATRIX_TYPING_HEATMAP)
  3. extern rgb_config_t rgb_matrix_config;
  4. extern uint8_t rgb_frame_buffer[MATRIX_ROWS][MATRIX_COLS];
  5. void process_rgb_matrix_typing_heatmap(keyrecord_t *record) {
  6. uint8_t row = record->event.key.row;
  7. uint8_t col = record->event.key.col;
  8. uint8_t m_row = row - 1;
  9. uint8_t p_row = row + 1;
  10. uint8_t m_col = col - 1;
  11. uint8_t p_col = col + 1;
  12. if (m_col < col)
  13. rgb_frame_buffer[row][m_col] = qadd8(rgb_frame_buffer[row][m_col], 16);
  14. rgb_frame_buffer[row][col] = qadd8(rgb_frame_buffer[row][col], 32);
  15. if (p_col < MATRIX_COLS)
  16. rgb_frame_buffer[row][p_col] = qadd8(rgb_frame_buffer[row][p_col], 16);
  17. if (p_row < MATRIX_ROWS) {
  18. if (m_col < col)
  19. rgb_frame_buffer[p_row][m_col] = qadd8(rgb_frame_buffer[p_row][m_col], 13);
  20. rgb_frame_buffer[p_row][col] = qadd8(rgb_frame_buffer[p_row][col], 16);
  21. if (p_col < MATRIX_COLS)
  22. rgb_frame_buffer[p_row][p_col] = qadd8(rgb_frame_buffer[p_row][p_col], 13);
  23. }
  24. if (m_row < row) {
  25. if (m_col < col)
  26. rgb_frame_buffer[m_row][m_col] = qadd8(rgb_frame_buffer[m_row][m_col], 13);
  27. rgb_frame_buffer[m_row][col] = qadd8(rgb_frame_buffer[m_row][col], 16);
  28. if (p_col < MATRIX_COLS)
  29. rgb_frame_buffer[m_row][p_col] = qadd8(rgb_frame_buffer[m_row][p_col], 13);
  30. }
  31. }
  32. bool rgb_matrix_typing_heatmap(effect_params_t* params) {
  33. // Modified version of RGB_MATRIX_USE_LIMITS to work off of matrix row / col size
  34. uint8_t led_min = RGB_MATRIX_LED_PROCESS_LIMIT * params->iter;
  35. uint8_t led_max = led_min + RGB_MATRIX_LED_PROCESS_LIMIT;
  36. if (led_max > sizeof(rgb_frame_buffer))
  37. led_max = sizeof(rgb_frame_buffer);
  38. if (params->init) {
  39. rgb_matrix_set_color_all(0, 0, 0);
  40. memset(rgb_frame_buffer, 0, sizeof rgb_frame_buffer);
  41. }
  42. // Render heatmap & decrease
  43. for (int i = led_min; i < led_max; i++) {
  44. uint8_t row = i % MATRIX_ROWS;
  45. uint8_t col = i / MATRIX_ROWS;
  46. uint8_t val = rgb_frame_buffer[row][col];
  47. // set the pixel colour
  48. uint8_t led[LED_HITS_TO_REMEMBER];
  49. uint8_t led_count = rgb_matrix_map_row_column_to_led(row, col, led);
  50. for (uint8_t j = 0; j < led_count; ++j)
  51. {
  52. if (!HAS_ANY_FLAGS(g_led_config.flags[led[j]], params->flags))
  53. continue;
  54. HSV hsv = { 170 - qsub8(val, 85), rgb_matrix_config.sat, scale8((qadd8(170, val) - 170) * 3, rgb_matrix_config.val) };
  55. RGB rgb = hsv_to_rgb(hsv);
  56. rgb_matrix_set_color(led[j], rgb.r, rgb.g, rgb.b);
  57. }
  58. rgb_frame_buffer[row][col] = qsub8(val, 1);
  59. }
  60. return led_max < sizeof(rgb_frame_buffer);
  61. }
  62. #endif // defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS) && !defined(DISABLE_RGB_MATRIX_TYPING_HEATMAP)