diff options
author | Manish Goregaokar <manishsmail@gmail.com> | 2019-10-07 17:20:14 -0700 |
---|---|---|
committer | Manish Goregaokar <manishsmail@gmail.com> | 2019-10-09 14:00:03 -0700 |
commit | c521d8ec013c5cdd35dd2986c81675b8eb9f07e7 (patch) | |
tree | 02c642aebeadd446aa009c5108692716a8a3db93 /components/script/dom/xrspace.rs | |
parent | 0a745aaa44755c0bf5aa0cc112a526b89a14faca (diff) | |
download | servo-c521d8ec013c5cdd35dd2986c81675b8eb9f07e7.tar.gz servo-c521d8ec013c5cdd35dd2986c81675b8eb9f07e7.zip |
Support grip spaces in WebXR
Diffstat (limited to 'components/script/dom/xrspace.rs')
-rw-r--r-- | components/script/dom/xrspace.rs | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/components/script/dom/xrspace.rs b/components/script/dom/xrspace.rs index ce68e786927..29d81fa6afe 100644 --- a/components/script/dom/xrspace.rs +++ b/components/script/dom/xrspace.rs @@ -19,6 +19,8 @@ pub struct XRSpace { eventtarget: EventTarget, session: Dom<XRSession>, input_source: MutNullableDom<XRInputSource>, + /// If we're an input space, are we an aim space or a grip space? + is_grip_space: bool, } impl XRSpace { @@ -27,14 +29,20 @@ impl XRSpace { eventtarget: EventTarget::new_inherited(), session: Dom::from_ref(session), input_source: Default::default(), + is_grip_space: false, } } - fn new_inputspace_inner(session: &XRSession, input: &XRInputSource) -> XRSpace { + fn new_inputspace_inner( + session: &XRSession, + input: &XRInputSource, + is_grip_space: bool, + ) -> XRSpace { XRSpace { eventtarget: EventTarget::new_inherited(), session: Dom::from_ref(session), input_source: MutNullableDom::new(Some(input)), + is_grip_space, } } @@ -42,9 +50,10 @@ impl XRSpace { global: &GlobalScope, session: &XRSession, input: &XRInputSource, + is_grip_space: bool, ) -> DomRoot<XRSpace> { reflect_dom_object( - Box::new(XRSpace::new_inputspace_inner(session, input)), + Box::new(XRSpace::new_inputspace_inner(session, input, is_grip_space)), global, XRSpaceBinding::Wrap, ) @@ -72,7 +81,11 @@ impl XRSpace { .iter() .find(|i| i.id == id) .expect("no input found"); - frame.target_ray_origin.map(cast_transform) + if self.is_grip_space { + frame.grip_origin.map(cast_transform) + } else { + frame.target_ray_origin.map(cast_transform) + } } else { unreachable!() } |