Skip to content

Instantly share code, notes, and snippets.

@russianryebread
Created December 19, 2018 03:16
Show Gist options
  • Save russianryebread/7f2a250ab8ffa95f56e6cc808882aba5 to your computer and use it in GitHub Desktop.
Save russianryebread/7f2a250ab8ffa95f56e6cc808882aba5 to your computer and use it in GitHub Desktop.
Doodl

<html>
<head>
<title>Doozle</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type="text/css">
* { margin: 0; padding: 0; }
body { background: transparent; }
#canvas { cursor: url(cursor.png) 0 31, auto; }
</style>
</head>
<body>
<canvas id="canvas"></canvas>
<script type="text/javascript">
var LINE_COLOR = "#99e265"
var LINE_WIDTH = 6
var CLEAR_DELAY_SECONDS = 1
var canvas = document.getElementById("canvas")
var ctx = canvas.getContext("2d")
window.addEventListener("load", init)
window.addEventListener("resize", resize)
function init() {
var painting = false
var lastX = 0
var lastY = 0
resize()
canvas.addEventListener('mousedown', paint)
canvas.addEventListener('mousemove', draw)
canvas.addEventListener('mouseup', reset)
canvas.addEventListener('mouseout', reset)
function paint(event) {
painting = true
lastX = event.pageX - this.offsetLeft
lastY = event.pageY - this.offsetTop
}
function draw(event) {
if (!painting) return
mouseX = event.pageX - this.offsetLeft
mouseY = event.pageY - this.offsetTop
ctx.beginPath()
ctx.moveTo(lastX, lastY)
ctx.lineTo(mouseX, mouseY)
ctx.lineWidth = LINE_WIDTH
ctx.lineJoin = "round"
ctx.lineCap = "round"
ctx.strokeStyle = LINE_COLOR
ctx.stroke()
lastX = mouseX
lastY = mouseY
}
function reset(event) {
painting = false
setTimeout(() => {
if (painting) return
ctx.clearRect(0, 0, canvas.width, canvas.height)
}, (CLEAR_DELAY_SECONDS * 1000))
}
}
function resize() {
canvas.width = window.innerWidth
canvas.height = window.innerHeight
if (window.devicePixelRatio > 1) {
var canvasWidth = canvas.width;
var canvasHeight = canvas.height;
canvas.width = canvasWidth * window.devicePixelRatio;
canvas.height = canvasHeight * window.devicePixelRatio;
canvas.style.width = canvasWidth;
canvas.style.height = canvasHeight;
ctx.scale(window.devicePixelRatio, window.devicePixelRatio);
}
}
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment