KEMBAR78
Add inlineVerticalFieldOfView to XRRenderState by toji · Pull Request #519 · immersive-web/webxr · GitHub
Skip to content

Conversation

toji
Copy link
Member

@toji toji commented Feb 12, 2019

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).

@toji
Copy link
Member Author

toji commented Feb 19, 2019

Updated to take all feedback into account except the last question, which I want to have a bit more discussion on.

@NellWaliczek NellWaliczek added this to the Next Working Draft milestone Mar 2, 2019
@NellWaliczek NellWaliczek added the agenda Request discussion in the next telecon/FTF label Mar 25, 2019
@toji
Copy link
Member Author

toji commented Mar 27, 2019

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:

  • attrib name is now defaultFieldOfView. defaultInlineVerticalFieldOfView would be more accurate but... no.
  • The dictionary value is non-nullable, but the read only attribute on the XRRenderState is nullable. This is slightly weird, but makes sense in terms of usage.
  • If the session is immersive, the defaultFieldOfView must be null, because it should always be using a physical value of some sort. Attempting to set a defaultFieldOfView will throw an exception.
  • If the session is inline the defaultFieldOfView will report the default value, not the one currently being used. You can try and derive that from the projection matrices if you really need it.

So... does that work for everyone who voiced concerns above? Pinging @NellWaliczek, @klausw, and @blairmacintyre.

@toji toji removed agenda Request discussion in the next telecon/FTF labels Mar 29, 2019
@NellWaliczek
Copy link
Member

I'm struggling with this approach... What if we added an optional nested "inline" attribute to the XRRenderState... So for an immersive session XRRenderState.inline would be null, but for an inline session it would be non-null with a child verticalFieldOfView?

@NellWaliczek
Copy link
Member

NellWaliczek commented Apr 4, 2019

To clarify... something like this:

dictionary XRRenderStateInit {
  double depthNear;
  double depthFar;
  XRInlineRenderStateInit? inline;
  XRLayer? baseLayer;
  XRPresentationContext? outputContext
};

dictionary XRInlineRenderStateInit {
  double verticalFieldOfView;
};

[SecureContext, Exposed=Window] interface XRRenderState {
  readonly attribute double depthNear;
  readonly attribute double depthFar;
  readonly attribute XRInlineRenderState? inline;
  readonly attribute XRLayer? baseLayer;
  readonly attribute XRPresentationContext? outputContext;
};


[SecureContext, Exposed=Window] interface XRInlineRenderState {
  readonly attribute double verticalFieldOfView;
};

@NellWaliczek
Copy link
Member

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.

  • XRWebGLLayerInit.ignoreDepthValues defaults to false and true may not be accepted.
  • XRWebGLLayerInit.framebufferScaleFactor defaults to 1 and it's possible other values won't be accepted.
  • XRWebGLLayer.requestViewportScaling() defaults to 1 and there's no guarantee other values will be accepted.

All this to say.... if we're worried about unnecessarily introducing additional dictionaries or types, then I'd vote for verticalFieldOfView and have the promise reject if it's not allowed.

@toji
Copy link
Member Author

toji commented Apr 5, 2019

Okay, back to verticalFieldOfView then! PTAL

@toji
Copy link
Member Author

toji commented Apr 5, 2019

Okay, after our last-second "wait, that still doesn't make sense" exchange today, I've changed the name once more to inlineVerticalFieldOfView.

Also, to be clear:

  • Name includes "inline" now because it will only ever apply to inline sessions.
  • The interface value is nullable because we don't want to report anything on immersive sessions where it could be misinterpreted as the actual FOV.
  • The dictionary value is not nullable, because there's no circumstance under which you should ever need to pass a null. (You will get an exception for passing one on immersive sessions and for inline you shouldn't set it to null ever.)
  • Yes, this is slightly weird.
  • One workaround would be to state that setting it to null for an inline session is equivalent to setting it back to the default (90deg), but given that the default is static I don't see much use for that mechanism.

@toji
Copy link
Member Author

toji commented Apr 12, 2019

Pinging @NellWaliczek to re-review

Copy link
Member

@NellWaliczek NellWaliczek left a 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?

@toji
Copy link
Member Author

toji commented Apr 16, 2019

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 this link in the spec for more details.")

@toji toji changed the title Add verticalFieldOfView to XRRenderState Add inlineVerticalFieldOfView to XRRenderState Apr 16, 2019
@toji
Copy link
Member Author

toji commented Apr 16, 2019

Okay, spec text is added.

Copy link
Member

@NellWaliczek NellWaliczek left a 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.
Copy link
Member

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.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done

@toji toji merged commit 595aa0e into master Apr 16, 2019
@toji toji deleted the inline-fov branch April 16, 2019 18:33
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Default FoV for magic window canvases

4 participants