Skip to content

Commit

Permalink
Fixed linear_gradient and radial_gradient 32-bit modes
Browse files Browse the repository at this point in the history
  • Loading branch information
radarhere committed Feb 22, 2021
1 parent 058b8d3 commit 2977892
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 6 deletions.
4 changes: 2 additions & 2 deletions Tests/test_image.py
Expand Up @@ -519,7 +519,7 @@ def test_linear_gradient(self):

# Arrange
target_file = "Tests/images/linear_gradient.png"
for mode in ["L", "P"]:
for mode in ["L", "P", "I", "F"]:

# Act
im = Image.linear_gradient(mode)
Expand All @@ -545,7 +545,7 @@ def test_radial_gradient(self):

# Arrange
target_file = "Tests/images/radial_gradient.png"
for mode in ["L", "P"]:
for mode in ["L", "P", "I", "F"]:

# Act
im = Image.radial_gradient(mode)
Expand Down
28 changes: 24 additions & 4 deletions src/libImaging/Fill.c
Expand Up @@ -76,8 +76,21 @@ ImagingFillLinearGradient(const char *mode) {
return NULL;
}

for (y = 0; y < 256; y++) {
memset(im->image8[y], (unsigned char)y, 256);
if (im->image8) {
for (y = 0; y < 256; y++) {
memset(im->image8[y], (unsigned char)y, 256);
}
} else {
int x;
for (y = 0; y < 256; y++) {
for (x = 0; x < 256; x++) {
if (im->type == IMAGING_TYPE_FLOAT32) {
IMAGING_PIXEL_FLOAT32(im, x, y) = y;
} else {
IMAGING_PIXEL_INT32(im, x, y) = y;
}
}
}
}

return im;
Expand All @@ -103,9 +116,16 @@ ImagingFillRadialGradient(const char *mode) {
d = (int)sqrt(
(double)((x - 128) * (x - 128) + (y - 128) * (y - 128)) * 2.0);
if (d >= 255) {
im->image8[y][x] = 255;
} else {
d = 255;
}
if (im->image8) {
im->image8[y][x] = d;
} else {
if (im->type == IMAGING_TYPE_FLOAT32) {
IMAGING_PIXEL_FLOAT32(im, x, y) = d;
} else {
IMAGING_PIXEL_INT32(im, x, y) = d;
}
}
}
}
Expand Down

0 comments on commit 2977892

Please sign in to comment.