Skip to content
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

Should orientation metadata (such as exif) be used when drawing HTMLImageElements/SVGImageElements to canvas? #10492

Open
weinig opened this issue Jul 17, 2024 · 7 comments

Comments

@weinig
Copy link

weinig commented Jul 17, 2024

Its possible it is specified elsewhere, but https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-drawimage doesn't seem to indicate whether orientation metadata (such as exif) should be respected when using drawImage.

Should it?

And if it should, should a CSS image-orientation property (e.g. image-orientation: none) computed for that image affect the rendering?

(my guess/suggestion here on what makes the most sense is that orientation metadata should be respected, but CSS image-orientation: should not be, just like the CSS to change the image's width and height is not respected. For users that want more control, ImageBitmap provides nobs).

@annevk
Copy link
Member

annevk commented Jul 18, 2024

Pretty sure that EXIF tags should be respected (and as per w3c/csswg-drafts#5165 (comment) user agents should act as if it's baked in for opaque images to avoid leaking orientation in addition to width/height).

See also #7210 and #9693.

cc @whatwg/canvas

@kdashg
Copy link

kdashg commented Jul 23, 2024

Yes, this all sounds correct.

@noamr
Copy link
Contributor

noamr commented Jul 24, 2024

Pretty sure that EXIF tags should be respected (and as per w3c/csswg-drafts#5165 (comment) user agents should act as if it's baked in for opaque images to avoid leaking orientation in addition to width/height).

See also #7210 and #9693.

cc @whatwg/canvas

I believe w3c/csswg-drafts#5165 is not relevant here because:

  1. the only way the orientation can leak is by using image-orientation: none. I don't think that CSS property should be respected, as anyway the image element that's drawn to a canvas does not necessarily originate from a CSS-selectable DOM context. So without that CSS property the orientation is anyway "baked into the image".
  2. drawing such an image into a canvas would taint the canvas anyway, so this information won't be leaked, no?

@weinig
Copy link
Author

weinig commented Jul 24, 2024

I think that’s right @noamr.

Would be good to clarify in the spec that:

  • exif is respected
  • CSS overrides are not

(perhaps a normative note about how ImageBitmap can be used if more control is required)

@schenney-chromium
Copy link
Contributor

I did the Chromium implementation of image orientation from exif. Looking at the code I wrote back then, Chromium respects the image-orientation: none CSS property on the canvas element itself, otherwise always respects orientation and always respects orientation on cross origin content (or any content that would taint). The logic was that if canvas authors did not want orientation, they would have a consistent desire for all images in the canvas and hence the canvas element was a good place to put the CSS property.

I'm fine with removing that and always orienting according to exif.

@noamr
Copy link
Contributor

noamr commented Sep 13, 2024

I did the Chromium implementation of image orientation from exif. Looking at the code I wrote back then, Chromium respects the image-orientation: none CSS property on the canvas element itself, otherwise always respects orientation and always respects orientation on cross origin content (or any content that would taint). The logic was that if canvas authors did not want orientation, they would have a consistent desire for all images in the canvas and hence the canvas element was a good place to put the CSS property.

I'm fine with removing that and always orienting according to exif.

I think it's fine the way it is from a security standpoint, as the canvas pixels would be tainted anyway.
However, I'd really like to see all of this in the HTML/CSS standards. None of this is spec'ed anywhere.

@schenney-chromium
Copy link
Contributor

Coming back to this, I like the argument above that in canvas drawImage() we should always ignore CSS image-orientation just as we ignore CSS width and height.

I have no idea whether this would break existing content in Chromium-based browsers (although such content is probably not interoperable) so I'll try to count such cases. It would also remove a possible forced layout in Chrome for same-origin images in drawImage.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

No branches or pull requests

5 participants