2018-12-23 18:42:30 +00:00
|
|
|
function paintCommand(canvas, cmd) {
|
|
|
|
var ctx = canvas.getContext("2d");
|
2018-12-23 19:06:40 +00:00
|
|
|
// console.log(`cmd: ${JSON.stringify(cmd)}`);
|
2018-12-23 18:42:30 +00:00
|
|
|
switch (cmd.kind) {
|
|
|
|
case "clear":
|
|
|
|
ctx.fillStyle = cmd.fill_style;
|
|
|
|
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
|
|
|
return;
|
|
|
|
case "line":
|
|
|
|
ctx.beginPath();
|
|
|
|
ctx.lineWidth = cmd.line_width;
|
|
|
|
ctx.strokeStyle = cmd.stroke_style;
|
2018-12-23 19:06:40 +00:00
|
|
|
ctx.moveTo(cmd.from.x, cmd.from.y);
|
|
|
|
ctx.lineTo(cmd.to.x, cmd.to.y);
|
2018-12-23 18:42:30 +00:00
|
|
|
ctx.stroke();
|
|
|
|
return;
|
|
|
|
case "circle":
|
|
|
|
ctx.fillStyle = cmd.fill_style;
|
|
|
|
ctx.beginPath();
|
2018-12-23 19:06:40 +00:00
|
|
|
ctx.arc(cmd.center.x, cmd.center.y, cmd.radius, 0, 2 * Math.PI, false);
|
2018-12-23 18:42:30 +00:00
|
|
|
ctx.fill();
|
|
|
|
return;
|
|
|
|
case "rounded_rect":
|
|
|
|
ctx.fillStyle = cmd.fill_style;
|
2018-12-23 19:06:40 +00:00
|
|
|
var x = cmd.pos.x;
|
|
|
|
var y = cmd.pos.y;
|
|
|
|
var width = cmd.size.x;
|
|
|
|
var height = cmd.size.y;
|
|
|
|
var r = cmd.corner_radius;
|
2018-12-23 18:42:30 +00:00
|
|
|
ctx.beginPath();
|
2018-12-23 19:06:40 +00:00
|
|
|
ctx.moveTo(x + r, y);
|
|
|
|
ctx.lineTo(x + width - r, y);
|
|
|
|
ctx.quadraticCurveTo(x + width, y, x + width, y + r);
|
|
|
|
ctx.lineTo(x + width, y + height - r);
|
|
|
|
ctx.quadraticCurveTo(x + width, y + height, x + width - r, y + height);
|
|
|
|
ctx.lineTo(x + r, y + height);
|
|
|
|
ctx.quadraticCurveTo(x, y + height, x, y + height - r);
|
|
|
|
ctx.lineTo(x, y + r);
|
|
|
|
ctx.quadraticCurveTo(x, y, x + r, y);
|
2018-12-23 18:42:30 +00:00
|
|
|
ctx.closePath();
|
|
|
|
ctx.fill();
|
|
|
|
return;
|
|
|
|
case "text":
|
|
|
|
ctx.font = cmd.font;
|
|
|
|
ctx.fillStyle = cmd.fill_style;
|
|
|
|
ctx.textAlign = cmd.text_align;
|
2018-12-23 19:06:40 +00:00
|
|
|
ctx.fillText(cmd.text, cmd.pos.x, cmd.pos.y);
|
2018-12-23 18:42:30 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// we'll defer our execution until the wasm is ready to go
|
|
|
|
function wasm_loaded() {
|
|
|
|
console.log("wasm loaded");
|
|
|
|
initialize();
|
|
|
|
}
|
|
|
|
// here we tell bindgen the path to the wasm file so it can start
|
|
|
|
// initialization and return to us a promise when it's done
|
|
|
|
wasm_bindgen("./emgui_bg.wasm")
|
|
|
|
.then(wasm_loaded)["catch"](console.error);
|
|
|
|
function rust_gui(input) {
|
|
|
|
return JSON.parse(wasm_bindgen.show_gui(JSON.stringify(input)));
|
|
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
function js_gui(input) {
|
|
|
|
var commands = [];
|
|
|
|
commands.push({
|
|
|
|
fillStyle: "#111111",
|
|
|
|
kind: "clear"
|
|
|
|
});
|
|
|
|
commands.push({
|
|
|
|
fillStyle: "#ff1111",
|
|
|
|
kind: "rounded_rect",
|
2018-12-23 19:06:40 +00:00
|
|
|
pos: { x: 100, y: 100 },
|
2018-12-23 18:42:30 +00:00
|
|
|
radius: 20,
|
2018-12-23 19:06:40 +00:00
|
|
|
size: { x: 200, y: 100 }
|
2018-12-23 18:42:30 +00:00
|
|
|
});
|
|
|
|
return commands;
|
|
|
|
}
|
2018-12-26 09:46:23 +00:00
|
|
|
function paint_gui(canvas, input) {
|
2018-12-23 18:42:30 +00:00
|
|
|
var commands = rust_gui(input);
|
2018-12-26 13:38:46 +00:00
|
|
|
commands.unshift({
|
|
|
|
fill_style: "#00000000",
|
|
|
|
kind: "clear"
|
|
|
|
});
|
2018-12-23 18:42:30 +00:00
|
|
|
for (var _i = 0, commands_1 = commands; _i < commands_1.length; _i++) {
|
|
|
|
var cmd = commands_1[_i];
|
|
|
|
paintCommand(canvas, cmd);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
2018-12-26 09:46:23 +00:00
|
|
|
var g_mouse_pos = { x: -1000.0, y: -1000.0 };
|
|
|
|
var g_mouse_down = false;
|
|
|
|
function get_input(canvas) {
|
|
|
|
return {
|
|
|
|
mouse_down: g_mouse_down,
|
|
|
|
mouse_pos: g_mouse_pos,
|
|
|
|
screen_size: { x: canvas.width, y: canvas.height }
|
|
|
|
};
|
|
|
|
}
|
2018-12-23 18:42:30 +00:00
|
|
|
function mouse_pos_from_event(canvas, evt) {
|
|
|
|
var rect = canvas.getBoundingClientRect();
|
|
|
|
return {
|
|
|
|
x: evt.clientX - rect.left,
|
|
|
|
y: evt.clientY - rect.top
|
|
|
|
};
|
|
|
|
}
|
|
|
|
function initialize() {
|
|
|
|
var canvas = document.getElementById("canvas");
|
|
|
|
canvas.addEventListener("mousemove", function (evt) {
|
2018-12-26 09:46:23 +00:00
|
|
|
g_mouse_pos = mouse_pos_from_event(canvas, evt);
|
|
|
|
paint_gui(canvas, get_input(canvas));
|
|
|
|
}, false);
|
|
|
|
canvas.addEventListener("mouseleave", function (evt) {
|
|
|
|
g_mouse_pos = { x: -1000.0, y: -1000.0 };
|
|
|
|
paint_gui(canvas, get_input(canvas));
|
2018-12-23 18:42:30 +00:00
|
|
|
}, false);
|
|
|
|
canvas.addEventListener("mousedown", function (evt) {
|
2018-12-26 09:46:23 +00:00
|
|
|
g_mouse_pos = mouse_pos_from_event(canvas, evt);
|
|
|
|
g_mouse_down = true;
|
|
|
|
paint_gui(canvas, get_input(canvas));
|
|
|
|
}, false);
|
|
|
|
canvas.addEventListener("mouseup", function (evt) {
|
|
|
|
g_mouse_pos = mouse_pos_from_event(canvas, evt);
|
|
|
|
g_mouse_down = false;
|
|
|
|
paint_gui(canvas, get_input(canvas));
|
2018-12-23 18:42:30 +00:00
|
|
|
}, false);
|
2018-12-26 09:46:23 +00:00
|
|
|
paint_gui(canvas, get_input(canvas));
|
2018-12-23 18:42:30 +00:00
|
|
|
}
|