2018-08-15 16:56:24 -07:00
|
|
|
use std::f64;
|
|
|
|
use wasm_bindgen::prelude::*;
|
|
|
|
use wasm_bindgen::JsCast;
|
2018-12-11 08:40:36 -02:00
|
|
|
use web_sys;
|
2018-08-15 16:56:24 -07:00
|
|
|
|
2018-11-28 09:25:51 -08:00
|
|
|
#[wasm_bindgen(start)]
|
|
|
|
pub fn start() {
|
2018-09-17 14:25:04 -07:00
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
2018-08-15 16:56:24 -07:00
|
|
|
let canvas = document.get_element_by_id("canvas").unwrap();
|
|
|
|
let canvas: web_sys::HtmlCanvasElement = canvas
|
|
|
|
.dyn_into::<web_sys::HtmlCanvasElement>()
|
|
|
|
.map_err(|_| ())
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let context = canvas
|
2018-08-16 23:13:34 -07:00
|
|
|
.get_context("2d")
|
2018-08-15 16:56:24 -07:00
|
|
|
.unwrap()
|
|
|
|
.unwrap()
|
2018-09-02 20:51:37 +03:00
|
|
|
.dyn_into::<web_sys::CanvasRenderingContext2d>()
|
2018-08-15 16:56:24 -07:00
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
context.begin_path();
|
|
|
|
|
|
|
|
// Draw the outer circle.
|
2018-09-26 08:26:00 -07:00
|
|
|
context
|
|
|
|
.arc(75.0, 75.0, 50.0, 0.0, f64::consts::PI * 2.0)
|
|
|
|
.unwrap();
|
2018-08-15 16:56:24 -07:00
|
|
|
|
|
|
|
// Draw the mouth.
|
|
|
|
context.move_to(110.0, 75.0);
|
2018-09-26 08:26:00 -07:00
|
|
|
context.arc(75.0, 75.0, 35.0, 0.0, f64::consts::PI).unwrap();
|
2018-08-15 16:56:24 -07:00
|
|
|
|
|
|
|
// Draw the left eye.
|
|
|
|
context.move_to(65.0, 65.0);
|
2018-09-26 08:26:00 -07:00
|
|
|
context
|
|
|
|
.arc(60.0, 65.0, 5.0, 0.0, f64::consts::PI * 2.0)
|
|
|
|
.unwrap();
|
2018-08-15 16:56:24 -07:00
|
|
|
|
|
|
|
// Draw the right eye.
|
|
|
|
context.move_to(95.0, 65.0);
|
2018-09-26 08:26:00 -07:00
|
|
|
context
|
|
|
|
.arc(90.0, 65.0, 5.0, 0.0, f64::consts::PI * 2.0)
|
|
|
|
.unwrap();
|
2018-08-15 16:56:24 -07:00
|
|
|
|
|
|
|
context.stroke();
|
|
|
|
}
|