651 {
652 if (blendType == LINEARBLEND_NOWRAP) {
653 index =
map8(index, 0, 239);
654
655 }
656
657
659 fl::u8 lo4 = index & 0x0F;
660
662
664 fl::u8 green1 = entry.green;
665 fl::u8 blue1 = entry.blue;
666
668
670
671 if (hi4 == 15) {
673 } else {
675 }
676
679
681 red1 = scale8_LEAVING_R1_DIRTY(red1, f1);
682 red2 = scale8_LEAVING_R1_DIRTY(red2, f2);
683 red1 += red2;
684
685 fl::u8 green2 = entry.green;
686 green1 = scale8_LEAVING_R1_DIRTY(green1, f1);
687 green2 = scale8_LEAVING_R1_DIRTY(green2, f2);
688 green1 += green2;
689
690 fl::u8 blue2 = entry.blue;
691 blue1 = scale8_LEAVING_R1_DIRTY(blue1, f1);
692 blue2 = scale8_LEAVING_R1_DIRTY(blue2, f2);
693 blue1 += blue2;
694
695 cleanup_R1();
696 }
697
701
702
703
704 if (red1) {
705 red1 = scale8_LEAVING_R1_DIRTY(red1,
brightness);
706#if !(FASTLED_SCALE8_FIXED == 1)
707 ++red1;
708#endif
709 }
710 if (green1) {
711 green1 = scale8_LEAVING_R1_DIRTY(green1,
brightness);
712#if !(FASTLED_SCALE8_FIXED == 1)
713 ++green1;
714#endif
715 }
716 if (blue1) {
717 blue1 = scale8_LEAVING_R1_DIRTY(blue1,
brightness);
718#if !(FASTLED_SCALE8_FIXED == 1)
719 ++blue1;
720#endif
721 }
722 cleanup_R1();
723 } else {
724 red1 = 0;
725 green1 = 0;
726 blue1 = 0;
727 }
728 }
729
730 return CRGB(red1, green1, blue1);
731}
fl::UISlider brightness("Brightness", BRIGHTNESS, 0, 255)
CRGB blend(const CRGB &p1, const CRGB &p2, fract8 amountOfP2)
#define FL_PGM_READ_DWORD_NEAR(x)
Read a double word (32-bit) from PROGMEM memory.
LIB8STATIC fl::u8 map8(fl::u8 in, fl::u8 rangeStart, fl::u8 rangeEnd)
Map from one full-range 8-bit value into a narrower range of 8-bit values, possibly a range of hues.
fl::u8 lsrX4(fl::u8 dividend)
Helper function to divide a number by 16, aka four logical shift right (LSR)'s.