This repository has been archived by the owner on Jul 10, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 23
/
vr_display.rs
59 lines (45 loc) · 2.14 KB
/
vr_display.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
use {VRDisplayData, VRFramebuffer, VRFramebufferAttributes, VRFrameData, VRLayer};
use std::sync::Arc;
use std::cell::RefCell;
pub type VRDisplayPtr = Arc<RefCell<VRDisplay>>;
/// The VRDisplay traits forms the base of all VR device implementations
pub trait VRDisplay: Send + Sync {
/// Returns unique device identifier
fn id(&self) -> u32;
/// Returns the current display data.
fn data(&self) -> VRDisplayData;
/// Returns the immediate VRFrameData of the HMD
/// Should be used when not presenting to the device.
fn immediate_frame_data(&self, near_z: f64, far_z: f64) -> VRFrameData;
/// Returns the synced VRFrameData to render the current frame.
/// Should be used when presenting to the device.
/// sync_poses must have been called before this call.
fn synced_frame_data(&self, next: f64, far_z: f64) -> VRFrameData;
/// Resets the pose for this display
fn reset_pose(&mut self);
/// Synchronization point to keep in step with the HMD
/// Returns VRFrameData to be used in the next render frame
/// Must be called in the render thread, before doing any work
fn sync_poses(&mut self);
/// Binds the framebuffer to directly render to the HDM
/// Must be called in the render thread, before doing any work
fn bind_framebuffer(&mut self, index: u32);
/// Returns the available FBOs that must be used to render to all eyes
/// Must be called in the render thread, before doing any work
fn get_framebuffers(&self) -> Vec<VRFramebuffer>;
/// Renders a VRLayer from a external texture
/// Must be called in the render thread
fn render_layer(&mut self, layer: &VRLayer);
/// Submits frame to the display
/// Must be called in the render thread
fn submit_frame(&mut self);
/// Hint to indicate that we are going to start sending frames to the device
fn start_present(&mut self, _attributes: Option<VRFramebufferAttributes>) {}
/// Hint to indicate that we are going to stop sending frames to the device
fn stop_present(&mut self) {}
}
impl PartialEq for VRDisplay {
fn eq(&self, other: &VRDisplay) -> bool {
self.id() == other.id()
}
}