aboutsummaryrefslogtreecommitdiff
path: root/quantum/rgb_matrix_animations/dual_beacon_anim.h
diff options
context:
space:
mode:
Diffstat (limited to 'quantum/rgb_matrix_animations/dual_beacon_anim.h')
-rw-r--r--quantum/rgb_matrix_animations/dual_beacon_anim.h24
1 files changed, 24 insertions, 0 deletions
diff --git a/quantum/rgb_matrix_animations/dual_beacon_anim.h b/quantum/rgb_matrix_animations/dual_beacon_anim.h
new file mode 100644
index 000000000..dda315780
--- /dev/null
+++ b/quantum/rgb_matrix_animations/dual_beacon_anim.h
@@ -0,0 +1,24 @@
1#pragma once
2#ifndef DISABLE_RGB_MATRIX_DUAL_BEACON
3
4extern rgb_counters_t g_rgb_counters;
5extern const rgb_led g_rgb_leds[DRIVER_LED_TOTAL];
6extern rgb_config_t rgb_matrix_config;
7
8bool rgb_matrix_dual_beacon(effect_params_t* params) {
9 RGB_MATRIX_USE_LIMITS(led_min, led_max);
10
11 HSV hsv = { 0, rgb_matrix_config.sat, rgb_matrix_config.val };
12 uint16_t time = scale16by8(g_rgb_counters.tick, rgb_matrix_config.speed / 4);
13 int8_t cos_value = cos8(time) - 128;
14 int8_t sin_value = sin8(time) - 128;
15 for (uint8_t i = led_min; i < led_max; i++) {
16 point_t point = g_rgb_leds[i].point;
17 hsv.h = ((point.y - 32) * cos_value + (point.x - 112) * sin_value) / 128 + rgb_matrix_config.hue;
18 RGB rgb = hsv_to_rgb(hsv);
19 rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
20 }
21 return led_max < DRIVER_LED_TOTAL;
22}
23
24#endif // DISABLE_RGB_MATRIX_DUAL_BEACON