The Cure
Canvas
Apple even creates open standards for the web                -Steve Jobs
<canvas id="my-canvas" width="700" height="600">    I am canvas</canvas>
var canvas = document.getElementById("my-canvas"),    context = canvas.getContext("2d");context.fillStyle = "#f00";context...
context.save();context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(50, 50, 100, 100);context.clearRect(40, 40, 20,...
context.fillRect(350, 50, 100, 100);context.lineWidth = "10";context.lineJoin = "round";context.moveTo(50, 50);context.lin...
context.beginPath();context.strokeStyle = "#00f";context.arc(200, 400, 75, 0, Math.PI*2, false);context.stroke();
context.fillStyle = "#f00";context.bezierCurveTo(100, 100, 10, 10, 250, 30);context.fill();
var gradient = context.createLinearGradient(0, 0, 0, canvas.height);gradient.addColorStop(0, "#f00");gradient.addColorStop...
var canvas = document.getElementById("my-canvas"),    context = canvas.getContext("2d"),    img = document.createElement("...
var patternImg = document.createElement("img");patternImg.onload = function () {    context.strokeStyle = context.createPa...
context.fillStyle = "#fff";context.fillRect(0, 0, 200, 200);context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);co...
context.strokeStyle = "transparent";context.arc(100, 100, 75, 0, Math.PI*2, false);context.clip();context.stroke();context...
context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.fillStyle =...
context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.scale(2, 2)...
context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.rotate(0.23...
context.fillStyle = "#000";context.font = "16px Helvetica Neue";context.fillText("I am text on canvas - how cool is that?"...
context.fillStyle = "#000";context.font = "16px Helvetica Neue";context.shadowColor = "rgba(100, 100, 100, 0.5)";context.s...
// Image for loadingvar img = document.createElement("img"),img.addEventListener("load", function () {    context.drawImag...
// To enable drag and dropcanvas.addEventListener("dragover", function (evt) {    evt.preventDefault();}, false);// Handle...
var mouseDown = false,    brushColor = "rgb(0, 0, 0)";// Detect mousedowncanvas.addEventListener("mousedown", function (ev...
location.href = canvas.toDataURL("image/png");
...
???
The Cure    - Demo
HTML5 Canvas for Internet Explorer <= 8                   -            explorercanvas
Robert Nyman                                                           http://robertnyman.com/                            ...
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Canvas - The Cure
Upcoming SlideShare
Loading in...5
×

Canvas - The Cure

1,951

Published on

An introduction to the HTML5 canvas element and what you can do with it.

The key is using it all together in the demo at the end

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
1,951
On Slideshare
0
From Embeds
0
Number of Embeds
1
Actions
Shares
0
Downloads
16
Comments
0
Likes
0
Embeds 0
No embeds

No notes for slide

Canvas - The Cure

  1. 1. The Cure
  2. 2. Canvas
  3. 3. Apple even creates open standards for the web -Steve Jobs
  4. 4. <canvas id="my-canvas" width="700" height="600"> I am canvas</canvas>
  5. 5. var canvas = document.getElementById("my-canvas"), context = canvas.getContext("2d");context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);
  6. 6. context.save();context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(50, 50, 100, 100);context.clearRect(40, 40, 20, 20);context.restore();
  7. 7. context.fillRect(350, 50, 100, 100);context.lineWidth = "10";context.lineJoin = "round";context.moveTo(50, 50);context.lineTo(200, 200);context.lineTo(100, 300);context.closePath();context.stroke();context.fill();
  8. 8. context.beginPath();context.strokeStyle = "#00f";context.arc(200, 400, 75, 0, Math.PI*2, false);context.stroke();
  9. 9. context.fillStyle = "#f00";context.bezierCurveTo(100, 100, 10, 10, 250, 30);context.fill();
  10. 10. var gradient = context.createLinearGradient(0, 0, 0, canvas.height);gradient.addColorStop(0, "#f00");gradient.addColorStop(1, "#ffffa2");context.fillStyle = gradient;context.fillRect(0, 0, canvas.width, canvas.height);
  11. 11. var canvas = document.getElementById("my-canvas"), context = canvas.getContext("2d"), img = document.createElement("img");img.addEventListener("load", function () { context.drawImage(img, 0, 0, 600, 200);}, false);img.setAttribute("src", "view.jpg");
  12. 12. var patternImg = document.createElement("img");patternImg.onload = function () { context.strokeStyle = context.createPattern(this, "repeat"); context.stroke();};patternImg.src = "view-small.jpg";
  13. 13. context.fillStyle = "#fff";context.fillRect(0, 0, 200, 200);context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.fillRect(100, 100, 100, 100);
  14. 14. context.strokeStyle = "transparent";context.arc(100, 100, 75, 0, Math.PI*2, false);context.clip();context.stroke();context.fillStyle = "#fff";context.fillRect(0, 0, 200, 200);context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.fillRect(100, 100, 100, 100);
  15. 15. context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(0, 0, 100, 100);context.restore();context.fillRect(0, 200, 100, 100);
  16. 16. context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.scale(2, 2);context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(0, 0, 100, 100);context.restore();context.fillRect(0, 200, 100, 100);
  17. 17. context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.save();context.translate(200, 200);context.rotate(0.23);context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(0, 0, 100, 100);context.restore();context.fillRect(0, 200, 100, 100);
  18. 18. context.fillStyle = "#000";context.font = "16px Helvetica Neue";context.fillText("I am text on canvas - how cool is that?",200, 250);
  19. 19. context.fillStyle = "#000";context.font = "16px Helvetica Neue";context.shadowColor = "rgba(100, 100, 100, 0.5)";context.shadowOffsetX = 5;context.shadowOffsetY = 5;context.fillText("I am text on canvas - how cool is that?",200, 250);
  20. 20. // Image for loadingvar img = document.createElement("img"),img.addEventListener("load", function () { context.drawImage(img, 0, 0);}, false);
  21. 21. // To enable drag and dropcanvas.addEventListener("dragover", function (evt) { evt.preventDefault();}, false);// Handle dropped image file - only Firefox and Google Chromecanvas.addEventListener("drop", function (evt) { var files = evt.dataTransfer.files; if (files.length > 0) { var file = files[0]; if (typeof FileReader !== "undefined" && file.type.indexOf("image") != -1) { var reader = new FileReader(); // Note: addEventListener doesnt work in Google Chrome for this event reader.onload = function (evt) { img.src = evt.target.result; }; reader.readAsDataURL(file); } } evt.preventDefault();}, false);
  22. 22. var mouseDown = false, brushColor = "rgb(0, 0, 0)";// Detect mousedowncanvas.addEventListener("mousedown", function (evt) { mouseDown = true; context.beginPath();}, false);// Detect mouseupcanvas.addEventListener("mouseup", function (evt) { mouseDown = false; var colors = context.getImageData(evt.layerX, evt.layerY, 1, 1).data; brushColor = "rgb(" + colors[0] + ", " + colors[1] + ", " + colors[2]+ ")";}, false);// Draw, if mouse button is pressedcanvas.addEventListener("mousemove", function (evt) { if (mouseDown) { context.strokeStyle = brushColor; context.lineWidth = 20; context.lineJoin = "round"; context.lineTo(evt.layerX+1, evt.layerY+1); context.stroke(); }}, false);
  23. 23. location.href = canvas.toDataURL("image/png");
  24. 24. 
  25. 25. ???
  26. 26. The Cure - Demo
  27. 27. HTML5 Canvas for Internet Explorer <= 8 - explorercanvas
  28. 28. Robert Nyman http://robertnyman.com/ Twitter: @robertnymanPictures:The Cure: http://www.amoeba.com/blog/2007/07/pen-is-mightier-than-the-sword/new-siouxsie-video-into-a-swan.htmlRobocop: http://www.meh.ro/2010/04/01/murphy-as-robocop/Sticky tape: http://damncoolpics.blogspot.com/2011/02/funny-graphs-and-charts.htmlCanvas: http://www.ioffer.com/c/Drawings-1000407Wash machine: http://www.mymodernmet.com/profiles/blogs/a-father-who-creativelyClip: http://pics33.blogspot.com/2010/08/best-examples-of-creative-edit-images.htmlLost in translation: http://www.impawards.com/2003/lost_in_translation_ver2.htmlCoffe machine: http://www.mymodernmet.com/profiles/blogs/a-father-who-creativelyThrowing: http://pics33.blogspot.com/2010/08/best-examples-of-creative-edit-images.htmlText: http://www.identifont.com/show?3OIDrag me: http://www.stardusttrailers.com/scheda_wallpaper.php?id=17261&titolo=Drag%20Me%20to%20HellDrawing: http://www.mathacademy.com/pr/minitext/escher/big.asp?image=drawing_handsProtect painting: http://yellowpagescoupons.net/protect-painting-200-licensed-experienced-professional-detailed-prep-painters-sf-east-bay-area-ca-yellow-pages-coupons/Calvin & Hobbes:http://www.fanpop.com/spots/calvin-and-hobbes/images/1395524/title/calvin-hobbes-hugging-wallpaper
  1. A particular slide catching your eye?

    Clipping is a handy way to collect important slides you want to go back to later.

×