typing_heatmap_anim.h 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #if defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS) && defined(ENABLE_RGB_MATRIX_TYPING_HEATMAP)
  2. RGB_MATRIX_EFFECT(TYPING_HEATMAP)
  3. # ifdef RGB_MATRIX_CUSTOM_EFFECT_IMPLS
  4. # ifndef RGB_MATRIX_TYPING_HEATMAP_DECREASE_DELAY_MS
  5. # define RGB_MATRIX_TYPING_HEATMAP_DECREASE_DELAY_MS 25
  6. # endif
  7. void process_rgb_matrix_typing_heatmap(uint8_t row, uint8_t 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) g_rgb_frame_buffer[row][m_col] = qadd8(g_rgb_frame_buffer[row][m_col], 16);
  13. g_rgb_frame_buffer[row][col] = qadd8(g_rgb_frame_buffer[row][col], 32);
  14. if (p_col < MATRIX_COLS) g_rgb_frame_buffer[row][p_col] = qadd8(g_rgb_frame_buffer[row][p_col], 16);
  15. if (p_row < MATRIX_ROWS) {
  16. if (m_col < col) g_rgb_frame_buffer[p_row][m_col] = qadd8(g_rgb_frame_buffer[p_row][m_col], 13);
  17. g_rgb_frame_buffer[p_row][col] = qadd8(g_rgb_frame_buffer[p_row][col], 16);
  18. if (p_col < MATRIX_COLS) g_rgb_frame_buffer[p_row][p_col] = qadd8(g_rgb_frame_buffer[p_row][p_col], 13);
  19. }
  20. if (m_row < row) {
  21. if (m_col < col) g_rgb_frame_buffer[m_row][m_col] = qadd8(g_rgb_frame_buffer[m_row][m_col], 13);
  22. g_rgb_frame_buffer[m_row][col] = qadd8(g_rgb_frame_buffer[m_row][col], 16);
  23. if (p_col < MATRIX_COLS) g_rgb_frame_buffer[m_row][p_col] = qadd8(g_rgb_frame_buffer[m_row][p_col], 13);
  24. }
  25. }
  26. // A timer to track the last time we decremented all heatmap values.
  27. static uint16_t heatmap_decrease_timer;
  28. // Whether we should decrement the heatmap values during the next update.
  29. static bool decrease_heatmap_values;
  30. bool TYPING_HEATMAP(effect_params_t* params) {
  31. // Modified version of RGB_MATRIX_USE_LIMITS to work off of matrix row / col size
  32. uint8_t led_min = RGB_MATRIX_LED_PROCESS_LIMIT * params->iter;
  33. uint8_t led_max = led_min + RGB_MATRIX_LED_PROCESS_LIMIT;
  34. if (led_max > sizeof(g_rgb_frame_buffer)) led_max = sizeof(g_rgb_frame_buffer);
  35. if (params->init) {
  36. rgb_matrix_set_color_all(0, 0, 0);
  37. memset(g_rgb_frame_buffer, 0, sizeof g_rgb_frame_buffer);
  38. }
  39. // The heatmap animation might run in several iterations depending on
  40. // `RGB_MATRIX_LED_PROCESS_LIMIT`, therefore we only want to update the
  41. // timer when the animation starts.
  42. if (params->iter == 0) {
  43. decrease_heatmap_values = timer_elapsed(heatmap_decrease_timer) >= RGB_MATRIX_TYPING_HEATMAP_DECREASE_DELAY_MS;
  44. // Restart the timer if we are going to decrease the heatmap this frame.
  45. if (decrease_heatmap_values) {
  46. heatmap_decrease_timer = timer_read();
  47. }
  48. }
  49. // Render heatmap & decrease
  50. for (int i = led_min; i < led_max; i++) {
  51. uint8_t row = i % MATRIX_ROWS;
  52. uint8_t col = i / MATRIX_ROWS;
  53. uint8_t val = g_rgb_frame_buffer[row][col];
  54. // set the pixel colour
  55. uint8_t led[LED_HITS_TO_REMEMBER];
  56. uint8_t led_count = rgb_matrix_map_row_column_to_led(row, col, led);
  57. for (uint8_t j = 0; j < led_count; ++j) {
  58. if (!HAS_ANY_FLAGS(g_led_config.flags[led[j]], params->flags)) continue;
  59. HSV hsv = {170 - qsub8(val, 85), rgb_matrix_config.hsv.s, scale8((qadd8(170, val) - 170) * 3, rgb_matrix_config.hsv.v)};
  60. RGB rgb = rgb_matrix_hsv_to_rgb(hsv);
  61. rgb_matrix_set_color(led[j], rgb.r, rgb.g, rgb.b);
  62. }
  63. if (decrease_heatmap_values) {
  64. g_rgb_frame_buffer[row][col] = qsub8(val, 1);
  65. }
  66. }
  67. return led_max < sizeof(g_rgb_frame_buffer);
  68. }
  69. # endif // RGB_MATRIX_CUSTOM_EFFECT_IMPLS
  70. #endif // defined(RGB_MATRIX_FRAMEBUFFER_EFFECTS) && defined(ENABLE_RGB_MATRIX_TYPING_HEATMAP)