FastLED 3.9.15
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages

◆ bilinearExpandArbitraryFloat()

void fl::bilinearExpandArbitraryFloat ( const CRGB * input,
CRGB * output,
uint16_t inputWidth,
uint16_t inputHeight,
XYMap xyMap )

Definition at line 182 of file bilinear_expansion.cpp.

184 {
185 uint16_t n = xyMap.getTotal();
186 uint16_t outputWidth = xyMap.getWidth();
187 uint16_t outputHeight = xyMap.getHeight();
188
189 for (uint16_t y = 0; y < outputHeight; y++) {
190 for (uint16_t x = 0; x < outputWidth; x++) {
191 // Map output pixel to input grid position
192 float fx =
193 static_cast<float>(x) * (inputWidth - 1) / (outputWidth - 1);
194 float fy =
195 static_cast<float>(y) * (inputHeight - 1) / (outputHeight - 1);
196
197 uint16_t ix = static_cast<uint16_t>(fx);
198 uint16_t iy = static_cast<uint16_t>(fy);
199 float dx = fx - ix;
200 float dy = fy - iy;
201
202 uint16_t ix1 = (ix + 1 < inputWidth) ? ix + 1 : ix;
203 uint16_t iy1 = (iy + 1 < inputHeight) ? iy + 1 : iy;
204
205 uint16_t i00 = iy * inputWidth + ix;
206 uint16_t i10 = iy * inputWidth + ix1;
207 uint16_t i01 = iy1 * inputWidth + ix;
208 uint16_t i11 = iy1 * inputWidth + ix1;
209
210 CRGB c00 = input[i00];
211 CRGB c10 = input[i10];
212 CRGB c01 = input[i01];
213 CRGB c11 = input[i11];
214
215 CRGB result;
216 result.r =
217 bilinearInterpolateFloat(c00.r, c10.r, c01.r, c11.r, dx, dy);
218 result.g =
219 bilinearInterpolateFloat(c00.g, c10.g, c01.g, c11.g, dx, dy);
220 result.b =
221 bilinearInterpolateFloat(c00.b, c10.b, c01.b, c11.b, dx, dy);
222
223 uint16_t idx = xyMap.mapToIndex(x, y);
224 if (idx < n) {
225 output[idx] = result;
226 }
227 }
228 }
229}
int y
Definition Audio.ino:72
int x
Definition Audio.ino:71
XYMap xyMap(WIDTH, HEIGHT, false)
uint8_t bilinearInterpolateFloat(uint8_t v00, uint8_t v10, uint8_t v01, uint8_t v11, float dx, float dy)
Representation of an RGB pixel (Red, Green, Blue)
Definition crgb.h:55

References bilinearInterpolateFloat(), x, xyMap, and y.

+ Here is the call graph for this function: