-
Notifications
You must be signed in to change notification settings - Fork 122
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Exif orientation correction and cropping of Exif oriented images #4352
base: main
Are you sure you want to change the base?
Conversation
373aea4
to
addfad8
Compare
💎💎💎!
This is among the most sought-after user-facing features. Several desks (who upload original material) are most affected (magazines, Feast, Sport, incl. via FTP). Central Production must have rotated hundreds of images over the years. Impact is worse as the only way to know orientation is there is to notice Grid can’t deal with it (as everything else can) and then original upload must also be deleted. Grid is full of wrongly oriented imagery.
Ideally, if only at a later stage, we should switch to imgproxy. It’s VIPS-based, likely much faster, will provide modern file format support to speed up previews in the future, allow for pre-render logic simplification and, crucially, understands colour management, so fixes #894, another oldie.
This would be beneficial to users, especially given some more recent crop-related work by @twrichards.
A useful future enhancement indeed, to deal with already uploaded oriented imagery and to manually fix situations where capturing device wasn’t able to record orientation correctly (looking at you, foodies). All in all, this is like your favourite car finally getting working windshield wipers. You never thought they are essential until it rained on a trip. Pinging @davmacbea as we know our friends at the BBC also will benefit. |
Totally agree with @paperboyo on the benefit of this - thank you @tonytw1 We were just talking about this issue last week at the BBC. It's a particular problem for images coming in from our newsgathering mobile app. |
this looks great! I'm going to try and find time to have a play one note:
It looks like all the mapping changes are additions, so migration shouldn't be necessary, the addition should be applicable with https://github.com/guardian/grid/tree/main/scripts#updatemapping. That said, what would happen after a migration? If the orientation metadata is read from an image which previously had it but we ignored, I think that image (not its crops!) would become rotated in the grid? Which is great for all the images in the Grid which have orientation data but unfortunate for the images which have incorrect orientation metadata, and happened to be the correct way up in spite of the incorrect data (which looks to be exceedingly rare, at least in the Guardian's catalogue, but a few do exist). I think probably not a blocker? But since we'd have this data I think I'd be very keen to add ability to rotate images in the Grid |
That would be desirable, yeah.
Acceptable edge case, I would say? And one day will be sorted when we add UI to store |
Yes. All the mapping changes are additions.
You are correct about this edge case. This makes this issue a sleeper which might appear many years after the change. It -might- be ok through; as the existing crops of these images were all still made with the editor exposed to |
addfad8
to
70c6c60
Compare
This change adds the rotation arg to dev imgops for me (appreciate it'd be better to swap out imgops for a better service, but in the meanwhile...) diff --git a/dev/imgops/nginx.conf b/dev/imgops/nginx.conf
index cc05582e4..cac970833 100644
--- a/dev/imgops/nginx.conf
+++ b/dev/imgops/nginx.conf
@@ -31,6 +31,7 @@ http {
image_filter_interlace on;
image_filter_jpeg_quality $arg_q;
image_filter resize $arg_w $arg_h;
+ image_filter rotate $arg_r;
# connect to the localstack docker container
proxy_pass http://localstack:4566$request_uri; |
Agree. This looks like what I used to test with imgops. |
#4347 has been merged so I'm going to rebase and rereview this PR this week. |
2d16b9c
to
601323a
Compare
Rebased and suggestion applied. |
601323a
to
605fb7d
Compare
605fb7d
to
bda2850
Compare
…ata about this image which could affect it's rendered orientation (ie. exif orientation tags). Update elastic mapping fields
makeImgopsUri adds rotate parameter to preview image urls. imgops rotates images counter-clockwise and ignores negative values/
…ke the cropper to be told if orientation effects the rendered dimensions of this image.
…d the field is present for this image.
…plied when these bounds where selected; an EXIF orientation rotation will be explictly shown here.
…andscape orientation.
…ave no orientation metadata.
bda2850
to
c5ab5ba
Compare
The Grid has never dealt with EXIF oriented images.
EXIF oriented images (say from raw camera files) appear 'incorrectly' rotated in the Grid UI and cannot be cropped correctly:
This is an interesting omission which could mean:
This PR is an opinion on how EXIF rotation could be handled in a way which is backwards compatible and protects the option of allowing manual rotations in the future. It also leads to begin able to filter for portrait or landscape images.
There is no pressing need to merge this as it appears no Grid users require it and it is a non trivial change:
This is working for what I use it for.
Please contact me if there is any desire to use this in the future.
This PR is stacked on top of #4347 which I think is possibly a bug and can be merged independently.
What does this change?
New optional
orientationMetadata
,orientation
andorientedDimensions
fields under source asset.orientationMetadata
records all of the things about the raw source file which could effect it's display orientation.The Exif orientation tag been the first thing.
The source
dimensions
field remains unchanged; it is the raw width and height of source file with no correction for orientation tags.orientedDimensions
shows what the user visible dimensions of this image would be ifdimensions
was corrected for the tags found inorientationMetadata
.orientation
records the portrait or landscape orientation of the image, based on the oriented dimensions.Potential to expose this as a searchable field.
To reduce the impact of this change we can omit these fields if there is no orientation tag or the tag has no material impact:
Thumbnails and crops are corrected for Exif orientation.
Thumbnail and master crop generation is updated to include rotations to correct the orientation if Exif orientation metadata is found.
imops previews are explicitly rotated to account for orientation
The imgops url includes an explicit rotate parameter.
☠️ The nginx image filter imgops service needs to be updated to accept a
rotate
value on the query parameterr
.Cropper uses corrected oriented dimensions
The cropper UI and backend use the
orientedDimension
when calculating the crop bounding box.Crops of Exif oriented source images now work as expected because the master crop has had it's orientation corrected before the other crops are made.
CropSpec includes a new optional
rotation
fieldWhich records the orientation the user saw when this crop was made (if any).
Because no Grid image has ever been rotated, all the existing crops have the correct empty rotation field set all ready.
The rotation is the actual rotation applied after all orientation corrections (and future manual rotations) have been applied.
An Exif portrait image will show a rotation of 90 degrees.
In this way, all crops can still be reproduced from the source image.
There's an implicit ordering here... to reproduce, rotate than crop; suggests that one day images transforms might be represented as a sequence of operations.
These are new Elastic search fields. so it requires an Elastic migration to apply correctly:
Ignoring this won't break existing indexes but will mean Exif oriented images will refuse to upload.
How should a reviewer test this change?
Tested locally from my fork of the Grid against my fork of imgops.
Milage may vary for the Guardian's implementation of imgops.
How can success be measured?
Who should look at this?
Tested? Documented?