RGB Matrix overhaul
Breakout of animations to separate files Integration of optimized int based math lib Overhaul of rgb_matrix.c and animations for performance
This commit is contained in:
		
							parent
							
								
									23086808a7
								
							
						
					
					
						commit
						8073da5dea
					
				
					 37 changed files with 3876 additions and 1009 deletions
				
			
		
							
								
								
									
										42
									
								
								quantum/rgb_matrix_animations/solid_splash_anim.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								quantum/rgb_matrix_animations/solid_splash_anim.h
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,42 @@
 | 
			
		|||
#pragma once
 | 
			
		||||
#ifdef RGB_MATRIX_KEYPRESSES
 | 
			
		||||
#if !defined(DISABLE_RGB_MATRIX_SOLID_SPLASH) || !defined(DISABLE_RGB_MATRIX_SOLID_MULTISPLASH)
 | 
			
		||||
 | 
			
		||||
extern const rgb_led g_rgb_leds[DRIVER_LED_TOTAL];
 | 
			
		||||
extern rgb_config_t rgb_matrix_config;
 | 
			
		||||
extern last_hit_t g_last_hit_tracker;
 | 
			
		||||
 | 
			
		||||
static bool rgb_matrix_solid_multisplash_range(uint8_t start, uint8_t iter) {
 | 
			
		||||
  RGB_MATRIX_USE_LIMITS(led_min, led_max);
 | 
			
		||||
 | 
			
		||||
  HSV hsv = { rgb_matrix_config.hue, rgb_matrix_config.sat, 0 };
 | 
			
		||||
  uint8_t count = g_last_hit_tracker.count;
 | 
			
		||||
  for (uint8_t i = led_min; i < led_max; i++) {
 | 
			
		||||
    hsv.v = 0;
 | 
			
		||||
    point_t point = g_rgb_leds[i].point;
 | 
			
		||||
    for (uint8_t j = start; j < count; j++) {
 | 
			
		||||
      int16_t dx = point.x - g_last_hit_tracker.x[j];
 | 
			
		||||
      int16_t dy = point.y - g_last_hit_tracker.y[j];
 | 
			
		||||
      uint8_t dist = sqrt16(dx * dx + dy * dy);
 | 
			
		||||
      uint16_t effect = scale16by8(g_last_hit_tracker.tick[j], rgb_matrix_config.speed) - dist;
 | 
			
		||||
      if (effect > 255)
 | 
			
		||||
        effect = 255;
 | 
			
		||||
      hsv.v = qadd8(hsv.v, 255 - effect);
 | 
			
		||||
    }
 | 
			
		||||
    hsv.v = scale8(hsv.v, rgb_matrix_config.val);
 | 
			
		||||
    RGB rgb = hsv_to_rgb(hsv);
 | 
			
		||||
    rgb_matrix_set_color(i, rgb.r, rgb.g, rgb.b);
 | 
			
		||||
  }
 | 
			
		||||
  return led_max < DRIVER_LED_TOTAL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool rgb_matrix_solid_multisplash(bool init, uint8_t iter) {
 | 
			
		||||
  return rgb_matrix_solid_multisplash_range(0, iter);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool rgb_matrix_solid_splash(bool init, uint8_t iter) {
 | 
			
		||||
  return rgb_matrix_solid_multisplash_range(qsub8(g_last_hit_tracker.count, 1), iter);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // !defined(DISABLE_RGB_MATRIX_SPLASH) && !defined(DISABLE_RGB_MATRIX_MULTISPLASH)
 | 
			
		||||
#endif // RGB_MATRIX_KEYPRESSES
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue