aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/xrview.rs
diff options
context:
space:
mode:
authorManish Goregaokar <manishsmail@gmail.com>2019-07-08 17:17:13 -0700
committerManish Goregaokar <manishsmail@gmail.com>2019-07-11 11:12:59 -0700
commit8780edb16563ac7d519091023a9ecf894c21fd0f (patch)
tree0768b81fc7feaadbe8351d187335dfe87790e313 /components/script/dom/xrview.rs
parent104a712a28beef693d727170bf25684bb618e5aa (diff)
downloadservo-8780edb16563ac7d519091023a9ecf894c21fd0f.tar.gz
servo-8780edb16563ac7d519091023a9ecf894c21fd0f.zip
Hook webxr data into XRFrame/XRView/XRSpace
Diffstat (limited to 'components/script/dom/xrview.rs')
-rw-r--r--components/script/dom/xrview.rs27
1 files changed, 9 insertions, 18 deletions
diff --git a/components/script/dom/xrview.rs b/components/script/dom/xrview.rs
index bac9e3612a1..122ba83fbbf 100644
--- a/components/script/dom/xrview.rs
+++ b/components/script/dom/xrview.rs
@@ -9,12 +9,11 @@ use crate::dom::bindings::root::{Dom, DomRoot};
use crate::dom::globalscope::GlobalScope;
use crate::dom::vrframedata::create_typed_array;
use crate::dom::xrrigidtransform::XRRigidTransform;
-use crate::dom::xrsession::XRSession;
+use crate::dom::xrsession::{cast_transform, ApiRigidTransform, XRSession};
use dom_struct::dom_struct;
-use euclid::RigidTransform3D;
use js::jsapi::{Heap, JSContext, JSObject};
use std::ptr::NonNull;
-use webvr_traits::WebVRFrameData;
+use webxr_api::View;
#[dom_struct]
pub struct XRView {
@@ -41,25 +40,15 @@ impl XRView {
}
#[allow(unsafe_code)]
- pub fn new(
+ pub fn new<V: Copy>(
global: &GlobalScope,
session: &XRSession,
+ view: &View<V>,
eye: XREye,
- pose: &RigidTransform3D<f64>,
- data: &WebVRFrameData,
+ pose: &ApiRigidTransform,
) -> DomRoot<XRView> {
// XXXManishearth compute and cache projection matrices on the Display
- let (proj, offset) = if eye == XREye::Left {
- (
- &data.left_projection_matrix,
- session.left_eye_params_offset(),
- )
- } else {
- (
- &data.right_projection_matrix,
- session.right_eye_params_offset(),
- )
- };
+ let offset = cast_transform(view.transform);
let transform = pose.post_mul(&offset.into());
let transform = XRRigidTransform::new(global, transform);
@@ -70,9 +59,11 @@ impl XRView {
XRViewBinding::Wrap,
);
+ // row_major since euclid uses row vectors
+ let proj = view.projection.to_row_major_array();
let cx = global.get_cx();
unsafe {
- create_typed_array(cx, proj, &ret.proj);
+ create_typed_array(cx, &proj, &ret.proj);
}
ret
}