typing_heatmap_anim.h 2.8 KB

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