typing_heatmap_anim.h 2.7 KB

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