summaryrefslogtreecommitdiff
path: root/users/anderson/dmc12.c
diff options
context:
space:
mode:
Diffstat (limited to 'users/anderson/dmc12.c')
-rw-r--r--users/anderson/dmc12.c46
1 files changed, 0 insertions, 46 deletions
diff --git a/users/anderson/dmc12.c b/users/anderson/dmc12.c
deleted file mode 100644
index 1dd89dce41..0000000000
--- a/users/anderson/dmc12.c
+++ /dev/null
@@ -1,46 +0,0 @@
-#include "dmc12.h"
-
-static uint32_t dmc12_color = 0;
-static uint16_t dmc12_timer = 0;
-static int8_t dmc12_current = 0;
-static uint8_t dmc12_direction = 1;
-
-void dmc12_start(uint32_t color, bool reset) {
- dmc12_color = color;
- if (reset) {
- dmc12_timer = 0;
- dmc12_current = 0;
- dmc12_direction = 1;
- }
-}
-
-void dmc12_process(void) {
- if (!dmc12_timer) {
- dmc12_timer = timer_read();
- return;
- }
- float dist_from_center = ((float)abs(dmc12_current - RGBLED_NUM / 2)) / ((float)RGBLED_NUM);
- if (timer_elapsed(dmc12_timer) > dist_from_center * LED_INTERVAL) {
- dmc12_current += dmc12_direction;
- if (dmc12_current == 0 || dmc12_current == RGBLED_NUM - 1) {
- dmc12_direction *= -1;
- }
- dmc12_timer = timer_read();
- for (int i = 0; i < RGBLED_NUM; i++) {
- if (i > dmc12_current - LED_RADIUS && i < dmc12_current + LED_RADIUS) {
- float intensity = (LED_RADIUS - abs(i - dmc12_current)) / ((float)LED_RADIUS);
- if (i != dmc12_current) {
- intensity /= 4.0;
- }
- rgblight_setrgb_at(
- ((dmc12_color >> 16) & 0xFF) * intensity,
- ((dmc12_color >> 8) & 0xFF) * intensity,
- (dmc12_color & 0xFF) * intensity,
- i
- );
- } else {
- rgblight_setrgb_at(0, 0, 0, i);
- }
- }
- }
-}