mirror of
https://github.com/servo/servo.git
synced 2025-08-04 21:20:23 +01:00
Compute view matrix from viewer pose
This commit is contained in:
parent
d1d8e97c30
commit
2e48606569
5 changed files with 51 additions and 17 deletions
|
@ -173,6 +173,14 @@ impl VRDisplay {
|
||||||
VRDisplayBinding::Wrap,
|
VRDisplayBinding::Wrap,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn left_eye_params_offset(&self) -> [f32; 3] {
|
||||||
|
self.left_eye_params.get().offset_array()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn right_eye_params_offset(&self) -> [f32; 3] {
|
||||||
|
self.right_eye_params.get().offset_array()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Drop for VRDisplay {
|
impl Drop for VRDisplay {
|
||||||
|
|
|
@ -61,6 +61,10 @@ impl VREyeParameters {
|
||||||
|
|
||||||
eye_parameters
|
eye_parameters
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn offset_array(&self) -> [f32; 3] {
|
||||||
|
self.parameters.borrow().offset
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl VREyeParametersMethods for VREyeParameters {
|
impl VREyeParametersMethods for VREyeParameters {
|
||||||
|
|
|
@ -5,13 +5,11 @@
|
||||||
use crate::dom::bindings::codegen::Bindings::XRFrameBinding;
|
use crate::dom::bindings::codegen::Bindings::XRFrameBinding;
|
||||||
use crate::dom::bindings::codegen::Bindings::XRFrameBinding::XRFrameMethods;
|
use crate::dom::bindings::codegen::Bindings::XRFrameBinding::XRFrameMethods;
|
||||||
use crate::dom::bindings::codegen::Bindings::XRViewBinding::XREye;
|
use crate::dom::bindings::codegen::Bindings::XRViewBinding::XREye;
|
||||||
use crate::dom::bindings::inheritance::Castable;
|
|
||||||
use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
|
use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
|
||||||
use crate::dom::bindings::root::{Dom, DomRoot};
|
use crate::dom::bindings::root::{Dom, DomRoot};
|
||||||
use crate::dom::globalscope::GlobalScope;
|
use crate::dom::globalscope::GlobalScope;
|
||||||
use crate::dom::xrreferencespace::XRReferenceSpace;
|
use crate::dom::xrreferencespace::XRReferenceSpace;
|
||||||
use crate::dom::xrsession::XRSession;
|
use crate::dom::xrsession::XRSession;
|
||||||
use crate::dom::xrstationaryreferencespace::XRStationaryReferenceSpace;
|
|
||||||
use crate::dom::xrview::XRView;
|
use crate::dom::xrview::XRView;
|
||||||
use crate::dom::xrviewerpose::XRViewerPose;
|
use crate::dom::xrviewerpose::XRViewerPose;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
|
@ -55,16 +53,21 @@ impl XRFrameMethods for XRFrame {
|
||||||
|
|
||||||
/// https://immersive-web.github.io/webxr/#dom-xrframe-getviewerpose
|
/// https://immersive-web.github.io/webxr/#dom-xrframe-getviewerpose
|
||||||
fn GetViewerPose(&self, reference: &XRReferenceSpace) -> Option<DomRoot<XRViewerPose>> {
|
fn GetViewerPose(&self, reference: &XRReferenceSpace) -> Option<DomRoot<XRViewerPose>> {
|
||||||
if let Some(_) = reference.downcast::<XRStationaryReferenceSpace>() {
|
let pose = reference.get_viewer_pose(&self.data);
|
||||||
// For 3DOF devices all three kinds of reference spaces are identical
|
let left = XRView::new(
|
||||||
// FIXME(#23070, Manishearth) support originOffset
|
&self.global(),
|
||||||
let left = XRView::new(&self.global(), &self.session, XREye::Left, &self.data);
|
&self.session,
|
||||||
let right = XRView::new(&self.global(), &self.session, XREye::Right, &self.data);
|
XREye::Left,
|
||||||
Some(XRViewerPose::new(&self.global(), &left, &right))
|
&pose,
|
||||||
} else {
|
&self.data,
|
||||||
// FIXME(#23070, Manishearth) support identity reference spaces
|
);
|
||||||
// depends on https://github.com/immersive-web/webxr/issues/565
|
let right = XRView::new(
|
||||||
None
|
&self.global(),
|
||||||
}
|
&self.session,
|
||||||
|
XREye::Right,
|
||||||
|
&pose,
|
||||||
|
&self.data,
|
||||||
|
);
|
||||||
|
Some(XRViewerPose::new(&self.global(), &left, &right))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,10 @@ impl XRSession {
|
||||||
self.display.xr_present(self, None, Some(p));
|
self.display.xr_present(self, None, Some(p));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn display(&self) -> &VRDisplay {
|
||||||
|
&self.display
|
||||||
|
}
|
||||||
|
|
||||||
pub fn set_layer(&self, layer: &XRLayer) {
|
pub fn set_layer(&self, layer: &XRLayer) {
|
||||||
self.base_layer.set(Some(layer))
|
self.base_layer.set(Some(layer))
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ use crate::dom::globalscope::GlobalScope;
|
||||||
use crate::dom::vrframedata::create_typed_array;
|
use crate::dom::vrframedata::create_typed_array;
|
||||||
use crate::dom::xrsession::XRSession;
|
use crate::dom::xrsession::XRSession;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
|
use euclid::Transform3D;
|
||||||
use js::jsapi::{Heap, JSContext, JSObject};
|
use js::jsapi::{Heap, JSContext, JSObject};
|
||||||
use std::ptr::NonNull;
|
use std::ptr::NonNull;
|
||||||
use webvr_traits::WebVRFrameData;
|
use webvr_traits::WebVRFrameData;
|
||||||
|
@ -39,6 +40,7 @@ impl XRView {
|
||||||
global: &GlobalScope,
|
global: &GlobalScope,
|
||||||
session: &XRSession,
|
session: &XRSession,
|
||||||
eye: XREye,
|
eye: XREye,
|
||||||
|
pose: &Transform3D<f64>,
|
||||||
data: &WebVRFrameData,
|
data: &WebVRFrameData,
|
||||||
) -> DomRoot<XRView> {
|
) -> DomRoot<XRView> {
|
||||||
let ret = reflect_dom_object(
|
let ret = reflect_dom_object(
|
||||||
|
@ -47,16 +49,29 @@ impl XRView {
|
||||||
XRViewBinding::Wrap,
|
XRViewBinding::Wrap,
|
||||||
);
|
);
|
||||||
|
|
||||||
let (proj, view) = if eye == XREye::Left {
|
let vr_display = session.display();
|
||||||
(&data.left_projection_matrix, &data.left_view_matrix)
|
|
||||||
|
// XXXManishearth compute and cache projection matrices on the Display
|
||||||
|
let (proj, offset) = if eye == XREye::Left {
|
||||||
|
(
|
||||||
|
&data.left_projection_matrix,
|
||||||
|
vr_display.left_eye_params_offset(),
|
||||||
|
)
|
||||||
} else {
|
} else {
|
||||||
(&data.right_projection_matrix, &data.right_view_matrix)
|
(
|
||||||
|
&data.right_projection_matrix,
|
||||||
|
vr_display.right_eye_params_offset(),
|
||||||
|
)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let offset =
|
||||||
|
Transform3D::create_translation(offset[0] as f64, offset[1] as f64, offset[2] as f64);
|
||||||
|
let view = pose.post_mul(&offset).cast().to_column_major_array();
|
||||||
|
|
||||||
let cx = global.get_cx();
|
let cx = global.get_cx();
|
||||||
unsafe {
|
unsafe {
|
||||||
create_typed_array(cx, proj, &ret.proj);
|
create_typed_array(cx, proj, &ret.proj);
|
||||||
create_typed_array(cx, view, &ret.view);
|
create_typed_array(cx, &view, &ret.view);
|
||||||
}
|
}
|
||||||
ret
|
ret
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue