SlideShare a Scribd company logo
Hello, Canvas.Hello, Canvas.
What is a canvas?
Hello, Canvas.
Hello, Canvas.
The <canvas> Element
<!doctype html>
<html>
<head>
<title>Canvas is awesome!</title>
</head>
<body>
<canvas width="500" height="500">
Sorry, your browser does not support canvas :(
</canvas>
</body>
</html>
<!doctype html>
<html>
<head>
<title>Canvas is awesome!</title>
</head>
<body>
<canvas width="500" height="500">
Sorry, your browser does not support canvas :(
</canvas>
</body>
</html>
The <canvas> Element
Hello, Canvas.
JavaScript to the rescue!
<!doctype html>
<html>
<head>
<title>Canvas is awesome!</title>
</head>
<body>
<canvas width="500" height="500">
Sorry, your browser does not support canvas :(
</canvas>
<script src="script.js"></script>
</body>
</html>
JavaScript to the rescue!
// script.js
var canvas = document.querySelector('canvas');
var ctx = canvas.getContext('2d');
ctx.fillRect(0, 0, 100, 100);
Learn more: https://developer.mozilla.org/en-US/docs/Web/HTML/Canvas
Hello, Canvas.
0, 0
x
y
x
0, 0
y
3, 1
x
0, 0
y
3, 1
2, 5
ctx.fillRect(5, 5, 3, 3);
start x coordinate
start y coordinate
width
height
x
0, 0
y
ctx.fillRect(5, 5, 3, 3);
x
0, 0
y
ctx.fillRect(5, 5, 3, 3);
5, 5
x
0, 0
y
ctx.fillRect(5, 5, 3, 3);
5, 5
3
3
Getting fancy
ctx.fillStyle = 'red'; // Draw a red square
ctx.fillStyle = 'blue'; // Draw a blue square
ctx.fillStyle = '#8A1CDA'; // Draw a purple square
Code Samples
https://github.com/sethmcl/yearup_intro_to_programming/tree/master/hello_canvas/part_1
Resources
Use canvas to draw a picture like this in the browser.
BONUS: Can you animate it?
Homework

More Related Content

What's hot (20)

PPTX
Element Styles and Positioning
alexisabril
 
PPTX
Php sessions
JIGAR MAKHIJA
 
PPTX
jQuery Mobile - Desenvolvimento para dispositivos móveis
Pablo Garrido
 
PDF
The Future of CSS with Web Components
ColdFusionConference
 
PDF
Our application got popular and now it breaks
ColdFusionConference
 
KEY
Artdm171 Week4 Tags
Gilbert Guerrero
 
PDF
Responsive WordPress workflow
James Bundey
 
PPT
Desenvolvimento web com jQuery Mobile
Pablo Garrido
 
PDF
Put the 5 in HTML
Frédéric Harper
 
PDF
Best Practices for Embedded UA - WritersUA 2012, Scott DeLoach, ClickStart
Scott DeLoach
 
PDF
Css sprite_maker-1
lokku
 
TXT
Htrl slide internacional
kactloko
 
PPT
Pres
Andrey L
 
PDF
Validações no Ruby on Rails
Eduardo Mendes
 
PDF
Implementing Awesome: An HTML5/CSS3 Workshop
Shoshi Roberts
 
KEY
Html5
Satoshi Kikuchi
 
PPTX
27 iframe
SatyakiDas12
 
PDF
Developing Context-sensitive Help for Web-based Applications - Scott DeLoach,...
Scott DeLoach
 
PDF
Introduction to Web Design, Week 1
Lou Susi
 
PPTX
Quickstrat fusionchart
Deni Ywn
 
Element Styles and Positioning
alexisabril
 
Php sessions
JIGAR MAKHIJA
 
jQuery Mobile - Desenvolvimento para dispositivos móveis
Pablo Garrido
 
The Future of CSS with Web Components
ColdFusionConference
 
Our application got popular and now it breaks
ColdFusionConference
 
Artdm171 Week4 Tags
Gilbert Guerrero
 
Responsive WordPress workflow
James Bundey
 
Desenvolvimento web com jQuery Mobile
Pablo Garrido
 
Put the 5 in HTML
Frédéric Harper
 
Best Practices for Embedded UA - WritersUA 2012, Scott DeLoach, ClickStart
Scott DeLoach
 
Css sprite_maker-1
lokku
 
Htrl slide internacional
kactloko
 
Pres
Andrey L
 
Validações no Ruby on Rails
Eduardo Mendes
 
Implementing Awesome: An HTML5/CSS3 Workshop
Shoshi Roberts
 
27 iframe
SatyakiDas12
 
Developing Context-sensitive Help for Web-based Applications - Scott DeLoach,...
Scott DeLoach
 
Introduction to Web Design, Week 1
Lou Susi
 
Quickstrat fusionchart
Deni Ywn
 

Viewers also liked (13)

PPT
Social Media para políticos
TestingBaires
 
PPT
Html powerpoint-presentation116
Febin Chacko
 
ODP
Visualization Methods
Petra Hegenbart
 
PDF
Chapter 1: Communicating with Your Computer
Seth McLaughlin
 
PDF
Are we there yet?
Seth McLaughlin
 
PDF
Get Moving! (with HTML5 canvas)
Seth McLaughlin
 
PDF
Building testable chrome extensions
Seth McLaughlin
 
PDF
Testing Web Applications
Seth McLaughlin
 
PDF
JavaScript State of Mind
Seth McLaughlin
 
PDF
Chapter 2: What's your type?
Seth McLaughlin
 
PPTX
Testlodge Tutorial v1.0
TestingBaires
 
PDF
Front-End Testing: Demystified
Seth McLaughlin
 
PDF
Join the darkside: Selenium testing with Nightwatch.js
Seth McLaughlin
 
Social Media para políticos
TestingBaires
 
Html powerpoint-presentation116
Febin Chacko
 
Visualization Methods
Petra Hegenbart
 
Chapter 1: Communicating with Your Computer
Seth McLaughlin
 
Are we there yet?
Seth McLaughlin
 
Get Moving! (with HTML5 canvas)
Seth McLaughlin
 
Building testable chrome extensions
Seth McLaughlin
 
Testing Web Applications
Seth McLaughlin
 
JavaScript State of Mind
Seth McLaughlin
 
Chapter 2: What's your type?
Seth McLaughlin
 
Testlodge Tutorial v1.0
TestingBaires
 
Front-End Testing: Demystified
Seth McLaughlin
 
Join the darkside: Selenium testing with Nightwatch.js
Seth McLaughlin
 
Ad

Similar to Hello, Canvas. (20)

PPTX
Advanced html5 diving into the canvas tag
David Voyles
 
PPTX
Introduction to HTML5 Canvas
Mindy McAdams
 
PPTX
JavaScript Canvas
jagriti srivastava
 
PPTX
Html5 canvas
AbhishekMondal42
 
PDF
Intro to HTML5 Canvas
Juho Vepsäläinen
 
PPTX
HTML 5_Canvas
Vishakha Vaidya
 
PDF
HTML5 Canvas - The Future of Graphics on the Web
Robin Hawkes
 
PDF
How to build a html5 websites.v1
Bitla Software
 
PPTX
Html5 canvas
Nisa Soomro
 
PPTX
introduction of HTML canvas and styles .pptx
hannahroseline2
 
PPTX
HTML5 Canvas - Basics.pptx
AhmadAbba6
 
PPTX
HTML5 Canvas
Dina Goldshtein
 
PPTX
Html canvas
Rao Mubashar
 
PPT
HTML5 Canvas
Robyn Overstreet
 
KEY
The canvas tag
guest3f63cf
 
PPTX
canvas.pptx
VeenaNaik23
 
PDF
Presentation Canvas for RSScholl 2025/04
innamassura
 
KEY
Exploring Canvas
Kevin Hoyt
 
PPTX
canvas_1.pptx
RutujRunwal1
 
KEY
Canvas and You
Shane Riley
 
Advanced html5 diving into the canvas tag
David Voyles
 
Introduction to HTML5 Canvas
Mindy McAdams
 
JavaScript Canvas
jagriti srivastava
 
Html5 canvas
AbhishekMondal42
 
Intro to HTML5 Canvas
Juho Vepsäläinen
 
HTML 5_Canvas
Vishakha Vaidya
 
HTML5 Canvas - The Future of Graphics on the Web
Robin Hawkes
 
How to build a html5 websites.v1
Bitla Software
 
Html5 canvas
Nisa Soomro
 
introduction of HTML canvas and styles .pptx
hannahroseline2
 
HTML5 Canvas - Basics.pptx
AhmadAbba6
 
HTML5 Canvas
Dina Goldshtein
 
Html canvas
Rao Mubashar
 
HTML5 Canvas
Robyn Overstreet
 
The canvas tag
guest3f63cf
 
canvas.pptx
VeenaNaik23
 
Presentation Canvas for RSScholl 2025/04
innamassura
 
Exploring Canvas
Kevin Hoyt
 
canvas_1.pptx
RutujRunwal1
 
Canvas and You
Shane Riley
 
Ad

Recently uploaded (20)

PDF
Show Which Projects Support Your Strategy and Deliver Results with OnePlan df
OnePlan Solutions
 
PDF
How to Download and Install ADT (ABAP Development Tools) for Eclipse IDE | SA...
SAP Vista, an A L T Z E N Company
 
PDF
ESUG 2025: Pharo 13 and Beyond (Stephane Ducasse)
ESUG
 
PDF
How AI in Healthcare Apps Can Help You Enhance Patient Care?
Lilly Gracia
 
PDF
Salesforce Experience Cloud Consultant.pdf
VALiNTRY360
 
PDF
How to get the licensing right for Microsoft Core Infrastructure Server Suite...
Q-Advise
 
PDF
AI Software Engineering based on Multi-view Modeling and Engineering Patterns
Hironori Washizaki
 
PDF
Simplify React app login with asgardeo-sdk
vaibhav289687
 
PDF
Code and No-Code Journeys: The Maintenance Shortcut
Applitools
 
PDF
10 Salesforce Consulting Companies in Sydney.pdf
DianApps Technologies
 
PDF
Everything you need to know about pricing & licensing Microsoft 365 Copilot f...
Q-Advise
 
PPTX
How Can Reporting Tools Improve Marketing Performance.pptx
Varsha Nayak
 
PDF
Australian Enterprises Need Project Service Automation
Navision India
 
PDF
Introduction to Apache Iceberg™ & Tableflow
Alluxio, Inc.
 
PDF
Message Level Status (MLS): The Instant Feedback Mechanism for UAE e-Invoicin...
Prachi Desai
 
PPTX
Build a Custom Agent for Agentic Testing.pptx
klpathrudu
 
PPTX
Smart Doctor Appointment Booking option in odoo.pptx
AxisTechnolabs
 
PDF
Understanding the EU Cyber Resilience Act
ICS
 
PDF
custom development enhancement | Togglenow.pdf
aswinisuhu
 
PPTX
Get Started with Maestro: Agent, Robot, and Human in Action – Session 5 of 5
klpathrudu
 
Show Which Projects Support Your Strategy and Deliver Results with OnePlan df
OnePlan Solutions
 
How to Download and Install ADT (ABAP Development Tools) for Eclipse IDE | SA...
SAP Vista, an A L T Z E N Company
 
ESUG 2025: Pharo 13 and Beyond (Stephane Ducasse)
ESUG
 
How AI in Healthcare Apps Can Help You Enhance Patient Care?
Lilly Gracia
 
Salesforce Experience Cloud Consultant.pdf
VALiNTRY360
 
How to get the licensing right for Microsoft Core Infrastructure Server Suite...
Q-Advise
 
AI Software Engineering based on Multi-view Modeling and Engineering Patterns
Hironori Washizaki
 
Simplify React app login with asgardeo-sdk
vaibhav289687
 
Code and No-Code Journeys: The Maintenance Shortcut
Applitools
 
10 Salesforce Consulting Companies in Sydney.pdf
DianApps Technologies
 
Everything you need to know about pricing & licensing Microsoft 365 Copilot f...
Q-Advise
 
How Can Reporting Tools Improve Marketing Performance.pptx
Varsha Nayak
 
Australian Enterprises Need Project Service Automation
Navision India
 
Introduction to Apache Iceberg™ & Tableflow
Alluxio, Inc.
 
Message Level Status (MLS): The Instant Feedback Mechanism for UAE e-Invoicin...
Prachi Desai
 
Build a Custom Agent for Agentic Testing.pptx
klpathrudu
 
Smart Doctor Appointment Booking option in odoo.pptx
AxisTechnolabs
 
Understanding the EU Cyber Resilience Act
ICS
 
custom development enhancement | Togglenow.pdf
aswinisuhu
 
Get Started with Maestro: Agent, Robot, and Human in Action – Session 5 of 5
klpathrudu
 

Hello, Canvas.