KEMBAR78
Simplify available spaces by toji · Pull Request #626 · immersive-web/webxr · GitHub
Skip to content

Conversation

toji
Copy link
Member

@toji toji commented May 3, 2019

/Fixes #625
/Fixes #623

(Happy to split these two out, but it felt like it would be clearer to view
both changes at once.)

Removes the position-disabled reference space from the spec and
explainers. Developers that wish to display the types of content this
reference space supported (primarily 360 media) should instead manually
zero-out the position of the XRView transforms when rendering.

Also consolidates the viewerSpace attribute and the identity reference
space into a single new reference space called viewer. This new
space is functionally equivalent to the previous viewerSpace but
fetched via requestReferenceSpace() with the same guarantee of
availability as identity had previously. All other spaces relate to it
like any other space.

@toji
Copy link
Member Author

toji commented May 6, 2019

I think this also fixes #478.

@toji toji force-pushed the simplify-space branch from 91901a8 to 9d646a4 Compare May 6, 2019 20:43
@toji toji added this to the May 2019 milestone May 6, 2019
@toji toji force-pushed the simplify-space branch from 9d646a4 to dc8df97 Compare May 7, 2019 16:44
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 still want to think one more time to make sure we aren't accidentally removing a use case, but in the meanwhile, here's some feedback...

@toji
Copy link
Member Author

toji commented May 8, 2019

Updated to address all applicable feedback. Please take another look!


### Stationary experiences
A _stationary_ experience is one which does not require the user to move around in space. This includes several categories of experiences that developers are commonly building today, and multiple reference space types are available to address each class of experience. "Standing" experiences can be created with a `floor-level` reference space. "Seated" experiences can be created with an `eye-level` reference space.
A _stationary_ experience is one which does not require the user to move around in space. This includes several categories of experiences that developers are commonly building today, and multiple reference space types are available to address each class of experience. "Standing" experiences can be created with a `floor-level` reference space. "Seated" experiences can be created with an `eye-level` reference space. Orientation-only experiences such as 360 photo/video viewers can also be created with an `eye-level` reference space, though in that case positional data should be ignored in order to display the media properly.
Copy link
Member

Choose a reason for hiding this comment

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

though in that case positional data should be ignored in order to display the media properly.

Is this actually the guidance? Thought it was to render the content on sufficiently far away surrounding geometry....

Copy link
Member Author

Choose a reason for hiding this comment

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

Either approach works, and there's minor pros/cons to each but no so much that it really makes a difference in terms of guidance here.

Copy link
Member

Choose a reason for hiding this comment

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

Then let's say something like this?

Orientation-only experiences such as 360 photo/video viewers can also be created with an eye-level reference space, and in that case one method would be to ignore the positional data in order to display the media properly.

Copy link
Member Author

Choose a reason for hiding this comment

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

Did one better and expanded this into it's own paragraph to give both options and explain why.


### Viewer reference spaces
A _viewer_ reference space tracks the origin of the viewer. This type of reference space is primarily used for creating inline experiences with no tracking information. Instead, developers may use `XRReferenceSpace.originOffset` which is described in the [Application supplied transforms section](#application-supplied-transforms). An example usage of an _viewer_ reference space is a furniture viewer that will use [click-and-drag controls](#click-and-drag-view-controls) to rotate the furniture. It also supports cases where the developer wishes to avoid displaying any type of tracking consent prompt to the user prior while displaying inline content.
A _viewer_ reference space's origin is always at the position and orientation of the viewer device. This type of reference space is primarily used for creating inline experiences with no tracking of the viewer relative to it's physical environment. Instead, developers may use `XRReferenceSpace.originOffset` which is described in the [Application supplied transforms section](#application-supplied-transforms). An example usage of an _viewer_ reference space is a furniture viewer that will use [click-and-drag controls](#click-and-drag-view-controls) to rotate the furniture. It also supports cases where the developer wishes to avoid displaying any type of tracking consent prompt to the user prior while displaying inline content.
Copy link
Member

Choose a reason for hiding this comment

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

XRReferenceSpace.originOffset

Are we planning to fixing the explainer text about originOffset in a separate PR?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yeah, that's a large enough change that I'd feel more comfortable handling it separately from this issue.

Copy link
Member

Choose a reason for hiding this comment

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

Fine by me. Can you file an issue to track that?

Copy link
Member Author

Choose a reason for hiding this comment

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

toji added 6 commits May 9, 2019 13:37
/Fixes #625

Removes the position-disabled reference space from the spec and
explainers. Developers that wish to display the types of content this
reference space supported (primarily 360 media) should instead manually
zero-out the position of the XRView transforms when rendering.
@toji toji force-pushed the simplify-space branch from a42b26f to bac64f7 Compare May 9, 2019 20:37
@toji
Copy link
Member Author

toji commented May 9, 2019

Okay, remainder of Nell's comments are addressed or responded to.

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.

Thanks so much for working through the details of this (significant) simplification! Approving under the assumption that the remaining two minor items of feedback will be addressed :)

@toji toji merged commit 9730cac into master May 9, 2019
@toji toji deleted the simplify-space branch May 10, 2019 17:02
@AdaRoseCannon AdaRoseCannon added ed:explainer Include in newsletter, explainer change ed:spec Include in newsletter, spec change labels Jun 17, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

ed:explainer Include in newsletter, explainer change ed:spec Include in newsletter, spec change

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Does the "position-disabled" reference space still make physical sense? Should identity and viewerSpace be merged?

4 participants