In our last class I showed you how to build a simple pong game using the <canvas>
element. The <canvas>
element is great for animated games, but it's also great for supporting random drawing like you can do in a raster-based paint program.
You goal for this lab is to create a simple line-drawing paint program. You will use the <canvas>
element and its methods to accomplish this.
To build the basic version of this application, follow these steps
- Declare a few variables to hold a reference to the
<canvas>
element as well as it's'2d'
drawing context. - Add an event listener for the
'mousedown'
event on the canvas element. When that event occurs, use the 2D drawing context to begin a path and move the drawing pen to the coordinates where the user clicked. Remember that the'mousedown'
event is passed an event object, which has the propertiesclientX
andclientY
. These properties are relative to the document area of entire browser window, so you will need to subtract the canvas element'soffsetLeft
andoffsetTop
properties to get the mouse coordinates relative to the canvas element. - Add another event listener for the
'mousemove'
event on the canvas element. When that occurs, if the mouse button is currently down, you should use thelineTo()
method to extend the path to the current mouse coordinates, and call thestroke()
method to actually draw the line.- Hint: The easiest way to tell if the mouse is down is to declare a boolean variable at a higher scope, set it to
true
during the'mousedown'
event, and set it back tofalse
during the'mouseup'
event. If you want to handle multiple mouse buttons, you can make that variable a numeric value that you increment and decrement instead.
- Hint: The easiest way to tell if the mouse is down is to declare a boolean variable at a higher scope, set it to
- Speaking of the
'mouseup'
event, add another event listener for that event on the canvas element. When that event occurs, you should extend the path to the current mouse coordinates, and again call the canvas'sstroke()
method to draw the line. Then you should reset your variable so that you know that the mouse button is no longer down.
If you do this properly, you should be able to freeform draw on the canvas by clicking your mouse and dragging around on the canvas surface. The line color will default to black, and the line width will default to 1
pixel.
The starter page contains a color input selector that users can click to select a different color than black. Add an event listener for the 'change'
event on that input element, and when that event occurs, set the canvas's 'strokeStyle'
property to the new color value.
If you do things correctly, the user should be able to use that color input to change the line color of future strokes. Existing strokes will remain with their existing color, as they are already drawn on the canvas.
Now that you figured out how to let the user adjust line color, add another input that will let the user adjust line width.
And if you really want to get creative, let users also adjust other line styles, such as the line end-cap or line join style.