summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorDane Madsen <[email protected]>2023-05-22 23:20:28 +1000
committerGitHub <[email protected]>2023-05-22 15:20:28 +0200
commita4a6d4da8a26d131bc3f3e643f6fe51de281d15f (patch)
tree62aaabf5222f158dc1ac4e861e499611d0d1303a /src
parent84ae26cdc0ab22e7721552647cd6c30d8a478bae (diff)
downloadraylib-a4a6d4da8a26d131bc3f3e643f6fe51de281d15f.tar.gz
raylib-a4a6d4da8a26d131bc3f3e643f6fe51de281d15f.zip
Add GenImageGradientSquare (#3077)
* Add GenImageGradientSquare to allow square gradients * Fix GenImageGradientSquare and add to textures_image_generation example * Remove params from GenImageGradientSquare
Diffstat (limited to 'src')
-rw-r--r--src/raylib.h1
-rw-r--r--src/rtextures.c49
2 files changed, 50 insertions, 0 deletions
diff --git a/src/raylib.h b/src/raylib.h
index 02d8e444..703e70c2 100644
--- a/src/raylib.h
+++ b/src/raylib.h
@@ -1241,6 +1241,7 @@ RLAPI bool ExportImageAsCode(Image image, const char *fileName);
RLAPI Image GenImageColor(int width, int height, Color color); // Generate image: plain color
RLAPI Image GenImageGradientLinear(int width, int height, int direction, Color start, Color end); // Generate image: linear gradient, direction in degrees [0..360], 0=Vertical gradient
RLAPI Image GenImageGradientRadial(int width, int height, float density, Color inner, Color outer); // Generate image: radial gradient
+RLAPI Image GenImageGradientSquare(int width, int height, float density, Color inner, Color outer); // Generate image: square gradient
RLAPI Image GenImageChecked(int width, int height, int checksX, int checksY, Color col1, Color col2); // Generate image: checked
RLAPI Image GenImageWhiteNoise(int width, int height, float factor); // Generate image: white noise
RLAPI Image GenImagePerlinNoise(int width, int height, int offsetX, int offsetY, float scale); // Generate image: perlin noise
diff --git a/src/rtextures.c b/src/rtextures.c
index d1cebe0d..f6a747c0 100644
--- a/src/rtextures.c
+++ b/src/rtextures.c
@@ -764,6 +764,55 @@ Image GenImageGradientRadial(int width, int height, float density, Color inner,
return image;
}
+// Generate image: square gradient
+Image GenImageGradientSquare(int width, int height, float density, Color inner, Color outer)
+{
+ Color *pixels = (Color *)RL_MALLOC(width*height*sizeof(Color));
+
+ float centerX = (float)width/2.0f;
+ float centerY = (float)height/2.0f;
+
+ for (int y = 0; y < height; y++)
+ {
+ for (int x = 0; x < width; x++)
+ {
+ // Calculate the Manhattan distance from the center
+ float distX = fabsf(x - centerX);
+ float distY = fabsf(y - centerY);
+
+ // Normalize the distances by the dimensions of the gradient rectangle
+ float normalizedDistX = distX / centerX;
+ float normalizedDistY = distY / centerY;
+
+ // Calculate the total normalized Manhattan distance
+ float manhattanDist = fmax(normalizedDistX, normalizedDistY);
+
+ // Subtract the density from the manhattanDist, then divide by (1 - density)
+ // This makes the gradient start from the center when density is 0, and from the edge when density is 1
+ float factor = (manhattanDist - density) / (1.0f - density);
+
+ // Clamp the factor between 0 and 1
+ factor = fminf(fmaxf(factor, 0.f), 1.f);
+
+ // Blend the colors based on the calculated factor
+ pixels[y*width + x].r = (int)((float)outer.r*factor + (float)inner.r*(1.0f - factor));
+ pixels[y*width + x].g = (int)((float)outer.g*factor + (float)inner.g*(1.0f - factor));
+ pixels[y*width + x].b = (int)((float)outer.b*factor + (float)inner.b*(1.0f - factor));
+ pixels[y*width + x].a = (int)((float)outer.a*factor + (float)inner.a*(1.0f - factor));
+ }
+ }
+
+ Image image = {
+ .data = pixels,
+ .width = width,
+ .height = height,
+ .format = PIXELFORMAT_UNCOMPRESSED_R8G8B8A8,
+ .mipmaps = 1
+ };
+
+ return image;
+}
+
// Generate image: checked
Image GenImageChecked(int width, int height, int checksX, int checksY, Color col1, Color col2)
{