Merge pull request #3359 from bz2/i16_getextrema

Give correct extrema for I;16 format images
This commit is contained in:
Hugo 2018-09-26 13:17:31 +03:00 committed by GitHub
commit 83d40f52b3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 13 additions and 0 deletions

Binary file not shown.

View File

@ -1,3 +1,4 @@
from PIL import Image
from helper import unittest, PillowTestCase, hopper
@ -19,6 +20,13 @@ class TestImageGetExtrema(PillowTestCase):
extrema("RGBA"), ((0, 255), (0, 255), (0, 255), (255, 255)))
self.assertEqual(
extrema("CMYK"), (((0, 255), (0, 255), (0, 255), (0, 0))))
self.assertEqual(extrema("I;16"), (0, 255))
def test_true_16(self):
im = Image.open("Tests/images/16_bit_noise.tif")
self.assertEqual(im.mode, 'I;16')
extrema = im.getextrema()
self.assertEqual(extrema, (106, 285))
if __name__ == '__main__':

View File

@ -1998,6 +1998,7 @@ _getextrema(ImagingObject* self, PyObject* args)
UINT8 u[2];
INT32 i[2];
FLOAT32 f[2];
UINT16 s[2];
} extrema;
int status;
@ -2013,6 +2014,10 @@ _getextrema(ImagingObject* self, PyObject* args)
return Py_BuildValue("ii", extrema.i[0], extrema.i[1]);
case IMAGING_TYPE_FLOAT32:
return Py_BuildValue("dd", extrema.f[0], extrema.f[1]);
case IMAGING_TYPE_SPECIAL:
if (strcmp(self->image->mode, "I;16") == 0) {
return Py_BuildValue("HH", extrema.s[0], extrema.s[1]);
}
}
Py_INCREF(Py_None);