Ensure keepIccProfile retains CMYK input profiles #3906

This commit is contained in:
Lovell Fuller 2024-02-11 20:10:18 +00:00
parent fc439bedf1
commit fb70fbb09f
3 changed files with 19 additions and 1 deletions

View File

@ -4,6 +4,11 @@
Requires libvips v8.15.1 Requires libvips v8.15.1
### v0.33.3 - TBD
* Ensure `keepIccProfile` retains CMYK input profiles.
[#3906](https://github.com/lovell/sharp/issues/3906)
### v0.33.2 - 12th January 2024 ### v0.33.2 - 12th January 2024
* Upgrade to libvips v8.15.1 for upstream bug fixes. * Upgrade to libvips v8.15.1 for upstream bug fixes.

View File

@ -776,7 +776,7 @@ class PipelineWorker : public Napi::AsyncWorker {
// Convert colourspace, pass the current known interpretation so libvips doesn't have to guess // Convert colourspace, pass the current known interpretation so libvips doesn't have to guess
image = image.colourspace(baton->colourspace, VImage::option()->set("source_space", image.interpretation())); image = image.colourspace(baton->colourspace, VImage::option()->set("source_space", image.interpretation()));
// Transform colours from embedded profile to output profile // Transform colours from embedded profile to output profile
if ((baton->keepMetadata & VIPS_FOREIGN_KEEP_ICC) && if ((baton->keepMetadata & VIPS_FOREIGN_KEEP_ICC) && baton->colourspaceInput != VIPS_INTERPRETATION_CMYK &&
baton->withIccProfile.empty() && sharp::HasProfile(image)) { baton->withIccProfile.empty() && sharp::HasProfile(image)) {
image = image.icc_transform("srgb", VImage::option() image = image.icc_transform("srgb", VImage::option()
->set("embedded", TRUE) ->set("embedded", TRUE)

View File

@ -576,6 +576,19 @@ describe('Image metadata', function () {
assert.strictEqual(description, 'Generic RGB Profile'); assert.strictEqual(description, 'Generic RGB Profile');
}); });
it('keep existing CMYK ICC profile', async () => {
const data = await sharp(fixtures.inputJpgWithCmykProfile)
.pipelineColourspace('cmyk')
.toColourspace('cmyk')
.keepIccProfile()
.toBuffer();
const metadata = await sharp(data).metadata();
assert.strictEqual(metadata.channels, 4);
const { description } = icc.parse(metadata.icc);
assert.strictEqual(description, 'U.S. Web Coated (SWOP) v2');
});
it('transform to ICC profile and attach', async () => { it('transform to ICC profile and attach', async () => {
const data = await sharp({ create }) const data = await sharp({ create })
.png() .png()