Scale three one-byte values by a fourth one, which is treated as the numerator of a fraction whose demominator is 256.
In other words, it computes r,g,b * (scale / 256)
- Warning
- This function always modifies its arguments in place!
- Parameters
-
r | first value to scale |
g | second value to scale |
b | third value to scale |
scale | scale factor, in n/256 units |
Definition at line 367 of file scale8.h.
367 {
368#if SCALE8_C == 1
369#if (FASTLED_SCALE8_FIXED == 1)
370 uint16_t scale_fixed =
scale + 1;
371 r = (((uint16_t)r) * scale_fixed) >> 8;
372 g = (((uint16_t)g) * scale_fixed) >> 8;
373 b = (((uint16_t)b) * scale_fixed) >> 8;
374#else
375 r = ((int)r * (int)(
scale)) >> 8;
376 g = ((int)g * (int)(
scale)) >> 8;
377 b = ((int)b * (int)(
scale)) >> 8;
378#endif
379#elif SCALE8_AVRASM == 1
384#else
385#error "No implementation for nscale8x3 available."
386#endif
387}
LIB8STATIC_ALWAYS_INLINE void cleanup_R1()
Clean up the r1 register after a series of *LEAVING_R1_DIRTY calls.
LIB8STATIC_ALWAYS_INLINE uint8_t scale8_LEAVING_R1_DIRTY(uint8_t i, fract8 scale)
This version of scale8() does not clean up the R1 register on AVR.
References cleanup_R1(), LIB8STATIC, scale, and scale8_LEAVING_R1_DIRTY().
Referenced by fl::ColorFromPaletteExtended(), fl::ColorFromPaletteExtended(), and MyColorFromPaletteExtended().