mirror of
https://github.com/servo/servo.git
synced 2025-08-05 21:50:18 +01:00
Hook XRInputSourceArray into XRSession
This commit is contained in:
parent
868e5cbd62
commit
8ae1c2e0ad
3 changed files with 33 additions and 37 deletions
|
@ -16,31 +16,26 @@ callback XRFrameRequestCallback = void (DOMHighResTimeStamp time, XRFrame frame)
|
||||||
interface XRSession : EventTarget {
|
interface XRSession : EventTarget {
|
||||||
// // Attributes
|
// // Attributes
|
||||||
readonly attribute XRSessionMode mode;
|
readonly attribute XRSessionMode mode;
|
||||||
// readonly attribute XRPresentationContext outputContext;
|
|
||||||
readonly attribute XREnvironmentBlendMode environmentBlendMode;
|
readonly attribute XREnvironmentBlendMode environmentBlendMode;
|
||||||
|
|
||||||
readonly attribute XRRenderState renderState;
|
// readonly attribute XRVisibilityState visibilityState;
|
||||||
|
[SameObject] readonly attribute XRRenderState renderState;
|
||||||
|
[SameObject] readonly attribute XRInputSourceArray inputSources;
|
||||||
|
|
||||||
// // Methods
|
// // Methods
|
||||||
|
[Throws] void updateRenderState(optional XRRenderStateInit state = {});
|
||||||
Promise<XRReferenceSpace> requestReferenceSpace(XRReferenceSpaceType type);
|
Promise<XRReferenceSpace> requestReferenceSpace(XRReferenceSpaceType type);
|
||||||
|
|
||||||
// workaround until we have FrozenArray
|
|
||||||
// see https://github.com/servo/servo/issues/10427#issuecomment-449593626
|
|
||||||
// FrozenArray<XRInputSource> getInputSources();
|
|
||||||
sequence<XRInputSource> getInputSources();
|
|
||||||
|
|
||||||
[Throws] void updateRenderState(optional XRRenderStateInit state = {});
|
|
||||||
long requestAnimationFrame(XRFrameRequestCallback callback);
|
long requestAnimationFrame(XRFrameRequestCallback callback);
|
||||||
void cancelAnimationFrame(long handle);
|
void cancelAnimationFrame(long handle);
|
||||||
|
|
||||||
Promise<void> end();
|
Promise<void> end();
|
||||||
|
|
||||||
// // Events
|
// // Events
|
||||||
// attribute EventHandler onblur;
|
|
||||||
// attribute EventHandler onfocus;
|
|
||||||
attribute EventHandler onend;
|
attribute EventHandler onend;
|
||||||
attribute EventHandler onselect;
|
attribute EventHandler onselect;
|
||||||
// attribute EventHandler oninputsourceschange;
|
// attribute EventHandler oninputsourceschange;
|
||||||
attribute EventHandler onselectstart;
|
attribute EventHandler onselectstart;
|
||||||
attribute EventHandler onselectend;
|
attribute EventHandler onselectend;
|
||||||
|
// attribute EventHandler onvisibilitychange;
|
||||||
};
|
};
|
||||||
|
|
|
@ -11,6 +11,7 @@ use crate::dom::globalscope::GlobalScope;
|
||||||
use crate::dom::xrinputsource::XRInputSource;
|
use crate::dom::xrinputsource::XRInputSource;
|
||||||
use crate::dom::xrsession::XRSession;
|
use crate::dom::xrsession::XRSession;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
|
use webxr_api::InputId;
|
||||||
|
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
pub struct XRInputSourceArray {
|
pub struct XRInputSourceArray {
|
||||||
|
@ -46,6 +47,14 @@ impl XRInputSourceArray {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn find(&self, id: InputId) -> Option<DomRoot<XRInputSource>> {
|
||||||
|
self.input_sources
|
||||||
|
.borrow()
|
||||||
|
.iter()
|
||||||
|
.find(|x| x.id() == id)
|
||||||
|
.map(|x| DomRoot::from_ref(&**x))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl XRInputSourceArrayMethods for XRInputSourceArray {
|
impl XRInputSourceArrayMethods for XRInputSourceArray {
|
||||||
|
|
|
@ -32,7 +32,7 @@ use crate::dom::node::NodeDamage;
|
||||||
use crate::dom::promise::Promise;
|
use crate::dom::promise::Promise;
|
||||||
use crate::dom::webglframebuffer::WebGLFramebufferAttachmentRoot;
|
use crate::dom::webglframebuffer::WebGLFramebufferAttachmentRoot;
|
||||||
use crate::dom::xrframe::XRFrame;
|
use crate::dom::xrframe::XRFrame;
|
||||||
use crate::dom::xrinputsource::XRInputSource;
|
use crate::dom::xrinputsourcearray::XRInputSourceArray;
|
||||||
use crate::dom::xrinputsourceevent::XRInputSourceEvent;
|
use crate::dom::xrinputsourceevent::XRInputSourceEvent;
|
||||||
use crate::dom::xrreferencespace::XRReferenceSpace;
|
use crate::dom::xrreferencespace::XRReferenceSpace;
|
||||||
use crate::dom::xrrenderstate::XRRenderState;
|
use crate::dom::xrrenderstate::XRRenderState;
|
||||||
|
@ -68,7 +68,7 @@ pub struct XRSession {
|
||||||
raf_callback_list: DomRefCell<Vec<(i32, Option<Rc<XRFrameRequestCallback>>)>>,
|
raf_callback_list: DomRefCell<Vec<(i32, Option<Rc<XRFrameRequestCallback>>)>>,
|
||||||
#[ignore_malloc_size_of = "defined in ipc-channel"]
|
#[ignore_malloc_size_of = "defined in ipc-channel"]
|
||||||
raf_sender: DomRefCell<Option<IpcSender<(f64, Frame)>>>,
|
raf_sender: DomRefCell<Option<IpcSender<(f64, Frame)>>>,
|
||||||
input_sources: DomRefCell<Vec<Dom<XRInputSource>>>,
|
input_sources: Dom<XRInputSourceArray>,
|
||||||
// Any promises from calling end()
|
// Any promises from calling end()
|
||||||
#[ignore_malloc_size_of = "promises are hard"]
|
#[ignore_malloc_size_of = "promises are hard"]
|
||||||
end_promises: DomRefCell<Vec<Rc<Promise>>>,
|
end_promises: DomRefCell<Vec<Rc<Promise>>>,
|
||||||
|
@ -77,7 +77,11 @@ pub struct XRSession {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl XRSession {
|
impl XRSession {
|
||||||
fn new_inherited(session: Session, render_state: &XRRenderState) -> XRSession {
|
fn new_inherited(
|
||||||
|
session: Session,
|
||||||
|
render_state: &XRRenderState,
|
||||||
|
input_sources: &XRInputSourceArray,
|
||||||
|
) -> XRSession {
|
||||||
XRSession {
|
XRSession {
|
||||||
eventtarget: EventTarget::new_inherited(),
|
eventtarget: EventTarget::new_inherited(),
|
||||||
base_layer: Default::default(),
|
base_layer: Default::default(),
|
||||||
|
@ -92,7 +96,7 @@ impl XRSession {
|
||||||
next_raf_id: Cell::new(0),
|
next_raf_id: Cell::new(0),
|
||||||
raf_callback_list: DomRefCell::new(vec![]),
|
raf_callback_list: DomRefCell::new(vec![]),
|
||||||
raf_sender: DomRefCell::new(None),
|
raf_sender: DomRefCell::new(None),
|
||||||
input_sources: DomRefCell::new(vec![]),
|
input_sources: Dom::from_ref(input_sources),
|
||||||
end_promises: DomRefCell::new(vec![]),
|
end_promises: DomRefCell::new(vec![]),
|
||||||
ended: Cell::new(false),
|
ended: Cell::new(false),
|
||||||
}
|
}
|
||||||
|
@ -100,20 +104,17 @@ impl XRSession {
|
||||||
|
|
||||||
pub fn new(global: &GlobalScope, session: Session) -> DomRoot<XRSession> {
|
pub fn new(global: &GlobalScope, session: Session) -> DomRoot<XRSession> {
|
||||||
let render_state = XRRenderState::new(global, 0.1, 1000.0, None);
|
let render_state = XRRenderState::new(global, 0.1, 1000.0, None);
|
||||||
|
let input_sources = XRInputSourceArray::new(global);
|
||||||
let ret = reflect_dom_object(
|
let ret = reflect_dom_object(
|
||||||
Box::new(XRSession::new_inherited(session, &render_state)),
|
Box::new(XRSession::new_inherited(
|
||||||
|
session,
|
||||||
|
&render_state,
|
||||||
|
&input_sources,
|
||||||
|
)),
|
||||||
global,
|
global,
|
||||||
XRSessionBinding::Wrap,
|
XRSessionBinding::Wrap,
|
||||||
);
|
);
|
||||||
{
|
input_sources.set_initial_inputs(&ret);
|
||||||
let mut input_sources = ret.input_sources.borrow_mut();
|
|
||||||
for info in ret.session.borrow().initial_inputs() {
|
|
||||||
// XXXManishearth we should be able to listen for updates
|
|
||||||
// to the input sources
|
|
||||||
let input = XRInputSource::new(global, &ret, *info);
|
|
||||||
input_sources.push(Dom::from_ref(&input));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ret.attach_event_handler();
|
ret.attach_event_handler();
|
||||||
ret
|
ret
|
||||||
}
|
}
|
||||||
|
@ -173,12 +174,7 @@ impl XRSession {
|
||||||
},
|
},
|
||||||
XREvent::Select(input, kind, frame) => {
|
XREvent::Select(input, kind, frame) => {
|
||||||
// https://immersive-web.github.io/webxr/#primary-action
|
// https://immersive-web.github.io/webxr/#primary-action
|
||||||
let source = self
|
let source = self.input_sources.find(input);
|
||||||
.input_sources
|
|
||||||
.borrow_mut()
|
|
||||||
.iter()
|
|
||||||
.find(|s| s.id() == input)
|
|
||||||
.map(|x| DomRoot::from_ref(&**x));
|
|
||||||
if let Some(source) = source {
|
if let Some(source) = source {
|
||||||
let frame = XRFrame::new(&self.global(), self, frame);
|
let frame = XRFrame::new(&self.global(), self, frame);
|
||||||
frame.set_active(true);
|
frame.set_active(true);
|
||||||
|
@ -438,13 +434,9 @@ impl XRSessionMethods for XRSession {
|
||||||
p
|
p
|
||||||
}
|
}
|
||||||
|
|
||||||
/// https://immersive-web.github.io/webxr/#dom-xrsession-getinputsources
|
/// https://immersive-web.github.io/webxr/#dom-xrsession-inputsources
|
||||||
fn GetInputSources(&self) -> Vec<DomRoot<XRInputSource>> {
|
fn InputSources(&self) -> DomRoot<XRInputSourceArray> {
|
||||||
self.input_sources
|
DomRoot::from_ref(&*self.input_sources)
|
||||||
.borrow()
|
|
||||||
.iter()
|
|
||||||
.map(|x| DomRoot::from_ref(&**x))
|
|
||||||
.collect()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// https://immersive-web.github.io/webxr/#dom-xrsession-end
|
/// https://immersive-web.github.io/webxr/#dom-xrsession-end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue