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

OffscreenCanvasRenderingContext2D does not have getContextAttributes #10872

Open
ccameron-chromium opened this issue Dec 18, 2024 · 10 comments
Open

Comments

@ccameron-chromium
Copy link
Contributor

ccameron-chromium commented Dec 18, 2024

What is the issue with the HTML Standard?

The getContextAttributes method allows for querying properties of a CanvasRenderingContext2D, such as its color space, alpha state, etc.

This method is not present on OffscreenCanvasRenderingContext.

This doesn't seem right, especially considering that the offscreen canvas 2D context is created using CanvasRenderingContext2DSettings. Is that just an oversight?

@annevk
Copy link
Member

annevk commented Dec 18, 2024

Seems worth looking at git blame (see README) to see if there was a reason. Might just be MVP.

cc @whatwg/canvas

@schenney-chromium
Copy link
Contributor

Interestingly there is no discussion of what the options are for OffscreenCanvas.getContext.

@ccameron-chromium
Copy link
Contributor Author

It dates back to this issue (sorry, forgot to mention it). It has a funny history where the API was accidentally shipped, then a Blink "Intent to Remove" caused people to realized that maybe we need it. It was committed here.

Do you think adding this would count as a clarification, or should it have a full review? Would it be best to fix this by:

  • Option A: Creating a new mixin common to CanvasRenderingContext2D and OffscreenCanvasRenderingContext2D
  • Option B: Adding a new method on OffscreenCanvasRenderingContext2D

I'm leaning towards Option B (since most related functionality, like 2d context creation, is separate).

@ccameron-chromium
Copy link
Contributor Author

To fully link things:

  • The 2D context creation algorithm for HTMLCanvasElement is here
  • The offscreen 2D context creation algorithm is here

They share alpha and colorSpace. They do not share desynchronized or willReadFrequently.

@annevk
Copy link
Member

annevk commented Dec 18, 2024

All normative changes go through this process: https://whatwg.org/working-mode#changes

I.e., PR + tests + implementer interest.

B seems fine. We should also split the dictionary if we don't actually support the same options, to enable feature testing going forward.

@ccameron-chromium
Copy link
Contributor Author

We should also split the dictionary if we don't actually support the same options, to enable feature testing going forward.

I did more archeology on this, and from what I can tell, the split for desynchronized and willReadFrequently support is accidental.

Given all of this, I think it would be better to move everything to a CanvasSettings (or something like that) interface. In particular:

Having these be un-merged has resulted in lots of duplicated (but slightly divergent) documentation (e.g, check out the different "alpha" documentation linked above), and a perpetual "oops we forgot to update OffscreenCanvasRenderingContext2D" situation.

Unless that is particularly upsetting, I'll put together a PR that does this reorganization.

@annevk
Copy link
Member

annevk commented Jan 7, 2025

Sounds good to me. Thanks for digging up the history!

@ccameron-chromium
Copy link
Contributor Author

ccameron-chromium commented Jan 7, 2025

This is the PR that I have in mind:
main...ccameron-chromium:html:canvas2d_settings

This is an explainer summarizing the above:
https://github.com/ccameron-chromium/ColorWeb-CG/blob/canvas_cleanup/canvas2d_settings.md

If that looks reasonable, I'll file position bugs and write tests.

@domfarolino
Copy link
Member

Yeah I would go ahead and turn that into a draft PR against this repository, which will be easier to review/evaluate.

@ccameron-chromium
Copy link
Contributor Author

I've opened a PR for this fix at #10904

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

No branches or pull requests

4 participants