pub struct Image { /* private fields */ }
Expand description
This struct represent an image. It is useful when using the Sprite struct.
§Example
use wasm_game_lib::graphics::image::Image;
// load a texture encoded in text
let ferris = Image::load("").await.unwrap();
// load a texture from the web
let ferris2 = Image::load("https://rustacean.net/assets/cuddlyferris.svg").await.unwrap();
Implementations§
Source§impl Image
impl Image
Sourcepub async fn load(url: &str) -> Result<Image, JsValue>
pub async fn load(url: &str) -> Result<Image, JsValue>
Load an Image. Return a Result because it may fail.
§Example
// load a texture encoded in text
let ferris = Image::load("").await.unwrap();
// load a texture from the web
let ferris2 = Image::load("https://rustacean.net/assets/cuddlyferris.svg").await.unwrap();
Sourcepub async fn load_and_send(url: &str, sender: Sender<Result<Image, JsValue>>)
pub async fn load_and_send(url: &str, sender: Sender<Result<Image, JsValue>>)
Load an Image and send it trought a oneshot channel.
§Example
use wasm_game_lib::graphics::image::Image;
use wasm_game_lib::system::sleep;
use futures::channel::oneshot::Receiver;
use futures::channel::oneshot;
use futures::join;
use wasm_bindgen::JsValue;
use std::time::Duration;
// the function which will be executed during the load
async fn loading_tracker(mut receivers: Vec<Receiver<Result<Image, JsValue>>>) -> Vec<Result<Image, JsValue>> {
let mut images = Vec::new();
for _ in 0..receivers.len() {
images.push(None);
}
loop {
for i in 0..images.len() {
if images[i].is_none() {
if let Ok(Some(result)) = receivers[i].try_recv() {
images[i] = Some(result);
}
}
}
if !images.contains(&None) {
// break when every image is ready
break;
}
// you may want to display a progress bar here
sleep(Duration::from_millis(20)).await;
}
let mut unwraped_images = Vec::new();
for image in images {
unwraped_images.push(image.unwrap());
}
return unwraped_images;
}
async fn start() {
// create 2 oneshot channels
let (sender1, receiver1) = oneshot::channel::<Result<Image, JsValue>>();
let (sender2, receiver2) = oneshot::channel::<Result<Image, JsValue>>();
// create futures
let loading_tracker_future = loading_tracker(vec![receiver1, receiver2]);
let image1_future = Image::load_and_send("https://images.pexels.com/photos/1086723/pexels-photo-1086723.jpeg?auto=compress&cs=tinysrgb&dpr=3&h=7000&w=7000", sender1);
let image2_future = Image::load_and_send("https://c.wallhere.com/photos/c1/ff/Moon_rocks_sky_8k-1430191.jpg!d", sender2);
// execute the three futures simultaneously and get the images
let images = join!(loading_tracker_future, image1_future, image2_future).0;
}
pub fn get_html_element(&self) -> &HtmlImageElement
Sourcepub fn get_height<T: From<u32>>(&self) -> T
pub fn get_height<T: From<u32>>(&self) -> T
Return the height of the image.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Image
impl RefUnwindSafe for Image
impl !Send for Image
impl !Sync for Image
impl Unpin for Image
impl UnwindSafe for Image
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more