From 54d9dc46f561aa1d841db27be801e323535dafe0 Mon Sep 17 00:00:00 2001 From: jakob0fischl <36727988+jakob0fischl@users.noreply.github.com> Date: Sun, 15 May 2022 13:26:57 +0200 Subject: [PATCH] Fix rotate-then-extract for EXIF orientation 2 (#3218) --- src/pipeline.cc | 18 +++++++++------- test/unit/extract.js | 51 ++++++++++++++++++++++++++++++++++++++------ 2 files changed, 54 insertions(+), 15 deletions(-) diff --git a/src/pipeline.cc b/src/pipeline.cc index c0ada83a1..437c4a1e9 100644 --- a/src/pipeline.cc +++ b/src/pipeline.cc @@ -95,16 +95,18 @@ class PipelineWorker : public Napi::AsyncWorker { if (baton->rotateBeforePreExtract) { if (rotation != VIPS_ANGLE_D0) { image = image.rot(rotation); - if (flip) { - image = image.flip(VIPS_DIRECTION_VERTICAL); - flip = FALSE; - } - if (flop) { - image = image.flip(VIPS_DIRECTION_HORIZONTAL); - flop = FALSE; - } + } + if (flip) { + image = image.flip(VIPS_DIRECTION_VERTICAL); + } + if (flop) { + image = image.flip(VIPS_DIRECTION_HORIZONTAL); + } + if (rotation != VIPS_ANGLE_D0 || flip || flop) { image = sharp::RemoveExifOrientation(image); } + flop = FALSE; + flip = FALSE; if (baton->rotationAngle != 0.0) { MultiPageUnsupported(nPages, "Rotate"); std::vector background; diff --git a/test/unit/extract.js b/test/unit/extract.js index 4120cb274..22eacc241 100644 --- a/test/unit/extract.js +++ b/test/unit/extract.js @@ -168,14 +168,51 @@ describe('Partial image extraction', function () { }); }); - it('Rotate with EXIF mirroring then extract', function (done) { - sharp(fixtures.inputJpgWithLandscapeExif7) - .rotate() - .extract({ left: 0, top: 208, width: 60, height: 40 }) - .toBuffer(function (err, data) { - if (err) throw err; - fixtures.assertSimilar(fixtures.expected('rotate-mirror-extract.jpg'), data, done); + describe('Apply exif orientation and mirroring then extract', () => { + [ + { + name: 'EXIF-1', + image: fixtures.inputJpgWithLandscapeExif1 + }, + { + name: 'EXIF-2', + image: fixtures.inputJpgWithLandscapeExif2 + }, + { + name: 'EXIF-3', + image: fixtures.inputJpgWithLandscapeExif3 + }, + { + name: 'EXIF-4', + image: fixtures.inputJpgWithLandscapeExif4 + }, + { + name: 'EXIF-5', + image: fixtures.inputJpgWithLandscapeExif5 + }, + { + name: 'EXIF-6', + image: fixtures.inputJpgWithLandscapeExif6 + }, + { + name: 'EXIF-7', + image: fixtures.inputJpgWithLandscapeExif7 + }, + { + name: 'EXIF-8', + image: fixtures.inputJpgWithLandscapeExif8 + } + ].forEach(({ name, image }) => { + it(name, function (done) { + sharp(image) + .rotate() + .extract({ left: 0, top: 208, width: 60, height: 40 }) + .toBuffer(function (err, data) { + if (err) throw err; + fixtures.assertSimilar(fixtures.expected('rotate-mirror-extract.jpg'), data, done); + }); }); + }); }); describe('Invalid parameters', function () {