-
Notifications
You must be signed in to change notification settings - Fork 410
Add inlineVerticalFieldOfView to XRRenderState #519
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
Conversation
Updated to take all feedback into account except the last question, which I want to have a bit more discussion on. |
Okay, thought long and hard about this and have a way forward that I'm not 100% thrilled with, but I think it's workable. PR has been updated to take it into account, but here's the TL;DR:
So... does that work for everyone who voiced concerns above? Pinging @NellWaliczek, @klausw, and @blairmacintyre. |
I'm struggling with this approach... What if we added an optional nested "inline" attribute to the |
To clarify... something like this:
|
By the by, it's worth noting that there are a number of places in the WebXR APIs that we pick an arbitrary default value that developers are allowed to attempt to change with no guarantee of success. And in none of those places do we put the word "default". For example, a few off the top of my head.
All this to say.... if we're worried about unnecessarily introducing additional dictionaries or types, then I'd vote for |
Okay, back to |
Okay, after our last-second "wait, that still doesn't make sense" exchange today, I've changed the name once more to Also, to be clear:
|
Pinging @NellWaliczek to re-review |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm good with this change, though I'd like to see us get in the habit of merging the spec changes and the explainer changes at the same time. WDYT?
Yeah, I'll happily add the spec change to this PR. I've been doing that more frequently recently with issues that are more straightforward, but given that I expected (and got) some significant feedback on this one I had wanted to focus on the simplest language first. (As a general rule I'd actually like to start getting into a pattern where the bulk of the text is spec and the explainer becomes more of "Here's a high level overview of the concept and go to |
Okay, spec text is added. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM; one nit.
index.bs
Outdated
|
||
{{XRRenderState/depthNear}} and {{XRRenderState/depthFar}} is used in the computation of the {{XRView/projectionMatrix}} of {{XRView}}s and determines how the values of an {{XRWebGLLayer}} depth buffer are interpreted. {{XRRenderState/depthNear}} MAY be greater than {{XRRenderState/depthFar}}. | ||
|
||
The <dfn attribute for="XRRenderState">inlineVerticalFieldOfView</dfn> attribute defines the default vertical field of view in radians used when computing projection matrices for {{XRSessionMode/inline}} {{XRSession}}s. The projection matrix calculation also takes into account the aspect ratio of the {{XRRenderState/outputContext}}'s {{XRPresentationContext/canvas}}. This value MUST be <code>null</code> for {{XRSessionMode/immersive-vr}} and {{XRSessionMode/immersive-ar}} {{XRSession}}s. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This value MUST be
null
for {{XRSessionMode/immersive-vr}} and {{XRSessionMode/immersive-ar}} {{XRSession}}s.
Let's just use the immersive session property instead of calling out both types.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done
Fixes #272.
Pretty simple feature, based on the feedback from the F2F. It's apparent to me that we're not going to magically come up with a default value that has a good reason behind it, so I plugged 90deg in there just because it's a clean number that's easy to guess and gives reasonable results. Also left it as a single direction that can be specified (vertical) because you can pretty trivially do the math to convert from one to the other and vertical seems to be the value that most developers/game players are used to setting. (This because monitors are traditionally wider than tall and it's easier to get predictable results out of a single vertical FoV when jumping between 4:3 and 16:9 aspect ratios).