You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The canvas TextStyles section says that for the direction IDL attribute "The direction IDL attribute, on getting, must return the current value." This is not currently interoperable when the value is "inherit", the default.
Firefox seems to follow the spec, reporting "inherit", but Chrome and Safari both resolve the "inherit" value to either "ltr" or "rtl" and report the resolved value.
The question here is which result is more useful for web developers. Knowing what the actual value is helps you know how it might change as other things in the page change (such as the direction CSS property or the HTML dir attribute), but to actually figure out the used value you would need to do a lot of work yourself. On the other hand, reporting the used value tells you what the test is going to render as, but tells you nothing of where the value came from (and doesn't even round-trip).
The underlying issue is that, unlike in CSS, there is no distinction between "the value" and "the computed value". I also have no idea how much content would break if the behavior was changed, although I'll add a counter to Chrome in an attempt to find out how often "ltr" or "rtl" is reported instead of "inherit" (i'm guessing a lot).
Resolution of this issue would clarify which of the two results is actually the right one, and optionally come up with a way for developers to say which one they want.
Can you check in your counters whether the value was set from the gotten value or from an explicit value? I suspect one case where "inherit" would be set is when one would try to reset the context's options to its defaults by using a clean context as source of truth. In this case they'd actually not use the default values in Chrome and Safari.
Maybe counters from Firefox would tell more than from Chrome.
And for what it's worth, getComputedStyle(ctx.canvas) will return the value used whether it's set through the dir attribute or through CSS, so it's not that hard to handle inherit. Also to be noted, some attributes like letterSpacing do accept relative length and don't expose the computed value in that case, so for these you'd also need to fetch it from the element yourself.
cc @whatwg/canvas
aarongable
pushed a commit
to chromium/chromium
that referenced
this issue
Jan 3, 2025
The reported value of Canvas TextStyle direction IDL attribute is not
interoperable. Firefox reports "inherit" for the default, whereas
Chrome and Safari report the computed value, either "ltr" or "rtl",
Investigate just how often the value is queried, with a goal to determining
a better standardized behavior.
Spec issue: whatwg/html#10884
Bug: 385194416
Change-Id: I61459fb965974e4fd52ffd4432c55c6048ad7c2e
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/6115394
Commit-Queue: Stephen Chenney <schenney@chromium.org>
Reviewed-by: Andres Ricardo Perez <andresrperez@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1401670}
What is the issue with the HTML Standard?
The canvas TextStyles section says that for the direction IDL attribute "The direction IDL attribute, on getting, must return the current value." This is not currently interoperable when the value is "inherit", the default.
Firefox seems to follow the spec, reporting "inherit", but Chrome and Safari both resolve the "inherit" value to either "ltr" or "rtl" and report the resolved value.
The question here is which result is more useful for web developers. Knowing what the actual value is helps you know how it might change as other things in the page change (such as the direction CSS property or the HTML dir attribute), but to actually figure out the used value you would need to do a lot of work yourself. On the other hand, reporting the used value tells you what the test is going to render as, but tells you nothing of where the value came from (and doesn't even round-trip).
The underlying issue is that, unlike in CSS, there is no distinction between "the value" and "the computed value". I also have no idea how much content would break if the behavior was changed, although I'll add a counter to Chrome in an attempt to find out how often "ltr" or "rtl" is reported instead of "inherit" (i'm guessing a lot).
Resolution of this issue would clarify which of the two results is actually the right one, and optionally come up with a way for developers to say which one they want.
The text was updated successfully, but these errors were encountered: