summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorraysan5 <[email protected]>2020-05-14 13:37:52 +0200
committerraysan5 <[email protected]>2020-05-14 13:37:52 +0200
commit3a33fe0fd9dae174a244680095c90b264d808416 (patch)
tree67f5e987dd6ed71935c422bba17cc527c3ac16d3
parent65b7047111c27de11c87c90cb15ef376c902e2d7 (diff)
downloadraylib-3a33fe0fd9dae174a244680095c90b264d808416.tar.gz
raylib-3a33fe0fd9dae174a244680095c90b264d808416.zip
Avoid LoadImageEx() usage internally
At this point LoadImageEx() could be removed from raylib... still thinking about it...
-rw-r--r--src/textures.c281
1 files changed, 174 insertions, 107 deletions
diff --git a/src/textures.c b/src/textures.c
index cfedf6be..d571eaa3 100644
--- a/src/textures.c
+++ b/src/textures.c
@@ -464,9 +464,13 @@ Image GenImageColor(int width, int height, Color color)
for (int i = 0; i < width*height; i++) pixels[i] = color;
- Image image = LoadImageEx(pixels, width, height);
-
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -489,8 +493,13 @@ Image GenImageGradientV(int width, int height, Color top, Color bottom)
}
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -512,8 +521,13 @@ Image GenImageGradientH(int width, int height, Color left, Color right)
}
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -544,8 +558,13 @@ Image GenImageGradientRadial(int width, int height, float density, Color inner,
}
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -564,8 +583,13 @@ Image GenImageChecked(int width, int height, int checksX, int checksY, Color col
}
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -581,8 +605,13 @@ Image GenImageWhiteNoise(int width, int height, float factor)
else pixels[i] = BLACK;
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -612,8 +641,13 @@ Image GenImagePerlinNoise(int width, int height, int offsetX, int offsetY, float
}
}
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -672,8 +706,13 @@ Image GenImageCellular(int width, int height, int tileSize)
RL_FREE(seeds);
- Image image = LoadImageEx(pixels, width, height);
- RL_FREE(pixels);
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
return image;
}
@@ -760,11 +799,12 @@ void ImageCrop(Image *image, Rectangle crop)
int format = image->format;
- UnloadImage(*image);
+ RL_FREE(image->data);
- *image = LoadImageEx(cropPixels, (int)crop.width, (int)crop.height);
-
- RL_FREE(cropPixels);
+ image->data = cropPixels;
+ image->width = (int)crop.width;
+ image->height = (int)crop.height;
+ image->format = UNCOMPRESSED_R8G8B8A8;
// Reformat 32bit RGBA image to original format
ImageFormat(image, format);
@@ -983,10 +1023,11 @@ void ImageToPOT(Image *image, Color fillColor)
int format = image->format; // Store image data format to reconvert later
- // NOTE: Image size changes, new width and height
- *image = LoadImageEx(pixelsPOT, potWidth, potHeight);
-
- RL_FREE(pixelsPOT); // Free POT pixels data
+ // Fill new image data
+ image->data = pixelsPOT;
+ image->width = potWidth;
+ image->height = potHeight;
+ image->format = UNCOMPRESSED_R8G8B8A8;
ImageFormat(image, format); // Reconvert image to previous format
@@ -1115,13 +1156,13 @@ void ImageAlphaClear(Image *image, Color color, float threshold)
for (int i = 0; i < image->width*image->height; i++) if (pixels[i].a <= (unsigned char)(threshold*255.0f)) pixels[i] = color;
- UnloadImage(*image);
-
+ RL_FREE(image->data);
int prevFormat = image->format;
- *image = LoadImageEx(pixels, image->width, image->height);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
ImageFormat(image, prevFormat);
- RL_FREE(pixels);
}
// Apply alpha mask to image
@@ -1192,13 +1233,13 @@ void ImageAlphaPremultiply(Image *image)
pixels[i].b = (unsigned char)((float)pixels[i].b*alpha);
}
- UnloadImage(*image);
+ RL_FREE(image->data);
int prevFormat = image->format;
- *image = LoadImageEx(pixels, image->width, image->height);
-
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
ImageFormat(image, prevFormat);
- RL_FREE(pixels);
}
// Resize and image to new size
@@ -1218,14 +1259,16 @@ void ImageResize(Image *image, int newWidth, int newHeight)
stbir_resize_uint8((unsigned char *)pixels, image->width, image->height, 0, (unsigned char *)output, newWidth, newHeight, 0, 4);
int format = image->format;
+
+ RL_FREE(pixels);
+ RL_FREE(image->data);
- UnloadImage(*image);
+ image->data = output;
+ image->width = newWidth;
+ image->height = newHeight;
+ image->format = UNCOMPRESSED_R8G8B8A8;
- *image = LoadImageEx(output, newWidth, newHeight);
ImageFormat(image, format); // Reformat 32bit RGBA image to original format
-
- RL_FREE(output);
- RL_FREE(pixels);
}
// Resize and image to new size using Nearest-Neighbor scaling algorithm
@@ -1255,12 +1298,15 @@ void ImageResizeNN(Image *image,int newWidth,int newHeight)
int format = image->format;
- UnloadImage(*image);
+ RL_FREE(image->data);
+
+ image->data = output;
+ image->width = newWidth;
+ image->height = newHeight;
+ image->format = UNCOMPRESSED_R8G8B8A8;
- *image = LoadImageEx(output, newWidth, newHeight);
ImageFormat(image, format); // Reformat 32bit RGBA image to original format
- RL_FREE(output);
RL_FREE(pixels);
}
@@ -1305,7 +1351,7 @@ void ImageResizeCanvas(Image *image, int newWidth, int newHeight, int offsetX, i
ImageDraw(&imTemp, *image, srcRec, dstRec, WHITE);
ImageFormat(&imTemp, image->format);
- UnloadImage(*image);
+ RL_FREE(image->data);
*image = imTemp;
}
else if ((newWidth < image->width) && (newHeight < image->height))
@@ -1336,7 +1382,7 @@ void ImageResizeCanvas(Image *image, int newWidth, int newHeight, int offsetX, i
ImageDraw(&imTemp, *image, srcRec, dstRec, WHITE);
ImageFormat(&imTemp, image->format);
- UnloadImage(*image);
+ RL_FREE(image->data);
*image = imTemp;
}
}
@@ -1541,14 +1587,15 @@ void ImageFlipVertical(Image *image)
}
}
- Image processed = LoadImageEx(dstPixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = dstPixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
RL_FREE(srcPixels);
- RL_FREE(dstPixels);
-
- image->data = processed.data;
}
// Flip image horizontally
@@ -1568,14 +1615,15 @@ void ImageFlipHorizontal(Image *image)
}
}
- Image processed = LoadImageEx(dstPixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = dstPixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
RL_FREE(srcPixels);
- RL_FREE(dstPixels);
-
- image->data = processed.data;
}
// Rotate image clockwise 90deg
@@ -1595,16 +1643,19 @@ void ImageRotateCW(Image *image)
}
}
- Image processed = LoadImageEx(rotPixels, image->height, image->width);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
-
+ int format = image->format;
+ int width = image->width;
+ int height = image-> height;
+ RL_FREE(image->data);
+
+ image->data = rotPixels;
+ image->width = height;
+ image->height = width;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
+
RL_FREE(srcPixels);
- RL_FREE(rotPixels);
-
- image->data = processed.data;
- image->width = processed.width;
- image->height = processed.height;
}
// Rotate image counter-clockwise 90deg
@@ -1624,16 +1675,19 @@ void ImageRotateCCW(Image *image)
}
}
- Image processed = LoadImageEx(rotPixels, image->height, image->width);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
-
+ int format = image->format;
+ int width = image->width;
+ int height = image-> height;
+ RL_FREE(image->data);
+
+ image->data = rotPixels;
+ image->width = height;
+ image->height = width;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
+
RL_FREE(srcPixels);
- RL_FREE(rotPixels);
-
- image->data = processed.data;
- image->width = processed.width;
- image->height = processed.height;
}
// Modify image color: tint
@@ -1666,12 +1720,13 @@ void ImageColorTint(Image *image, Color color)
}
}
- Image processed = LoadImageEx(pixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
- RL_FREE(pixels);
-
- image->data = processed.data;
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
}
// Modify image color: invert
@@ -1692,12 +1747,13 @@ void ImageColorInvert(Image *image)
}
}
- Image processed = LoadImageEx(pixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
- RL_FREE(pixels);
-
- image->data = processed.data;
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
}
// Modify image color: grayscale
@@ -1755,12 +1811,13 @@ void ImageColorContrast(Image *image, float contrast)
}
}
- Image processed = LoadImageEx(pixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
- RL_FREE(pixels);
-
- image->data = processed.data;
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
}
// Modify image color: brightness
@@ -1798,12 +1855,13 @@ void ImageColorBrightness(Image *image, int brightness)
}
}
- Image processed = LoadImageEx(pixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
- RL_FREE(pixels);
-
- image->data = processed.data;
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
}
// Modify image color: replace color
@@ -1831,12 +1889,13 @@ void ImageColorReplace(Image *image, Color color, Color replace)
}
}
- Image processed = LoadImageEx(pixels, image->width, image->height);
- ImageFormat(&processed, image->format);
- UnloadImage(*image);
- RL_FREE(pixels);
-
- image->data = processed.data;
+ int format = image->format;
+ RL_FREE(image->data);
+
+ image->data = pixels;
+ image->format = UNCOMPRESSED_R8G8B8A8;
+
+ ImageFormat(image, format);
}
#endif // SUPPORT_IMAGE_MANIPULATION
@@ -2488,13 +2547,21 @@ void ImageDraw(Image *dst, Image src, Rectangle srcRec, Rectangle dstRec, Color
}
}
- UnloadImage(*dst);
+ Image final = {
+ .data = dstPixels,
+ .width = dst->width,
+ .height = dst->height,
+ .format = UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
- *dst = LoadImageEx(dstPixels, (int)dst->width, (int)dst->height);
- ImageFormat(dst, dst->format);
+ // NOTE: dstPixels are free() inside ImageFormat()
+ ImageFormat(&final, dst->format);
+
+ UnloadImage(*dst);
+ *dst = final;
RL_FREE(srcPixels);
- RL_FREE(dstPixels);
}
// Draw text (default font) within an image (destination)