/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ use dom_struct::dom_struct; use ipc_channel::ipc::IpcSender; use webxr_api::{ Handedness, InputId, MockDeviceMsg, MockInputMsg, SelectEvent, SelectKind, TargetRayMode, }; use crate::dom::bindings::codegen::Bindings::FakeXRDeviceBinding::FakeXRRigidTransformInit; use crate::dom::bindings::codegen::Bindings::FakeXRInputControllerBinding::FakeXRInputControllerMethods; use crate::dom::bindings::codegen::Bindings::XRInputSourceBinding::{ XRHandedness, XRTargetRayMode, }; use crate::dom::bindings::error::Fallible; use crate::dom::bindings::reflector::{reflect_dom_object, Reflector}; use crate::dom::bindings::root::DomRoot; use crate::dom::bindings::str::DOMString; use crate::dom::fakexrdevice::get_origin; use crate::dom::globalscope::GlobalScope; #[dom_struct] pub struct FakeXRInputController { reflector: Reflector, #[ignore_malloc_size_of = "defined in ipc-channel"] #[no_trace] sender: IpcSender, #[ignore_malloc_size_of = "defined in webxr-api"] #[no_trace] id: InputId, } impl FakeXRInputController { pub fn new_inherited(sender: IpcSender, id: InputId) -> FakeXRInputController { FakeXRInputController { reflector: Reflector::new(), sender, id, } } pub fn new( global: &GlobalScope, sender: IpcSender, id: InputId, ) -> DomRoot { reflect_dom_object( Box::new(FakeXRInputController::new_inherited(sender, id)), global, ) } fn send_message(&self, msg: MockInputMsg) { let _ = self .sender .send(MockDeviceMsg::MessageInputSource(self.id, msg)); } } impl FakeXRInputControllerMethods for FakeXRInputController { /// fn SetPointerOrigin(&self, origin: &FakeXRRigidTransformInit, _emulated: bool) -> Fallible<()> { self.send_message(MockInputMsg::SetPointerOrigin(Some(get_origin(origin)?))); Ok(()) } /// fn SetGripOrigin(&self, origin: &FakeXRRigidTransformInit, _emulated: bool) -> Fallible<()> { self.send_message(MockInputMsg::SetGripOrigin(Some(get_origin(origin)?))); Ok(()) } /// fn ClearGripOrigin(&self) { self.send_message(MockInputMsg::SetGripOrigin(None)) } /// fn Disconnect(&self) { self.send_message(MockInputMsg::Disconnect) } /// fn Reconnect(&self) { self.send_message(MockInputMsg::Reconnect) } /// fn StartSelection(&self) { self.send_message(MockInputMsg::TriggerSelect( SelectKind::Select, SelectEvent::Start, )) } /// fn EndSelection(&self) { self.send_message(MockInputMsg::TriggerSelect( SelectKind::Select, SelectEvent::End, )) } /// fn SimulateSelect(&self) { self.send_message(MockInputMsg::TriggerSelect( SelectKind::Select, SelectEvent::Select, )) } /// fn SetHandedness(&self, handedness: XRHandedness) { let h = match handedness { XRHandedness::None => Handedness::None, XRHandedness::Left => Handedness::Left, XRHandedness::Right => Handedness::Right, }; self.send_message(MockInputMsg::SetHandedness(h)); } /// fn SetTargetRayMode(&self, target_ray_mode: XRTargetRayMode) { let t = match target_ray_mode { XRTargetRayMode::Gaze => TargetRayMode::Gaze, XRTargetRayMode::Tracked_pointer => TargetRayMode::TrackedPointer, XRTargetRayMode::Screen => TargetRayMode::Screen, }; self.send_message(MockInputMsg::SetTargetRayMode(t)); } /// fn SetProfiles(&self, profiles: Vec) { let t = profiles.into_iter().map(String::from).collect(); self.send_message(MockInputMsg::SetProfiles(t)); } }