HTML 5
<canvas>
by Daniil Suleiman
<canvas> can:
- Draw Graphics
- Draw Text
- Can be Animated
- Can be Interactive
- Can be used in Games
data:image/s3,"s3://crabby-images/1d96e/1d96e4fd3d977958ff02d0b7a1ee33db322f5a06" alt=""
data:image/s3,"s3://crabby-images/56bea/56bea1172eca4621341b484187b524b79a1ebb94" alt=""
Draw on the Canvas With JavaScript
<script>
var canvas
...
</script>
getContext()
<canvas id="canvas"></canvas>
<script>
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
...
...
</script>
<body>
<canvas id="line"></canvas>
<script>
var line = document.getElementById("line");
var ctx = line.getContext("2d");
ctx.moveTo(0, 0);
ctx.strokeStyle = 'purple';
ctx.lineTo(300, 150);
ctx.stroke();
</script>
data:image/s3,"s3://crabby-images/afc1e/afc1e7c6884b980c1c88518879c7c5c691a0d14f" alt=""
x
y
0
- moveTo(x, y)
- lineTo(x, y)
- stroke()
Lines
Line Properties
- lineCap
- lineJoin
- lineWidth
data:image/s3,"s3://crabby-images/2e56a/2e56ada1294cb0f3770d1eed9a2caed325638e51" alt=""
data:image/s3,"s3://crabby-images/68d83/68d8348729a73e951fdc8d38a9673760a794fd9a" alt=""
data:image/s3,"s3://crabby-images/274c4/274c4da159afe1a68bb8d45c7c69114547b5a0a8" alt=""
butt
round
square
1px
12px
data:image/s3,"s3://crabby-images/57cf3/57cf339dc447bff60393266d32a8c6867f890a91" alt=""
var rectangle = document.getElementById('rectangle');
var ctx = rectangle.getContext('2d');
ctx.strokeStyle = 'green';
ctx.strokeRect(100, 25, 100, 100);
Rectangles
data:image/s3,"s3://crabby-images/c748e/c748e59f14e7f6cceaaba235ae5991fdbf402f20" alt=""
var rectangle = document.getElementById('rectangle');
var ctx = rectangle.getContext('2d');
ctx.fillStyle = 'green';
ctx.fillRect(100, 25, 100, 100);
- fillRect(x,y,width,height)
- strokeRect(x,y,width,height)
data:image/s3,"s3://crabby-images/06e73/06e73d904f2cb58bceb2b555892789345e211c2c" alt=""
var circle = document.getElementById("circle");
var ctx = circle.getContext("2d");
ctx.beginPath();
ctx.strokeStyle = 'red';
ctx.arc(150, 75, 60, 0, 2*Math.PI);
ctx.stroke();
- beginPath()
- arc(x,y,radius, startAngle, endAngle)
Circles and arcs
0
Pi
0.5Pi
1.5Pi
for( ; ; ) +
canvas methods (beginPath(), moveTo(), lineTo(), fill() and else)
+ some MAGIC..
- quadraticCurveTo(cpx,cpy,x,y)
Curves
- bezierCurveTo(cp1x,cp1y,cp2x,cp2y,x,y)
data:image/s3,"s3://crabby-images/4f91b/4f91bedc48ac14c42482979d3ed145ca3ee82a2a" alt=""
for( ; ; ) +
bezierCurveTo()
+ no MAGIC..
data:image/s3,"s3://crabby-images/a7b5d/a7b5d03eadd6b779b1e06cd95c98007f70af098a" alt=""
<script>
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var grd=ctx.createRadialGradient(100,100,100,100,100,0);
grd.addColorStop(0,"white");
grd.addColorStop(1,"blue");
ctx.fillStyle = grd;
ctx.fillRect(0,0,200,200);
</script>
data:image/s3,"s3://crabby-images/8b26a/8b26a75033847f4f0107172adbb3fef35c450da0" alt=""
<script>
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
var grd=ctx.createLinearGradient(0,0,250,0);
grd.addColorStop(0,"blue");
grd.addColorStop(1,"white");
ctx.fillStyle=grd;
ctx.fillRect(10,10,250,150);
</script>
Canvas - Gradients
- createLinearGradient()
- createRadialGradient()
That's what I've got
Canvas Animations
data:image/s3,"s3://crabby-images/5a707/5a707377b9a51d967b59adaeaec74657a8a3a145" alt=""
-
clear the canvas
-
save the canvas state
- draw animated shapes
- restore the canvas state
Animation steps
(clearRect())
- setInterval()
- setTimeout()
- requestAnimationFrame()
Scheduled updates
data:image/s3,"s3://crabby-images/e2239/e223979a9b4f422b69553e94d1728a1e8717ffcb" alt=""
The Svisloch' river?!?!
Drawing Text on the Canvas
data:image/s3,"s3://crabby-images/9dcd2/9dcd221b1ddf5e1e2a591f0b25eb368cd02452ec" alt=""
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
ctx.font = "90px Arial";
ctx.fillText("EPAM",50,100);
data:image/s3,"s3://crabby-images/7d353/7d3537bfbbc931e761bb11f94409aeb9bfe25d3d" alt=""
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');
ctx.font = "90px Arial";
ctx.strokeText("EPAM",50,100);
- fillText(text,x,y)
- strokeText(text,x,y)
data:image/s3,"s3://crabby-images/ecc10/ecc1048218fac883c6ea4b556528a3ff45c23ad9" alt=""
HTML 5
<canvas>
by Daniil Suleiman
data:image/s3,"s3://crabby-images/49251/492512205e4af546c4c74f8897fbcf561f326b41" alt=""
HTML Canvas
By Daniel Suleiman
HTML Canvas
- 254