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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#![doc = include_str!("../README.md")]
#[cfg(test)]
pub mod tests;
pub mod sys;
pub mod shader;
pub mod component;
pub mod utils;
pub mod entity;
pub mod scene;
pub mod assets;
#[cfg(feature = "yew-support")]
pub mod yew_ext;
pub use shader::*;
pub use component::*;
pub use utils::*;
pub use entity::*;
pub use scene::*;
pub use assets::*;
#[cfg(feature = "yew-support")]
pub use crate::yew_ext::*;
#[cfg(feature = "init")]
pub async fn init_aframe()
{
const LINK: &'static str = "https://aframe.io/releases/1.2.0/aframe.min.js";
use wasm_bindgen::prelude::*;
use wasm_bindgen::JsCast;
use std::sync::{Once, Arc};
use async_lock::Barrier;
use futures::executor::block_on;
static INIT: Once = Once::new();
if INIT.is_completed()
{
return;
}
let barrier = Arc::new(Barrier::new(2));
INIT.call_once(||
{
if let Some(document) = web_sys::window().and_then(|win| win.document())
{
if let Some(head) = document.head()
{
if let Ok(script_element) = document.create_element("script")
{
if let Ok(script_element) = script_element.dyn_into::<web_sys::HtmlElement>()
{
head.append_child(&script_element).unwrap();
let closure =
{
let barrier = barrier.clone();
Closure::wrap(Box::new(move ||
{
block_on(barrier.wait());
}) as Box<dyn FnMut()>)
};
script_element.set_onload(Some(closure.as_ref().unchecked_ref()));
closure.forget();
if let Ok(_) = script_element.set_attribute("src", LINK)
{
}
}
}
}
}
});
barrier.wait().await;
}