Making Match-3 Browser Games
Making Match-3 Browser Games
Tile-Matching Game Mechanics for Phaser.js Gaming Frameworks v3.x.x & v2.x.x
About the Book
Discover how to create online Match-3 and "Draw-3+" games using the methods in this single chapter from the Phaser Game Starter Kit Collection. When you finish this chapter, you will have a production pipeline ready to create as many different "tile-matching" games as your imagination can dream of!
You'll also get bonus content, download examples, game variations, and source code references on how to do every single thing in this game design workbook, so you can copy and paste any examples into your own productions and then modify those resources for your own purposes. General Game Licenses are included in the purchased book.
I would like to guide you in creating several styles of Match-3 and "three-in-a-row+" game mechanics. We will use the game mechanics, mechanisms and the development methods discussed in Phaser Game Prototypes. By the end of this workbook, you should have a fully functional Match-3 or Trace-3+ game - not just a copy of my game, but your very own product using your own gaming assets. There is a supporting website where you can download the bonus content included with your workbook's purchase.
This extraordinarily comprehensive guide will teach you how to:
- Use the Phaser JS Gaming Framework! either v2.x.x or v3.16+.
- How to integrate "Match-3" game mechanics into other game genres such as RPG adventure, and combat systems!
- Use your game as a "Progressive Web Application" or "Single Page Web Application" for any device.
- Analyze current business demand for this game's genre, how and where to deploy it.
- Automatically generate various game board features.
If you have any feedback or suggestions please join our email listing or participate in the forum for this course!
Table of Contents
-
-
Distribution Permission
- Supporting website
- Disclosures
- Disclaimer
-
About this Workbook
- Links and References
- Workbook Content
-
How to Read & Use this workbook:
- Viewing this eBook:
- Who should use this workbook?
- Your newly obtained skills …
-
Game Design Resources
- Game Studio - Book Series
- Game Studio - Online Courses
- “Making Browser Games” - Books Series
- “Making Browser Games” Series - online Courses
- Programming Courses
- “Walk-Thru Tutorial” Series - Online Courses
-
Distribution Permission
-
Making HTML5 Games
-
1 Introduction to Game Design
- 1.1 Game Genre Defined
- 1.2 Game Tools & Generators
- 1.3 References From
-
2 Standard Project Setup
- 2.1 Standardized File Structure
- 2.2 Barebones Set-up
- 2.3 Web Server Required - Batteries not included!
-
3 Starting a Game Project
-
3.1 Step 0: Review your competition and their games
- Game Examples
- 3.2 Step 1: Create your “front-door”
-
3.3 Step 2. Create your “Game Shell” & Phases
- Network Impact
- Gamer’s Local Activity
-
3.4 Select a JS Format
- ES5 Format
- ES6+ Format as “FAT Arrow” Function
- ES6+ Format as “Phaser.Class”
- ES6+ Format as “Phaser.Scene”
-
3.1 Step 0: Review your competition and their games
-
1 Introduction to Game Design
-
Part II: Making “Match-3” Browser Games
-
4 Match-3 — Core Game Construction
- 4.1 Game Project Overview
- 4.2 Our Goal
- 4.3 Match-3 Genre Description
- 4.4 Game Mechanics (GM) - Logic & Rules
- 4.5 Game Recipe™ Featured Ingredients
-
4.6 Design Considerations
- Match 3 (Placed) - Tic-tac-toe
- Match 4 (Placed) - “Connect”
- Match 5 (Placed) - “Go”
- 4.7 Match 3+ - “Tracing-a-line”
- 4.8 Step 3: Create “Play.js”
- 4.9 Step 4: Create Supporting functions.
- 4.10 Conclusion
-
5 Phaser v3.16+ Code Review
-
5.1 Game Set-up Options
- Phaser III Config and Game Settings - Lines 630 to 718:
-
5.2 Game Mechanisms Component - “playGame Class”
- PlayGame.constructor – Lines 73 to 79
- “Preload” Essential Functions – Lines 79 to 152
- “Create” Essential Functions – Lines 97 to 155
- PlayGame.drawGameBoard – Lines 156 to 175
- PlayGame.tileSelect – Lines 177 to 207
- PlayGame.swapTiles – Lines 209 to 236
- PlayGame.handleMatches – Lines 238 to 291
- PlayGame.makeTilesFall – Lines 292 to 345
- PlayGame.endOfMove – Lines 347 to 365
-
5.3 Match-3 Game Mechanics Component
- Arrange Board After Match – Lines 397 to 415
- Create and Manage the Gameboard data – Lines 422 to 447
-
5.1 Game Set-up Options
-
6 Phaser v2.x.x Code Review
-
- Play.js
-
6.1 Match-3+ Core Mechanics
- Step 3. Create your core Game logic & supporting functions
-
6.2 Game-board set-up
-
function
drawField
- Lines 57 to 80:
-
function
-
6.3 Input Validation
- Function Tile selection – Lines 81 to 121
- Function Tile De-selection – Lines 122 to 129
- Function Tile Move – Lines 130 to 161
- Function Tile swapping – Lines 162 to 202
- Function Tile Next – Lines 199 to 202
- Function Tile the same – Lines 203 to 206
- Function Tile at – Lines 207 to 214
-
6.4 Tile Discovery
- Function Get Tile row – Lines 215 to 218
- Function Get Tile column – Lines 220 to 224
-
6.5 Game Rules and logic
- Function Tile Horizontal Match – Lines 225 to 228
- Function Tile Vertical match – Lines 229 to 232
- Function Tile is a Match – Lines 233 to 236
- Function Existing Match in Board – Lines 237 to 248
- Function Match Handling “Workhorse” – Lines 249 to 271
- Function Handle Vertical Matches – a delegation pattern; Line 272 to313
- Function Handle Horizontal Matches – a delegation pattern; Line 314 to 355
-
6.6 Game Board Management
- Function Tile Removal – Lines 356 to 382
- Function Tile Falling (visual display management) – Lines 383 to 427
- Function Replenish Tile Field (visual display management) – Lines 428 to 474
- Function Tile Holes Below (visual display management) – Lines 475 to 486
- Function Tile Holes in Columns (visual display management) – Lines 487 to 497
-
-
7 Game Shell - The CMS!
- 7.1 Generic
- 7.2 Generic Boot.js
- 7.3 Generic Preload.js
- 7.4 Generic Splash.js or Language.js
-
7.5 Generic Menu.js
- Sample CMS page — Credits.js
- Deeper Dive: Using JAMStack as an SSG …
- Deeper Dive: Static Site Generators (SSG)
- 7.6 Inside each Game Phase
- 8 Plug-in Enhancements
- 9 Conclusion
- 10 Bonus Development Content
-
4 Match-3 — Core Game Construction
-
What’s next?
-
-
10.1 Game Distribution & Marketing
- Introduction: 8-Step Deployment Method.
- 10.2 Book Review Protocol
- 10.3 Tell the world about your game!
-
10.1 Game Distribution & Marketing
-
-
Appendix
-
More Resources
- JavaScript Garden
- Additional Appendices
- Other resources:
- Selling your Game Assets
- Appendix: Online Game Development
- Appendix: Making WebXR Games!
- Appendix: Phaser III Plugins
-
Appendix: “How to Start a WebSocket”
- Testing Your Browser
-
WebSocket Protocol Handshake
- Deeper Dive: WebSocket API
-
Sample Source Code: Client-side WebSocket
-
Step #1: Game
index
page - Step #2: Generate Event handlers
-
Step #1: Game
-
More Resources
-
Appendix: OLOO - Safe JavaScript
-
- Deeper Dive: JS Delegation (aka “Inheritance”?)
- The old way
- Objects Linking to Other Objects (OLOO)
- Compare your code
- Object.create
- Exercise Lesson 9:
- Game Singletons
- Deeper Dive: Object Manipulation objects in ES5/6
- Lesson Summary
- Resource References:
-
- Notes
-
Answers to Exercises
-
- Appendix: OLOO - Safe JavaScript
-
Other books by this author
The Leanpub 60-day 100% Happiness Guarantee
Within 60 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
See full terms
Do Well. Do Good.
Authors have earned$11,845,077writing, publishing and selling on Leanpub, earning 80% royalties while saving up to 25 million pounds of CO2 and up to 46,000 trees.
Learn more about writing on Leanpub
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers) and EPUB (for phones, tablets and Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
Learn more about Leanpub's ebook formats and where to read them
Top Books
The Hitchhiker's Guide to DFIR: Experiences From Beginners and Experts
Barry Grundy, Tristram, John Haynes, ApexPredator, Andrew Rathbun, Kevin Pagano, Victor Heiland, Nisarg Suthar, Guus Beckers, and Jason WilkinsA first-of-its-kind crowdsourced Digital Forensics and Incident Response (DFIR) book by the Digital Forensics Discord Server members to share knowledge!
OpenIntro Statistics
David Diez, Christopher Barr, Mine Cetinkaya-Rundel, and OpenIntroA complete foundation for Statistics, also serving as a foundation for Data Science.
Leanpub revenue supports OpenIntro (US-based nonprofit) so we can provide free desk copies to teachers interested in using OpenIntro Statistics in the classroom and expand the project to support free textbooks in other subjects.
More resources: openintro.org.
Ansible for DevOps
Jeff GeerlingAnsible is a simple, but powerful, server and configuration management tool. Learn to use Ansible effectively, whether you manage one server—or thousands.
Maîtriser Apache JMeter
Philippe Mouawad, Bruno Demion (Milamber), and Antonio Gomes RodriguesToute la puissance d'Apache JMeter expliquée par ses commiteurs et utilisateurs experts. De l'intégration continue en passant par le Cloud, vous découvrirez comment intégrer JMeter à vos processus "Agile" et Devops.
If you're looking for the newer english version of this book, go to Master JMeter : From load testing to DevOps
Software Architecture for Developers
Simon BrownA developer-friendly, practical and pragmatic guide to lightweight software architecture, technical leadership and the balance with agility.
Functional Event-Driven Architecture
Gabriel VolpeExplore the event-driven architecture (EDA) in a purely functional way. Learn to design and develop distributed systems that scale. Identify common design patterns in such systems.
Take your functional programming skills to the next level by joining me in developing a distributed system powered by Apache Pulsar and Fs2 streams, all in Scala 3!
R Programming for Data Science
Roger D. PengThis book brings the fundamentals of R programming to you, using the same material developed as part of the industry-leading Johns Hopkins Data Science Specialization. The skills taught in this book will lay the foundation for you to begin your journey learning data science. Printed copies of this book are available through Lulu.
Concurrency with Modern C++
Rainer GrimmC++11 is the first C++ standard that deals with concurrency. The story goes on with C++17, C++20, and will continue with C++23.
I'll give you a detailed insight into the current and the upcoming concurrency in C++. This insight includes the theory and a lot of practice.
Thinking with Types
Sandy MaguireThis book aims to be the comprehensive manual for type-level programming. It's about getting you from here to there---from a competent Haskell programmer to one who convinces the compiler to do their work for them.
Biological Modeling
Phillip CompeauIn this ebook, learn why zebras have stripes, why SARS-CoV-2 spread so quickly around the planet, how to train a computer to classify cellular images, and more!
Top Bundles
- #1
CCIE Service Provider Ultimate Study Bundle
2 Books
Piotr Jablonski, Lukasz Bromirski, and Nick Russo have joined forces to deliver the only CCIE Service Provider training resource you'll ever need. This bundle contains a detailed and challenging collection of workbook labs, plus an extensively detailed technical reference guide. All of us have earned the CCIE Service Provider certification... - #2
Modern C++ Collection
3 Books
Get All about Modern C++C++ Standard Library, including C++20Concurrency with Modern C++, including C++20C++20Each book has about 200 complete code examples. Updates are included. When I update one of the books, you immediately get the updated bundle. You can expect significant updates to each new C++ standard (C++23, C++26, .. ) and also... - #3
Software Architecture
2 Books
"Software Architecture for Developers" is a practical and pragmatic guide to modern, lightweight software architecture, specifically aimed at developers. You'll learn:The essence of software architecture.Why the software architecture role should include coding, coaching and collaboration.The things that you really need to think about before... - #4
Practical FP in Scala + Functional event-driven architecture
2 Books
Practical FP in Scala (A hands-on approach) & Functional event-driven architecture, aka FEDA, (Powered by Scala 3), together as a bundle! The content of PFP in Scala is a requirement to understand FEDA so why not take advantage of this bundle!? - #6
Pattern-Oriented Memory Forensics and Malware Detection
2 Books
This training bundle for security engineers and researchers, malware and memory forensics analysts includes two accelerated training courses for Windows memory dump analysis using WinDbg. It is also useful for technical support and escalation engineers who analyze memory dumps from complex software environments and need to check for possible... - #8
Learn Git, Bash, and Terraform the Hard Way
3 Books
Learn Git, Bash and Terraform using the Hard Way method.These technologies are essential tools in the DevOps armoury. These books walk you through their features and subtleties in a simple, gradual way that reinforces learning rather than baffling you with theory. - #9
Quality Software
11 Books
The Quality Software Bundle is for managers, would-be managers, and any of us who find themselves being managed and confused. This comprehensive bundle covers the entire span of software development approaches, from hacking through waterfall, cascade, prototyping, Iterative enhancement, reusable code, off-the-shelf, to Agile teams. The bundle... - #10
Static Analysis and Automated Refactoring
2 Books
As PHP developers we are living in the "Age of Static Analysis". We can use a tool like PHPStan to learn about potential bugs before we ship our code to production, and we can enforce our team's programming standards using custom PHPStan rules. Recipes for Decoupling by Matthias Noback teaches you in great detail how to do this, while also...