mirror of
https://github.com/servo/servo.git
synced 2025-08-04 21:20:23 +01:00
Add XRRay.matrix
This commit is contained in:
parent
e7ba4e5a47
commit
7dd2a71d6d
4 changed files with 43 additions and 10 deletions
|
@ -10,5 +10,5 @@ interface XRRay {
|
||||||
constructor(XRRigidTransform transform);
|
constructor(XRRigidTransform transform);
|
||||||
[SameObject] readonly attribute DOMPointReadOnly origin;
|
[SameObject] readonly attribute DOMPointReadOnly origin;
|
||||||
[SameObject] readonly attribute DOMPointReadOnly direction;
|
[SameObject] readonly attribute DOMPointReadOnly direction;
|
||||||
// [SameObject] readonly attribute Float32Array matrix;
|
[SameObject] readonly attribute Float32Array matrix;
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,12 +6,16 @@ use crate::dom::bindings::codegen::Bindings::DOMPointBinding::DOMPointInit;
|
||||||
use crate::dom::bindings::codegen::Bindings::XRRayBinding::XRRayMethods;
|
use crate::dom::bindings::codegen::Bindings::XRRayBinding::XRRayMethods;
|
||||||
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::DomRoot;
|
use crate::dom::bindings::root::DomRoot;
|
||||||
|
use crate::dom::bindings::utils::create_typed_array;
|
||||||
use crate::dom::dompointreadonly::DOMPointReadOnly;
|
use crate::dom::dompointreadonly::DOMPointReadOnly;
|
||||||
use crate::dom::globalscope::GlobalScope;
|
use crate::dom::globalscope::GlobalScope;
|
||||||
use crate::dom::window::Window;
|
use crate::dom::window::Window;
|
||||||
use crate::dom::xrrigidtransform::XRRigidTransform;
|
use crate::dom::xrrigidtransform::XRRigidTransform;
|
||||||
|
use crate::script_runtime::JSContext;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
use euclid::Vector3D;
|
use euclid::{Angle, RigidTransform3D, Rotation3D, Vector3D};
|
||||||
|
use js::jsapi::{Heap, JSObject};
|
||||||
|
use std::ptr::NonNull;
|
||||||
use webxr_api::{ApiSpace, Ray};
|
use webxr_api::{ApiSpace, Ray};
|
||||||
|
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
|
@ -19,6 +23,8 @@ pub struct XRRay {
|
||||||
reflector_: Reflector,
|
reflector_: Reflector,
|
||||||
#[ignore_malloc_size_of = "defined in webxr"]
|
#[ignore_malloc_size_of = "defined in webxr"]
|
||||||
ray: Ray<ApiSpace>,
|
ray: Ray<ApiSpace>,
|
||||||
|
#[ignore_malloc_size_of = "defined in mozjs"]
|
||||||
|
matrix: Heap<*mut JSObject>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl XRRay {
|
impl XRRay {
|
||||||
|
@ -26,6 +32,7 @@ impl XRRay {
|
||||||
XRRay {
|
XRRay {
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
ray,
|
ray,
|
||||||
|
matrix: Heap::default(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,4 +89,38 @@ impl XRRayMethods for XRRay {
|
||||||
0.,
|
0.,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// https://immersive-web.github.io/hit-test/#dom-xrray-matrix
|
||||||
|
fn Matrix(&self, _cx: JSContext) -> NonNull<JSObject> {
|
||||||
|
// https://immersive-web.github.io/hit-test/#xrray-obtain-the-matrix
|
||||||
|
// Step 1
|
||||||
|
if self.matrix.get().is_null() {
|
||||||
|
let cx = self.global().get_cx();
|
||||||
|
// Step 2
|
||||||
|
let z = Vector3D::new(0., 0., -1.);
|
||||||
|
// Step 3
|
||||||
|
let axis = z.cross(self.ray.direction);
|
||||||
|
// Step 4
|
||||||
|
let cos_angle = z.dot(self.ray.direction);
|
||||||
|
// Step 5
|
||||||
|
let rotation = if cos_angle > -1. && cos_angle < 1. {
|
||||||
|
Rotation3D::around_axis(axis, Angle::radians(cos_angle.acos()))
|
||||||
|
} else if cos_angle == -1. {
|
||||||
|
let axis = Vector3D::new(1., 0., 0.);
|
||||||
|
Rotation3D::around_axis(axis, Angle::radians(cos_angle.acos()))
|
||||||
|
} else {
|
||||||
|
Rotation3D::identity()
|
||||||
|
};
|
||||||
|
// Step 6
|
||||||
|
let translation = self.ray.origin;
|
||||||
|
// Step 7
|
||||||
|
// According to the spec all matrices are column-major,
|
||||||
|
// however euclid uses row vectors so we use .to_row_major_array()
|
||||||
|
let arr = RigidTransform3D::new(rotation, translation)
|
||||||
|
.to_transform()
|
||||||
|
.to_row_major_array();
|
||||||
|
create_typed_array(cx, &arr, &self.matrix);
|
||||||
|
}
|
||||||
|
NonNull::new(self.matrix.get()).unwrap()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
[xrRay_constructor.https.html]
|
|
||||||
[XRRay constructors work]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
|
@ -1,4 +0,0 @@
|
||||||
[xrRay_matrix.https.html]
|
|
||||||
[XRRay matrix works]
|
|
||||||
expected: FAIL
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue