Bugfixes.
- gamma on *Color palettes - gamma moved out of WS2812FX - palette fade (JSON) fix
This commit is contained in:
		| @@ -319,3 +319,52 @@ uint16_t approximateKelvinFromRGB(uint32_t rgb) { | ||||
|     return (k > 10091) ? 10091 : k; | ||||
|   } | ||||
| } | ||||
|  | ||||
| //gamma 2.8 lookup table used for color correction | ||||
| static byte gammaT[] = { | ||||
|     0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|     0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  1,  1,  1,  1, | ||||
|     1,  1,  1,  1,  1,  1,  1,  1,  1,  2,  2,  2,  2,  2,  2,  2, | ||||
|     2,  3,  3,  3,  3,  3,  3,  3,  4,  4,  4,  4,  4,  5,  5,  5, | ||||
|     5,  6,  6,  6,  6,  7,  7,  7,  7,  8,  8,  8,  9,  9,  9, 10, | ||||
|    10, 10, 11, 11, 11, 12, 12, 13, 13, 13, 14, 14, 15, 15, 16, 16, | ||||
|    17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 24, 24, 25, | ||||
|    25, 26, 27, 27, 28, 29, 29, 30, 31, 32, 32, 33, 34, 35, 35, 36, | ||||
|    37, 38, 39, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 50, | ||||
|    51, 52, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 66, 67, 68, | ||||
|    69, 70, 72, 73, 74, 75, 77, 78, 79, 81, 82, 83, 85, 86, 87, 89, | ||||
|    90, 92, 93, 95, 96, 98, 99,101,102,104,105,107,109,110,112,114, | ||||
|   115,117,119,120,122,124,126,127,129,131,133,135,137,138,140,142, | ||||
|   144,146,148,150,152,154,156,158,160,162,164,167,169,171,173,175, | ||||
|   177,180,182,184,186,189,191,193,196,198,200,203,205,208,210,213, | ||||
|   215,218,220,223,225,228,231,233,236,239,241,244,247,249,252,255 }; | ||||
|  | ||||
| uint8_t gamma8_cal(uint8_t b, float gamma) | ||||
| { | ||||
|   return (int)(powf((float)b / 255.0f, gamma) * 255.0f + 0.5f); | ||||
| } | ||||
|  | ||||
| void calcGammaTable(float gamma) | ||||
| { | ||||
|   for (uint16_t i = 0; i < 256; i++) { | ||||
|     gammaT[i] = gamma8_cal(i, gamma); | ||||
|   } | ||||
| } | ||||
|  | ||||
| uint8_t gamma8(uint8_t b) | ||||
| { | ||||
|   return gammaT[b]; | ||||
| } | ||||
|  | ||||
| uint32_t gamma32(uint32_t color) | ||||
| { | ||||
|   uint8_t w = W(color); | ||||
|   uint8_t r = R(color); | ||||
|   uint8_t g = G(color); | ||||
|   uint8_t b = B(color); | ||||
|   w = gammaT[w]; | ||||
|   r = gammaT[r]; | ||||
|   g = gammaT[g]; | ||||
|   b = gammaT[b]; | ||||
|   return RGBW32(r, g, b, w); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaz Kristan
					Blaz Kristan