2019-04-03 02:24:14 +02:00
|
|
|
#ifndef DISABLE_RGB_MATRIX_RAINDROPS
|
2019-05-11 01:55:02 +02:00
|
|
|
RGB_MATRIX_EFFECT(RAINDROPS)
|
|
|
|
#ifdef RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
2019-04-03 02:24:14 +02:00
|
|
|
|
2019-04-30 00:18:50 +02:00
|
|
|
static void raindrops_set_color(int i, effect_params_t* params) {
|
2019-05-08 01:22:46 +02:00
|
|
|
if (!HAS_ANY_FLAGS(g_led_config.flags[i], params->flags)) return;
|
2019-05-20 06:12:29 +02:00
|
|
|
HSV hsv = { 0 , rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v };
|
2019-04-03 02:24:14 +02:00
|
|
|
|
|
|
|
// Take the shortest path between hues
|
2019-05-20 06:12:29 +02:00
|
|
|
int16_t deltaH = ((rgb_matrix_config.hsv.h + 180) % 360 - rgb_matrix_config.hsv.h) / 4;
|
2019-04-03 02:24:14 +02:00
|
|
|
if (deltaH > 127) {
|
|
|
|
deltaH -= 256;
|
|
|
|
} else if (deltaH < -127) {
|
|
|
|
deltaH += 256;
|
|
|
|
}
|
|
|
|
|
2019-05-20 06:12:29 +02:00
|
|
|
hsv.h = rgb_matrix_config.hsv.h + (deltaH * (rand() & 0x03));
|
2019-04-03 02:24:14 +02:00
|
|
|
RGB rgb = hsv_to_rgb(hsv);
|
|
|
|
rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
|
|
|
|
}
|
|
|
|
|
2019-05-11 01:55:02 +02:00
|
|
|
bool RAINDROPS(effect_params_t* params) {
|
2019-04-03 02:24:14 +02:00
|
|
|
if (!params->init) {
|
|
|
|
// Change one LED every tick, make sure speed is not 0
|
|
|
|
if (scale16by8(g_rgb_counters.tick, qadd8(rgb_matrix_config.speed, 16)) % 10 == 0) {
|
2019-04-30 00:18:50 +02:00
|
|
|
raindrops_set_color(rand() % DRIVER_LED_TOTAL, params);
|
2019-04-03 02:24:14 +02:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
RGB_MATRIX_USE_LIMITS(led_min, led_max);
|
|
|
|
for (int i = led_min; i < led_max; i++) {
|
2019-04-30 00:18:50 +02:00
|
|
|
raindrops_set_color(i, params);
|
2019-04-03 02:24:14 +02:00
|
|
|
}
|
|
|
|
return led_max < DRIVER_LED_TOTAL;
|
|
|
|
}
|
|
|
|
|
2019-05-11 01:55:02 +02:00
|
|
|
#endif // RGB_MATRIX_CUSTOM_EFFECT_IMPLS
|
2019-04-03 02:24:14 +02:00
|
|
|
#endif // DISABLE_RGB_MATRIX_RAINDROPS
|