Canvas
The beginning of a new era
Table of contents
1. Canvas API
- History
- Introduction
- Use cases
- Live examples
2. PixiJS
- Introduction
- Pros and cons
- Live examples
3. ThreeJS
- Introduction
- Live examples
Canvas API
0. Examples
data:image/s3,"s3://crabby-images/6e022/6e022f5813d705c75927995b3340333d6e3d99fd" alt=""
data:image/s3,"s3://crabby-images/7829b/7829b23e440729116938ba8efc1847d188ab455c" alt=""
1. History
Introduced by Apple in 2004 in WebKit
Adopted in 2005 by Gecko
→ Firefox 1.5
Adopted in 2011 by Microsoft
→ Internet Explorer 9
data:image/s3,"s3://crabby-images/1ed5b/1ed5bfc10dd1264e3899554a7c8fcc0fb0ae45b7" alt=""
data:image/s3,"s3://crabby-images/e7b84/e7b84596a4fcbc913531f795b468befbb2dfcea8" alt=""
2. Introduction
a. Setup HTML
<canvas id='scene'>
<!-- Fallback -->
<p>Your browser doesn't support the HTML5 Canvas</p>
</canvas>
b. Setup Javascript
// Select the Canvas element in the page
var canvas = document.getElementById('scene');
// Select the 2D context of the element (The 2D library)
var ctx = canvas.getContext('2d');
c. Draw a rectangle
// Define color for the filling
ctx.fillStyle = "orange";
// Start a new path
ctx.beginPath();
// Define a rectangle
ctx.rect(0, 0, 100, 100); // X, Y, Width, Height
// Fill the rectangle
ctx.fill();
d. Set size
// Set Width of the canvas
canvas.width = 200;
// Set Height of the canvas
canvas.height = 200;
CSS
e. Drawing function
// Start and end a path
ctx.beginPath();
ctx.closePath();
// Basic functions
ctx.arc();
ctx.drawImage();
ctx.ellipse();
ctx.rect();
// Custom path
ctx.lineTo();
ctx.moveTo();
ctx.bezierCurveTo();
ctx.quadraticCurveTo();
// Fill or stroke a path
ctx.fill();
ctx.stroke();
// Shorthand of ctx.rect(); ctx.fill();
ctx.fillRect();
ctx.strokeRect();
// Fill or stroke text
ctx.fillText();
ctx.strokeText();
// Set a rect to transparent pixels
ctx.clearRect();
f. Properties
// Color of fill
fillStyle
// Font styles
font
// Opacity
globalAlpha
// Blending modes
globalCompositeOperation
// Cap of lines
lineCap
// Dashed lines
lineDashOffset
// Shape of two lines joining
lineJoin
// Thickness of lines
lineWidth
// Strength of shadow blur
shadowBlur
// Color of shadow
shadowColor
// X offset of shadows
shadowOffsetX
// Y offset of shadows
shadowOffsetY
// Color of the strokes
strokeStyle
// Same as CSS (left, center, right)
textAlign
// Vertical alignment of the text
textBaseline
g. Coordinates
data:image/s3,"s3://crabby-images/c00ad/c00ade902c884fb00dc723b3de4a14a3d6ff1118" alt=""
x : 0 = Left
y : 0 = Top
// Translate X and Y
ctx.translate();
// Rotate the coordinates
ctx.rotate(); --> In Radian !
// Multiplies a matrix on current transform
ctx.transform();
// Set the transform matrix
ctx.setTransform();
h. Save and restore
// Save the current state
ctx.save();
// Put back the saved state
ctx.restore();
strokeStyle, fillStyle, globalAlpha, lineWidth, lineCap, lineJoin, miterLimit, lineDashOffset, shadowOffsetX, shadowOffsetY, shadowBlur, shadowColor, globalCompositeOperation, font, textAlign, textBaseline, direction, imageSmoothingEnabled.
i. Animation
Use requestAnimationFrame() instead of setInterval() !
The window.requestAnimationFrame() method tells the browser that you wish to perform an animation and requests that the browser call a specified function to update an animation before the next repaint.
3. Use cases
- Gaming : For 2D (and 3D) games
- Advertising : Great replacement for Flash ads
- Data Representation : Good alternative to SVG
- Art : Because you can do pretty things
4. Live examples
data:image/s3,"s3://crabby-images/39247/39247d047dfa330d5cae658f30c073efd7b55183" alt=""
data:image/s3,"s3://crabby-images/c004a/c004af8f79a6cd75c467374ee090b5d162672e2c" alt=""
data:image/s3,"s3://crabby-images/c4323/c43231698901a909910d18d9386d6a66bd5c40c0" alt=""
No library & < 300 lines of JS
5. Moar ?
data:image/s3,"s3://crabby-images/fb580/fb580ed7771407429284822e2d726113dcbff692" alt=""
PixiJS
data:image/s3,"s3://crabby-images/1e4bb/1e4bbcd6dde7d14aa926534fc1e999d9d87a80af" alt=""
1. Introduction
a. Setup HTML
<canvas id='scene'>
<!-- Fallback -->
<p>Your browser doesn't support the HTML5 Canvas</p>
</canvas>
// Load PixiJS
<script src="js/pixi.min.js"></script>
b. Setup Javascript
// Setup the renderer (Canvas or WebGL based on browser support)
var renderer = new PIXI.autoDetectRenderer(width, height, {
view: document.getElementById("scene")
});
// Create a container where we'll put all the elements
var stage = new PIXI.Container();
c. Draw a rectangle
// Create a graphic constructor
var graphics = new PIXI.Graphics();
// Add graphics into the stage
stage.addChild(graphics);
// Define the fill color
graphics.beginFill(0XFFA500, 1);
// Draw a rectangle
graphics.drawRect(0, 0, 100, 100);
// Ask the renderer to render the stage
renderer.render(stage);
d. Draw an image
// Instance a new loader
var loader = new PIXI.loaders.Loader();
// Add the ressources needed
loader.add('burger', 'https://s3-us-west-2.amazonaws.com/s.cdpn.io/127738/burger.png');
// Load the ressources and call onLoad when loading is complete
loader.load(onLoad);
function onLoad(){
// create a new Sprite from the loaded image
var burger = new PIXI.Sprite(loader.resources['burger'].texture)
// Add the burger in the scene
stage.addChild(burger);
// Render the scene
renderer.render(stage);
}
d. Draw an image
e. Animation
f. Animation with GSAP
g. and more
data:image/s3,"s3://crabby-images/f310f/f310fae4e8474f9fc9317ae43161a0588ec02b90" alt=""
data:image/s3,"s3://crabby-images/e92ab/e92abdf773b7d9e2dc3e6b444232f4dc1b83724d" alt=""
data:image/s3,"s3://crabby-images/c1208/c12080e357789fe2c6095433d65af7434eb32240" alt=""
data:image/s3,"s3://crabby-images/3fff1/3fff142adb90a1b2f4e7b0d890d1fe80832c42f8" alt=""
data:image/s3,"s3://crabby-images/ad2db/ad2dbd5d62aecb54f86f130570b82bbf298ffd2d" alt=""
data:image/s3,"s3://crabby-images/29f5f/29f5fd9e3a0cb0d0cc0996e61920a10022dcbe1f" alt=""
2. Pros and cons
Pros
- Good performances
- Works great on mobile
- Browser support (IE9+)
- Open Source
- Accessibility features
- Canvas Fallback for old browser
Cons
- Its weight (> 400ko)
3. Live examples
data:image/s3,"s3://crabby-images/f4d70/f4d70c64f8dd7ea93d750b82cb9928c347ffdfab" alt=""
data:image/s3,"s3://crabby-images/0c1ab/0c1abf816602fcc5b387cdc5a0ae479ebd1c7e11" alt=""
data:image/s3,"s3://crabby-images/dcec2/dcec221fd36994ab41066aa00eef1adead12a72c" alt=""
data:image/s3,"s3://crabby-images/93e6e/93e6e9cc08731c0a638c914ca36158787c8927c4" alt=""
ThreeJS
1. Introduction
a. Setup HTML
<canvas id='scene'>
<!-- Fallback -->
<p>Your browser doesn't support the HTML5 Canvas</p>
</canvas>
// Load ThreeJs
<script src="js/three.min.js"></script>
b. Setup a new scene
- Renderer
- Camera
- Scene
- Light (optional)
data:image/s3,"s3://crabby-images/6e4ce/6e4ced21c8dc888fbf0649e1afd174171f7e5ea2" alt=""
c. Camera
Orthographic
Perspective
data:image/s3,"s3://crabby-images/d01c9/d01c9036ea222986d591e76a3e88ac7d4356f110" alt=""
d. Create a box
- Geometry : The shape of the box
- Material : The color & texture
- Mesh : A 3D object created from a geometry and a material
var geometry = new THREE.BoxGeometry(10,10,10);
var material = new THREE.MeshBasicMaterial({
color:0x00ff00 // Green color
});
var box = new THREE.Mesh(geometry, material);
e. Built in geometries
data:image/s3,"s3://crabby-images/0ba16/0ba169d67e26e3ed8103d5173ed5b92ab98d922a" alt=""
data:image/s3,"s3://crabby-images/a6a5f/a6a5f17f9c45cdd4394ed4e111d77beb31782561" alt=""
f. Materials
MeshBasicMaterial
MeshLambertMaterial
MeshPhongMaterial
g. More ?
data:image/s3,"s3://crabby-images/d51fe/d51fef43854f6000368fa254b8f7264597912d7f" alt=""
2. Live examples
data:image/s3,"s3://crabby-images/8829f/8829f20c11ba9ee9239b37e466de678917b8f425" alt=""
data:image/s3,"s3://crabby-images/d478a/d478aa57a3741663ec00aa958cf60a235ce87ad6" alt=""
data:image/s3,"s3://crabby-images/1bd6d/1bd6d73cc611aecb6c3e06e870139545b50a5f25" alt=""
data:image/s3,"s3://crabby-images/59ca4/59ca4715d49c522b8e39bf3a42562de89d71ede3" alt=""
data:image/s3,"s3://crabby-images/132c0/132c0261a4c94bc1fa11d3aaab1f5d5526ffca5d" alt=""
Questions ?
Thank you !
data:image/s3,"s3://crabby-images/a31fa/a31fa0ebfc89020b4bd879f84dfd572789b5d676" alt=""
Canvas : a new era
By Louis Hoebregts
Canvas : a new era
- 1,652