2018-09-13 03:38:22 +03:00
|
|
|
use std::cell::Cell;
|
2018-09-13 02:10:23 +03:00
|
|
|
use std::rc::Rc;
|
|
|
|
use wasm_bindgen::prelude::*;
|
|
|
|
use wasm_bindgen::JsCast;
|
|
|
|
|
2018-11-28 09:25:51 -08:00
|
|
|
#[wasm_bindgen(start)]
|
|
|
|
pub fn start() -> Result<(), JsValue> {
|
2018-09-17 14:25:04 -07:00
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
2018-09-13 02:10:23 +03:00
|
|
|
let canvas = document
|
2018-11-08 10:58:55 -08:00
|
|
|
.create_element("canvas")?
|
|
|
|
.dyn_into::<web_sys::HtmlCanvasElement>()?;
|
|
|
|
document.body().unwrap().append_child(&canvas)?;
|
2018-09-13 02:10:23 +03:00
|
|
|
canvas.set_width(640);
|
|
|
|
canvas.set_height(480);
|
2018-11-08 10:58:55 -08:00
|
|
|
canvas.style().set_property("border", "solid")?;
|
2018-09-13 02:10:23 +03:00
|
|
|
let context = canvas
|
2018-11-08 10:58:55 -08:00
|
|
|
.get_context("2d")?
|
2018-09-13 02:10:23 +03:00
|
|
|
.unwrap()
|
2018-11-08 10:58:55 -08:00
|
|
|
.dyn_into::<web_sys::CanvasRenderingContext2d>()?;
|
2018-09-13 02:10:23 +03:00
|
|
|
let context = Rc::new(context);
|
2018-09-13 03:38:22 +03:00
|
|
|
let pressed = Rc::new(Cell::new(false));
|
2018-09-13 02:10:23 +03:00
|
|
|
{
|
|
|
|
let context = context.clone();
|
|
|
|
let pressed = pressed.clone();
|
2018-10-03 09:53:55 -07:00
|
|
|
let closure = Closure::wrap(Box::new(move |event: web_sys::MouseEvent| {
|
2018-09-13 02:10:23 +03:00
|
|
|
context.begin_path();
|
|
|
|
context.move_to(event.offset_x() as f64, event.offset_y() as f64);
|
2018-09-13 03:38:22 +03:00
|
|
|
pressed.set(true);
|
2018-12-12 08:12:51 +01:00
|
|
|
}) as Box<dyn FnMut(_)>);
|
2018-11-27 12:07:59 -08:00
|
|
|
canvas.add_event_listener_with_callback("mousedown", closure.as_ref().unchecked_ref())?;
|
2018-09-13 02:10:23 +03:00
|
|
|
closure.forget();
|
|
|
|
}
|
|
|
|
{
|
|
|
|
let context = context.clone();
|
|
|
|
let pressed = pressed.clone();
|
2018-10-03 09:53:55 -07:00
|
|
|
let closure = Closure::wrap(Box::new(move |event: web_sys::MouseEvent| {
|
2018-09-13 03:38:22 +03:00
|
|
|
if pressed.get() {
|
2018-09-13 02:10:23 +03:00
|
|
|
context.line_to(event.offset_x() as f64, event.offset_y() as f64);
|
|
|
|
context.stroke();
|
|
|
|
context.begin_path();
|
|
|
|
context.move_to(event.offset_x() as f64, event.offset_y() as f64);
|
|
|
|
}
|
2018-12-12 08:12:51 +01:00
|
|
|
}) as Box<dyn FnMut(_)>);
|
2018-11-27 12:07:59 -08:00
|
|
|
canvas.add_event_listener_with_callback("mousemove", closure.as_ref().unchecked_ref())?;
|
2018-09-13 02:10:23 +03:00
|
|
|
closure.forget();
|
|
|
|
}
|
|
|
|
{
|
|
|
|
let context = context.clone();
|
|
|
|
let pressed = pressed.clone();
|
2018-10-03 09:53:55 -07:00
|
|
|
let closure = Closure::wrap(Box::new(move |event: web_sys::MouseEvent| {
|
2018-09-13 03:38:22 +03:00
|
|
|
pressed.set(false);
|
2018-09-13 02:10:23 +03:00
|
|
|
context.line_to(event.offset_x() as f64, event.offset_y() as f64);
|
|
|
|
context.stroke();
|
2018-12-12 08:12:51 +01:00
|
|
|
}) as Box<dyn FnMut(_)>);
|
2018-11-27 12:07:59 -08:00
|
|
|
canvas.add_event_listener_with_callback("mouseup", closure.as_ref().unchecked_ref())?;
|
2018-09-13 02:10:23 +03:00
|
|
|
closure.forget();
|
|
|
|
}
|
2018-11-08 10:58:55 -08:00
|
|
|
|
|
|
|
Ok(())
|
2018-09-13 02:10:23 +03:00
|
|
|
}
|