mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-13 10:46:16 +03:00
Merge pull request #7966 from radarhere/palette
Support unpacking more rawmodes to RGBA palettes
This commit is contained in:
commit
9c7ba240e9
|
@ -79,6 +79,7 @@ def test_putpalette_with_alpha_values() -> None:
|
||||||
(
|
(
|
||||||
("RGBA", (1, 2, 3, 4)),
|
("RGBA", (1, 2, 3, 4)),
|
||||||
("RGBAX", (1, 2, 3, 4, 0)),
|
("RGBAX", (1, 2, 3, 4, 0)),
|
||||||
|
("ARGB", (4, 1, 2, 3)),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
def test_rgba_palette(mode: str, palette: tuple[int, ...]) -> None:
|
def test_rgba_palette(mode: str, palette: tuple[int, ...]) -> None:
|
||||||
|
|
|
@ -380,6 +380,7 @@ class DdsImageFile(ImageFile.ImageFile):
|
||||||
elif pfflags & DDPF.PALETTEINDEXED8:
|
elif pfflags & DDPF.PALETTEINDEXED8:
|
||||||
self._mode = "P"
|
self._mode = "P"
|
||||||
self.palette = ImagePalette.raw("RGBA", self.fp.read(1024))
|
self.palette = ImagePalette.raw("RGBA", self.fp.read(1024))
|
||||||
|
self.palette.mode = "RGBA"
|
||||||
elif pfflags & DDPF.FOURCC:
|
elif pfflags & DDPF.FOURCC:
|
||||||
offset = header_size + 4
|
offset = header_size + 4
|
||||||
if fourcc == D3DFMT.DXT1:
|
if fourcc == D3DFMT.DXT1:
|
||||||
|
|
|
@ -433,7 +433,7 @@ class GifImageFile(ImageFile.ImageFile):
|
||||||
self._prev_im = self.im
|
self._prev_im = self.im
|
||||||
if self._frame_palette:
|
if self._frame_palette:
|
||||||
self.im = Image.core.fill("P", self.size, self._frame_transparency or 0)
|
self.im = Image.core.fill("P", self.size, self._frame_transparency or 0)
|
||||||
self.im.putpalette(*self._frame_palette.getdata())
|
self.im.putpalette("RGB", *self._frame_palette.getdata())
|
||||||
else:
|
else:
|
||||||
self.im = None
|
self.im = None
|
||||||
self._mode = temp_mode
|
self._mode = temp_mode
|
||||||
|
|
|
@ -889,7 +889,7 @@ class Image:
|
||||||
if self.im is not None and self.palette and self.palette.dirty:
|
if self.im is not None and self.palette and self.palette.dirty:
|
||||||
# realize palette
|
# realize palette
|
||||||
mode, arr = self.palette.getdata()
|
mode, arr = self.palette.getdata()
|
||||||
self.im.putpalette(mode, arr)
|
self.im.putpalette(self.palette.mode, mode, arr)
|
||||||
self.palette.dirty = 0
|
self.palette.dirty = 0
|
||||||
self.palette.rawmode = None
|
self.palette.rawmode = None
|
||||||
if "transparency" in self.info and mode in ("LA", "PA"):
|
if "transparency" in self.info and mode in ("LA", "PA"):
|
||||||
|
@ -899,9 +899,9 @@ class Image:
|
||||||
self.im.putpalettealphas(self.info["transparency"])
|
self.im.putpalettealphas(self.info["transparency"])
|
||||||
self.palette.mode = "RGBA"
|
self.palette.mode = "RGBA"
|
||||||
else:
|
else:
|
||||||
palette_mode = "RGBA" if mode.startswith("RGBA") else "RGB"
|
self.palette.palette = self.im.getpalette(
|
||||||
self.palette.mode = palette_mode
|
self.palette.mode, self.palette.mode
|
||||||
self.palette.palette = self.im.getpalette(palette_mode, palette_mode)
|
)
|
||||||
|
|
||||||
if self.im is not None:
|
if self.im is not None:
|
||||||
if cffi and USE_CFFI_ACCESS:
|
if cffi and USE_CFFI_ACCESS:
|
||||||
|
@ -2046,7 +2046,7 @@ class Image:
|
||||||
palette = ImagePalette.raw(rawmode, data)
|
palette = ImagePalette.raw(rawmode, data)
|
||||||
self._mode = "PA" if "A" in self.mode else "P"
|
self._mode = "PA" if "A" in self.mode else "P"
|
||||||
self.palette = palette
|
self.palette = palette
|
||||||
self.palette.mode = "RGB"
|
self.palette.mode = "RGBA" if "A" in rawmode else "RGB"
|
||||||
self.load() # install new palette
|
self.load() # install new palette
|
||||||
|
|
||||||
def putpixel(self, xy, value):
|
def putpixel(self, xy, value):
|
||||||
|
@ -2161,7 +2161,7 @@ class Image:
|
||||||
# m_im.putpalette(mapping_palette, 'L') # converts to 'P'
|
# m_im.putpalette(mapping_palette, 'L') # converts to 'P'
|
||||||
# or just force it.
|
# or just force it.
|
||||||
# UNDONE -- this is part of the general issue with palettes
|
# UNDONE -- this is part of the general issue with palettes
|
||||||
m_im.im.putpalette(palette_mode + ";L", m_im.palette.tobytes())
|
m_im.im.putpalette(palette_mode, palette_mode + ";L", m_im.palette.tobytes())
|
||||||
|
|
||||||
m_im = m_im.convert("L")
|
m_im = m_im.convert("L")
|
||||||
|
|
||||||
|
|
|
@ -1725,10 +1725,11 @@ _putpalette(ImagingObject *self, PyObject *args) {
|
||||||
ImagingShuffler unpack;
|
ImagingShuffler unpack;
|
||||||
int bits;
|
int bits;
|
||||||
|
|
||||||
char *rawmode, *palette_mode;
|
char *palette_mode, *rawmode;
|
||||||
UINT8 *palette;
|
UINT8 *palette;
|
||||||
Py_ssize_t palettesize;
|
Py_ssize_t palettesize;
|
||||||
if (!PyArg_ParseTuple(args, "sy#", &rawmode, &palette, &palettesize)) {
|
if (!PyArg_ParseTuple(
|
||||||
|
args, "ssy#", &palette_mode, &rawmode, &palette, &palettesize)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1738,7 +1739,6 @@ _putpalette(ImagingObject *self, PyObject *args) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
palette_mode = strncmp("RGBA", rawmode, 4) == 0 ? "RGBA" : "RGB";
|
|
||||||
unpack = ImagingFindUnpacker(palette_mode, rawmode, &bits);
|
unpack = ImagingFindUnpacker(palette_mode, rawmode, &bits);
|
||||||
if (!unpack) {
|
if (!unpack) {
|
||||||
PyErr_SetString(PyExc_ValueError, wrong_raw_mode);
|
PyErr_SetString(PyExc_ValueError, wrong_raw_mode);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user