⚡ Limited seats — grab fast

$19.99 Free
Get Free Coupon
Coupon Verified

Code Your First Game: Arcade Classic in JavaScript on Canvas

4.50
398,323 students
2h 9m
Updated Apr 2026

What you'll learn

Display, position, and move filled shapes for retro and prototype gameplay
Move a ball around your game space such that it bounces off boundaries
Handle real-time mouse input
Detect and respond to simple collisions
Program very basic artificial intelligence
Keep and display score during play
Understand the subtle, key difference between a classic game in this style which is fun to play versus one that isn't
Define and code a win condition and end state for your game

Course Description

At the end of this short course you'll have programmed your first game. You'll learn gameplay development fundamentals by really doing it – writing and running real code on your own machine.

Each step of the course has the source code attached exactly as it should look at that time (click "View Resources" then "Downloadable Resources"), for you to compare to or pick up from, so you can't get stuck!

Begin Your Game Programming Journey the Proven Way

"Make the simplest game possible." "Program a ball and paddle project." "Practice by first remaking something from the 1970's." All beginning developers hear this advice from more experienced peers... because it works!

By following this approach you will:

  • Learn design from a fun classic that people know and enjoy.
  • Start your practice today – now! – without waiting for an idea.
  • Finish your game in hours or in a weekend, not over months.
  • Understand every line of code used in the entire program.
  • Avoid distraction from searching for or creating detailed art.
  • Master fundamentals needed to make your own games better.

You can program this game with a normal text editor, and run it in the web browser you already have. No special software is needed.

Though you'll be coding in JavaScript for HTML5 canvas in this course, the focus is on common game programming concepts. You can later apply these same patterns to get quick results in other programming languages such as C#, Java, ActionScript 3, C++, or Python.

I'm a private game development trainer, and for clients new to gameplay programming this is exactly the material that I cover to get them started quickly. Within hours you will have finished programming your first project. This is the fastest way to get results. The momentum gained from doing this provides a solid foundation to give more advanced concepts meaning and context as you continue on in your journey of learning game development.

(HTML5 Logo in the course image is by W3C, licensed under Creative Commons Attribution 3.0 Unported.)

Requirements

  • Very early on students will need to show file extensions in their operating system (explained briefly in the video)
  • If a plain text editor is available that has programming features like line numbers and auto-indent (ex. Notepad++ on PC, TextWrangler on Mac) that may be handy but is not necessary, as a generic text editor like Notepad or TextEdit will work fine for a program of this size
Mastering C Language - C Programming For Beginners
FREE
Development Expires soon

Mastering C Language - C Programming For Beginners

4.0 (0) 30.4k 1h 48m Beginner 🌐 English
$19.99 FREE
Get Free

⚡ Limited seats — grab it fast

Understanding Bootstrap Grids and Columns
FREE
Development Expires soon

Understanding Bootstrap Grids and Columns

4.4 (0) 13.9k 40m All Levels 🌐 English
$19.99 FREE
Get Free

⚡ Limited seats — grab it fast

Master Node.js: From Beginner to Full-Stack Developer
FREE
Development Expires soon

Master Node.js: From Beginner to Full-Stack Developer

0.0 (0) 🌐 English
$54.99 FREE
Get Free

⚡ Limited seats — grab it fast

Code Your First Game: Arcade Classic in JavaScript on Canvas

$19.99

Free

100% Off
Get Coupon Code Save for Later

Limited coupon seats — once all free spots are claimed, Udemy may show the full price. Grab it early!

Course Details

  • Level Beginner
  • Lectures 12
  • Duration 2h 9m