HTML Canvas Day 8 of 30.
This commit is contained in:
parent
fb6f66bd84
commit
38c106b43b
57
HTML Canvas [8-30]/index.html
Normal file
57
HTML Canvas [8-30]/index.html
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>HTML5 Canvas</title>
|
||||||
|
<link rel="icon" href="https://fav.farm/🔥" />
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<canvas id="draw" width="800" height="800"></canvas>
|
||||||
|
<script>
|
||||||
|
const canvas = document.querySelector('#draw');
|
||||||
|
const ctx = canvas.getContext('2d');
|
||||||
|
canvas.width = window.innerWidth;
|
||||||
|
canvas.heigh = window.innerHeight;
|
||||||
|
ctx.strokeStyle = '#BADA55';
|
||||||
|
ctx.lineJoin = 'round';
|
||||||
|
ctx.lineCap = 'round';
|
||||||
|
ctx.lineWidth = 6;
|
||||||
|
|
||||||
|
let isDrawing = false;
|
||||||
|
let lastX = 0;
|
||||||
|
let lastY = 0;
|
||||||
|
let hue = 0;
|
||||||
|
|
||||||
|
function draw(e) {
|
||||||
|
if(!isDrawing) return;
|
||||||
|
// console.log(e);
|
||||||
|
ctx.strokeStyle = `hsl(${hue}, 100%, 50%)`;
|
||||||
|
ctx.beginPath();
|
||||||
|
ctx.moveTo(lastX, lastY);
|
||||||
|
ctx.lineTo(e.offsetX, e.offsetY);
|
||||||
|
ctx.stroke();
|
||||||
|
[lastX, lastY] = [e.offsetX, e.offsetY];
|
||||||
|
hue++;
|
||||||
|
if(hue > 360) hue = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
canvas.addEventListener('mousedown', (e)=> {
|
||||||
|
isDrawing = true;
|
||||||
|
[lastX, lastY] = [e.offsetX, e.offsetY];
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
canvas.addEventListener('mousemove', draw);
|
||||||
|
canvas.addEventListener('mouseup', ()=> isDrawing = false);
|
||||||
|
canvas.addEventListener('mouseout', ()=> isDrawing = false);
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
html, body {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in New Issue
Block a user