Cocos2d-x Game Development Blueprints
()
About this ebook
- Explore the powerful features of Cocos2d-x and use them to your advantage
- Tackle commonly faced problems while creating popular 2D games
- A step-by-step guide to help you understand and develop some of the most popular games of the industry such as Angry Bird
If you are a proficient Cocos2d game developer who wants to enhance his or her game development skill set using Cocos2d-x to build different types of games, this book is for you.
Related to Cocos2d-x Game Development Blueprints
Related ebooks
The Daschund - A Dog Anthology (A Vintage Dog Books Breed Classic) Rating: 0 out of 5 stars0 ratingsLearning Cocos2d-JS Game Development Rating: 0 out of 5 stars0 ratingsBuilding Android Games with Cocos2d-x Rating: 0 out of 5 stars0 ratingsLearning Cocos2d-x Game Development Rating: 0 out of 5 stars0 ratingsAndroid Game Programming by Example Rating: 0 out of 5 stars0 ratingsCocos2D Game Development Essentials Rating: 0 out of 5 stars0 ratingsCreating Games with cocos2d for iPhone 2 Rating: 0 out of 5 stars0 ratingsCocos2d Game Development Blueprints Rating: 0 out of 5 stars0 ratingsBuilding a 3D Game with LibGDX Rating: 1 out of 5 stars1/5Beginning Android C++ Game Development Rating: 0 out of 5 stars0 ratingsHTML5 Game Development with GameMaker Rating: 0 out of 5 stars0 ratingsSDL Game Development Rating: 0 out of 5 stars0 ratingsBuilding your First Mobile Game using XNA 4.0 Rating: 0 out of 5 stars0 ratingsLearning Libgdx Game Development Rating: 0 out of 5 stars0 ratingsLearning LibGDX Game Development - Second Edition Rating: 0 out of 5 stars0 ratingsMastering LibGDX Game Development Rating: 0 out of 5 stars0 ratingsLearning Android Game Development Rating: 0 out of 5 stars0 ratingsBox2D for Flash Games Rating: 0 out of 5 stars0 ratingsOpenGL Game Development By Example Rating: 0 out of 5 stars0 ratingsLibGDX Game Development By Example Rating: 0 out of 5 stars0 ratingsBeginning Android Games Development: From Beginner to Pro Rating: 0 out of 5 stars0 ratingsMonoGame Mastery: Build a Multi-Platform 2D Game and Reusable Game Engine Rating: 0 out of 5 stars0 ratingsBeginning Unity Android Game Development: From Beginner to Pro Rating: 0 out of 5 stars0 ratingsGodot from Zero to Proficiency (Advanced): Godot from Zero to Proficiency, #1 Rating: 5 out of 5 stars5/5Godot from Zero to Proficiency (Intermediate): Godot from Zero to Proficiency, #3 Rating: 5 out of 5 stars5/5Mastering Android Game Development Rating: 0 out of 5 stars0 ratingsUnity Game Development Blueprints Rating: 0 out of 5 stars0 ratingsGetting Started with Unity 5 Rating: 5 out of 5 stars5/5Mastering Unity Scripting Rating: 0 out of 5 stars0 ratingsMastering Android NDK Rating: 0 out of 5 stars0 ratings
Programming For You
Excel : The Ultimate Comprehensive Step-By-Step Guide to the Basics of Excel Programming: 1 Rating: 5 out of 5 stars5/5Python: For Beginners A Crash Course Guide To Learn Python in 1 Week Rating: 4 out of 5 stars4/5Java for Beginners: A Crash Course to Learn Java Programming in 1 Week Rating: 5 out of 5 stars5/5Python: Learn Python in 24 Hours Rating: 4 out of 5 stars4/5HTML & CSS: Learn the Fundaments in 7 Days Rating: 4 out of 5 stars4/5Learn SQL in 24 Hours Rating: 5 out of 5 stars5/5Grokking Algorithms: An illustrated guide for programmers and other curious people Rating: 4 out of 5 stars4/5SQL All-in-One For Dummies Rating: 3 out of 5 stars3/5Coding All-in-One For Dummies Rating: 4 out of 5 stars4/5Learn to Code. Get a Job. The Ultimate Guide to Learning and Getting Hired as a Developer. Rating: 5 out of 5 stars5/5SQL QuickStart Guide: The Simplified Beginner's Guide to Managing, Analyzing, and Manipulating Data With SQL Rating: 4 out of 5 stars4/5Python Machine Learning By Example Rating: 4 out of 5 stars4/5Python Programming : How to Code Python Fast In Just 24 Hours With 7 Simple Steps Rating: 4 out of 5 stars4/5Unreal Engine from Zero to Proficiency (Foundations): Unreal Engine from Zero to Proficiency, #1 Rating: 0 out of 5 stars0 ratingsPython Projects for Beginners: A Ten-Week Bootcamp Approach to Python Programming Rating: 0 out of 5 stars0 ratingsHTML in 30 Pages Rating: 5 out of 5 stars5/5C++ Learn in 24 Hours Rating: 0 out of 5 stars0 ratingsProfessional C++ Rating: 2 out of 5 stars2/5OneNote: The Ultimate Guide on How to Use Microsoft OneNote for Getting Things Done Rating: 1 out of 5 stars1/5Beginning Programming with Python For Dummies Rating: 3 out of 5 stars3/5Linux: Learn in 24 Hours Rating: 5 out of 5 stars5/5
Reviews for Cocos2d-x Game Development Blueprints
0 ratings0 reviews
Book preview
Cocos2d-x Game Development Blueprints - Karan Sequeira
Table of Contents
Cocos2d-x Game Development Blueprints
Credits
About the Author
About the Reviewers
www.PacktPub.com
Support files, eBooks, discount offers, and more
Why subscribe?
Free access for Packt account holders
Preface
What this book covers
What you need for this book
Who this book is for
Conventions
Reader feedback
Customer support
Downloading the example code
Downloading the color images of this book
Errata
Piracy
Questions
1. A Colorful Start
An overview of ColourSmash
Setting up the environment for Cocos2d-html5
Creating a project in Cocos2d-html5
Getting acquainted with the project structure
Creating the first scene – the main menu
Moving on to the game world
Declaring and initializing the variables
Creating the background
Creating the tiles
Creating the Heads-Up Display
The countdown timer
Let's get touchy...
The core gameplay
Finding the tiles
Removing the tiles
Finding and shifting tiles from above
Adding new tiles
Adding score and bonus
Updating the timer
Summary
2. How to Fly a Dragon!
Getting to know sprite sheets
Creating a lively menu screen
Creating a fairy tale
Building an infinitely long castle in 20 lines of code
Adding the stars
Setting things into motion
On to the game world
The core gameplay
Creating the dragon
Creating the towers
The update loop
Updating the dragon
Updating the towers
Collision detection
Flying the dragon
Farewell dear dragon
Saving a high score using LocalStorage
Let's make some HTML5 noise
Summary
3. Not Just a Space Game
An overview of SpaceCraze
Creating a project
Defining the global variables of the game
Creating your own Sprite
On to the game world...
The Player class
The Enemy class
The Brick class
Parsing the level file
Creating enemies
Creating bricks
Creating the player
Creating HUD elements
The start and stop functions
Moving the enemies
Fire the bullets!
The update function
Checking for collisions
Touch controls
Level complete and game over
Summary
4. Back to the Drawing Board
An introduction to Inverse Universe
The CCDrawNode class
Figuring out the geometry
Defining the elements of Inverse Universe
The Player class
The Enemy class
The PowerUp class
The Bomb class
The Blast class
The MissileLauncher class
The Missile class
The Shield class
Creating the game
The update loop
Adding tilt controls
Moving the player
Adding progression and difficulty levels
Summary
5. Let's Get Physical!
An overview of Jumpy Clown
The basics of Box2D
Creating the world
Using debug draw
Stepping into the world
Creating the GameObject class
Creating the walls
Creating the base
Creating the clown
Defining the clown's state machine
Creating the platform
Adding and removing platforms
Adding the controls
Listening for collisions
The Collectible class
Creating and reusing collectibles
The update loop
Summary
6. Creativity with Textures
An introduction to Penguins Can Fly
The Terrain class
Generating the striped texture
Drawing the stripes
Adding a gradient
Adding some highlight
Drawing the border
Adding some noise
Generating the hills
Generating the hill key points
Generating the curve of the hill
Creating the Box2D body for the hill
Rendering the hills
Updating the hill
The Penguin class
Updating the penguin
On to the game world
Summary
7. Old is Gold!
An introduction to Iceman
What is a tile-based game?
What is the Tiled Map Editor?
Creating a new tile map
Adding a tileset
Adding a tile layer
Adding an objects layer
Tile-based collision detection
The GameObject class
The Hero class
The Enemy class
Collisions with moving platforms and enemies
Summary
8. Box2D Meets RUBE
An introduction to Angry Fish
A brief introduction to RUBE
Creating bodies
Running the scene
Importing images
Creating a level with RUBE
Creating the catapult
Adding custom properties
Generating a world using data exported from RUBE
Defining the fish
The Fish class
The ShootingFish class
The SplittingFish class
The ExplodingFish class
Using Box2D's RayCast
The Cat class
The PostSolve function
Creating and spawning the fish
Creating a mouse joint
Summary
9. The Two Towers
Introduction to Pumpkin Defense
Defining the properties of the tower
Defining the properties of the enemy
Defining the XML file for a level
Designing the level in Tiled
The Tower class
The Lightning class
The Enemy class
Spawning waves of enemies
The GestureLayer class
Spawning the towers
Fast forwarding the gameplay
Summary
10. Cross-platform Building
Setting up the environment for Android
Java Development Kit 7+
The Android SDK
Eclipse or the ADT bundle
ADT plugin for Eclipse
Installing Cygwin for Windows
The Android NDK
Building Pumpkin Defense on Android
Creating an Android Virtual Device
Running Pumpkin Defense on Android
Setting up the environment for Windows Phone 8
Building Pumpkin Defense on Windows Phone 8
What to do next?
Summary
Index
Cocos2d-x Game Development Blueprints
Cocos2d-x Game Development Blueprints
Copyright © 2015 Packt Publishing
All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews.
Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book.
Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information.
First published: July 2015
Production reference: 1220715
Published by Packt Publishing Ltd.
Livery Place
35 Livery Street
Birmingham B3 2PB, UK.
ISBN 978-1-78398-526-5
www.packtpub.com
Credits
Author
Karan Sequeira
Reviewers
Harrison
Carlos Piñan
Germán González Rodríguez
Commissioning Editor
Ashwin Nair
Acquisition Editor
Kevin Colaco
Content Development Editor
Shweta Pant
Technical Editor
Madhunikita Sunil Chindarkar
Copy Editor
Roshni Banerjee
Project Coordinator
Shipra Chawhan
Proofreader
Safis Editing
Indexer
Priya Sane
Production Coordinator
Komal Ramchandani
Cover Work
Komal Ramchandani
About the Author
Karan Sequeira is a budding game developer with 4 years of experience in the mobile game development industry. He started out as a JavaScript programmer, developing HTML5 games, and fell in love with C++ when he moved to Cocos2d-x. He has a handful of games on the iOS and Android app stores and is currently working for an organization in the in-flight entertainment industry. He is extremely passionate about learning new technologies and dreams about building an artificially intelligent super computer that can fall in love.
I am deeply grateful to the amazing folks at Packt Publishing, who presented me with a wonderful opportunity and supported me unceasingly. I owe a lot to the developers of Cocos2d-x and its ever-growing community of developers. But most of all, I am blessed to have a loving and encouraging family as well as friends who have been patient through all the times I've ditched them for this book.
About the Reviewers
Harrison is one of the core developers of Cocos2d-x. As a maintainer of this broadly used game engine, he has been working on the v2.x and v3.x versions since 2013, focusing on rendering modules. In addition to this, he is experienced on desktop game developing, including game logic, rendering, animation, and particle systems. In his own words, Cocos2d-x is making progress, I hope my team and I can provide a good engine for all developers—code less, enjoy more!
Carlos Piñan is a software engineer with 5 years of experience and is dedicated to game development and Android development. He contributes libraries to the Cocos2d-x communities and contributes to the Android community as well. He is a speaker at different events and is a trainer for Android apps.
He contributes to algorithm books and other Cocos2d-x books as well.
I would like to thank my family for always believing in me and my friends at Vitrum for being a great team.
Germán González Rodríguez is a software engineer with a master's degree in telecommunications engineering and over 7 years' experience working as a game, app, and web developer on the PC, Mac, iOS, and Android platforms. He has had a passion for programming video games since an early age. In school, he checked out hundreds of library books and typed in thousands of lines of BASIC code to make text adventures on his father's old 386 computer.
After he finished his degree, he worked for an independent video game developing company called Lemon Team in Alicante, Spain, until he became a freelance software engineer. In that time, he successfully shipped games on the App Store, Google Play Store, Amazon Appstore, and Windows Store with more than 2,000,000 combined installations for companies such as Amazon Games Studios and Fresh Games.
At present, he lives in the US and tries to promote sustainability practices as a game developer in the nonprofit organization Cool Choices, which is based in Madison, Wisconsin.
I would like to thank my wife, Patricia, for her love, support, and patience. I love you.
I would also like to thank my parents for always being there. I am who I am today because of you.
www.PacktPub.com
Support files, eBooks, discount offers, and more
For support files and downloads related to your book, please visit www.PacktPub.com.
Did you know that Packt offers eBook versions of every book published, with PDF and ePub files available? You can upgrade to the eBook version at www.PacktPub.com and as a print book customer, you are entitled to a discount on the eBook copy. Get in touch with us at
At www.PacktPub.com, you can also read a collection of free technical articles, sign up for a range of free newsletters and receive exclusive discounts and offers on Packt books and eBooks.
https://www2.packtpub.com/books/subscription/packtlib
Do you need instant solutions to your IT questions? PacktLib is Packt's online digital book library. Here, you can search, access, and read Packt's entire library of books.
Why subscribe?
Fully searchable across every book published by Packt
Copy and paste, print, and bookmark content
On demand and accessible via a web browser
Free access for Packt account holders
If you have an account with Packt at www.PacktPub.com, you can use this to access PacktLib today and view 9 entirely free books. Simply use your login credentials for immediate access.
Preface
Cocos2d-x offers you, as a game developer, an open source engine that enables you to effortlessly build powerful 2D games and publish them on a multitude of popular platforms. In today's fast-paced world, what more could a game developer need?
This book gets you started by introducing the continually evolving HTML5 platform and familiarizes you with the Cocos2d-html5 framework.
This book is written to get you well versed with the many versatile features of Cocos2d-x, by demonstrating the creation of nine different games—from arcade style games to new age physics games and from simple puzzle games to strategic tower defense games! All the while, focusing on gameplay and letting Cocos2d-x do all the heavy lifting for you.
For the finale, you will learn how to build your games for Android and Windows Phone 8, bringing you to a full circle on Cocos2d-x.
What this book covers
Chapter 1, A Colorful Start, introduces the HTML5 version of the Cocos2d family by creating a simple and colorful puzzle game. You will learn how to set up your environment to develop using the Cocos2d-html5 engine. You also get familiar with the various actions you can use to get things done in an instant.
Chapter 2, How to Fly a Dragon!, concludes your HTML5 journey and will show you how to use sprite sheets, how to implement simple gravity, and use rectangular collision detection.
Chapter 3, Not Just a Space Game, shows you how to create a multiplatform Cocos2d-x project. You will also learn to create a level-based arcade game where you learn how to parse XML, play particle effects, and extend the engine by inheriting from its primary classes.
Chapter 4, Back to the Drawing Board, shows you just how easy it is to make a game that completely uses primitive drawing for its entities. You will also learn how to implement simple accelerometer controls and how to add difficulty progression to an endless game.
Chapter 5, Let's Get Physical!, guides you through the process of using Box2D to build a physics game. You will also learn about state machines and object pools.
Chapter 6, Creativity with Textures, shows you how to fire OpenGL commands and render your own sprite. You will also learn to use Box2D to make a picturesque side-scroller game.
Chapter 7, Old is Gold!, introduces you to the Tiled map editor and the basics of a tile-based game. You will also learn how to implement a reusable tile-based collision detection algorithm.
Chapter 8, Box2D Meets RUBE, introduces you to RUBE, which is a powerful physics editor. You will use it to create levels for a slingshot type physics game. You will also learn about ray casting and how to implement explosions in Box2D.
Chapter 9, The Two Towers, shows you how easy it is to implement a tower defense game in Cocos2d-x. In the process, you will learn how to implement scalable architectures for your enemies and towers. You will also learn how a simple gesture recognizer works and how you can control the speed of your gameplay.
Chapter 10, Cross-platform Building, shows you how to set up your environment and build one of your games on Android and Windows Phone 8.
What you need for this book
The source bundle will contain all the source code and project files to run each game. However, you will need to install the following software to run the games:
A computer running Windows, Linux, or Mac OS. However, you will need a computer running Windows 8 in order to build on Windows Phone 8.
WebStorm, or a similar JavaScript editor, and at least one browser to run the HTML5 games in the first two chapters.
Microsoft Visual Studio to run the projects on Windows PC and Windows Phone and Eclipse to run the projects on Android.
Who this book is for
This book is written for people who have basic experience in Cocos2d-x and want to use it to implement a wide variety of high-quality games. The book revisits some of the basic concepts, but we hit the ground running. As such, some basic understanding of Cocos2d-x is recommended. In addition, since the first couple of chapters are on Cocos2d-html5, some knowledge of JavaScript is strongly recommended.
Conventions
In this book, you will find a number of text styles that distinguish between different kinds of information. Here are some examples of these styles and an explanation of their meaning.
Code words in text, database table names, folder names, filenames, file extensions, pathnames, dummy URLs, user input, and Twitter handles are shown as follows: If you expand the Classes folder inside pumpkindefenseComponent, you will notice that the actual sources are missing.
A block of code is set as follows:
createTileData:function(){
this.tileData = [];
// generate tile data randomly
for(var i = 0; i < (NUM_COLS * NUM_ROWS); ++i){
this.tileData[i] = 1 + Math.floor(Math.random() * MAX_COLOURS);
}
}
Any command-line input or output is written as follows:
export NDK_ROOT=/Android/android-ndk-r10
New terms and important words are shown in bold. Words that you see on the screen, for example, in menus or dialog boxes, appear in the text like this: By default, you will see a whole lot of packages selected, out of which Android SDK Platform-tools and Android SDK Build-tools are necessary.
Note
Warnings or important notes appear in a box like this.
Tip
Tips and tricks appear like this.
Reader feedback
Feedback from our readers is always welcome. Let us know what you think about this book—what you liked or disliked. Reader feedback is important for us as it helps us develop titles that you will really get the most out of.
To send us general feedback, simply e-mail <feedback@packtpub.com>, and mention the book's title in the subject of your message.
If there is a topic that you have expertise in and you are interested in either writing or contributing to a book, see our author guide at www.packtpub.com/authors.
Customer support
Now that you are the proud owner of a Packt book, we have a number of things to help you to get the most from your purchase.
Downloading the example code
You can download the example code files from your account at http://www.packtpub.com for all the Packt Publishing books you have purchased. If you purchased this book elsewhere, you can visit http://www.packtpub.com/support and register to have the files e-mailed directly to you.
Downloading the color images of this book
We also provide you with a PDF file that has color images of the screenshots/diagrams used in this book. The color images will help you better understand the changes in the output. You can download this file from https://www.packtpub.com/sites/default/files/downloads/5265OS_ColorImages.pdf.
Errata
Although we have taken every care to ensure the accuracy of our content, mistakes do happen. If you find a mistake in one of our books—maybe a mistake in the text or the code—we would be grateful if you could report this to us. By doing so, you can save other readers from frustration and help us improve subsequent versions of this book. If you find any errata, please report them by visiting http://www.packtpub.com/submit-errata, selecting your book, clicking on the Errata Submission Form link, and entering the details of your errata. Once your errata are verified, your submission will be accepted and the errata will be uploaded to our website or added to any list of existing errata under the Errata section of that title.
To view the previously submitted errata, go to https://www.packtpub.com/books/content/support and enter the name of the book in the search field. The required information will appear under the Errata section.
Piracy
Piracy of copyrighted material on the Internet is an ongoing problem across all media. At Packt, we take the protection of our copyright and licenses very seriously. If you come across any illegal copies of our works in any form on the Internet, please provide us with the location address or website name immediately so that we can pursue a remedy.
Please contact us at <copyright@packtpub.com> with a link to the suspected pirated material.
We appreciate your help in protecting our authors and our ability to bring you valuable content.
Questions
If you have a problem with any aspect of this book, you can contact us at <questions@packtpub.com>, and we will do our best to address the problem.
Chapter 1. A Colorful Start
We start the journey of game development in Cocos2d-x with a simple, fun, and colorful game. Let's call it ColourSmash. This will serve as a revision of the basic features of the engine and will get us started with some fun development. We will be using the HTML5 version of Cocos2d for this project—Cocos2d-html5-v2.2.3 to be specific. So all the coding in this chapter, and the next, will be done in JavaScript.
Here's what you'll learn in this chapter:
How and where to use cc.Scene and cc.Layer
How to optimize rendering with a batch node
How to use actions and easing
How to get touches
How to schedule callbacks
An overview of ColourSmash
The game we will discuss here is one of the many famous puzzle games found online. The basic idea of the game is simple: click on a colored tile and all adjacent tiles of the same color disappear. As you may have guessed, the game world consists of a set of colorful tiles. You keep clicking tiles and they disappear. What makes it fun is a bunch of tiles disappearing together yields you a bonus!
This is a glimpse of what we should have at the end of this chapter:
Setting up the environment for Cocos2d-html5
Before we actually begin developing this game, let's spend some time setting up an environment for our HTML5 games. Since these are HTML5 games, they will essentially run in a web browser—be it on a computer or a mobile device. You are free to run these games in a browser of your choice. My personal favorite is Google Chrome!
Since we will be using JavaScript to develop the game, I would definitely recommend brushing up on some basic JavaScript coding principles before diving into the code. You can visit the following URL for some help:
http://jstherightway.org/
Moving on, here is the list of software that you will require to run the tests/samples in the Cocos2d-html5 source as well as the Cocos2d-html5 games we'll develop:
Cocos2d-html5 source (version 2.2.3 at the time of writing this chapter) can be found at http://cdn.Cocos2d-x.org/Cocos2d-html5-v2.2.3.zip
WebStorm (optional) at https://confluence.jetbrains.com/display/WI/Previous+WebStorm+Releases
WampServer (optional and for Windows only) can be downloaded from http://www.wampserver.com/en/
The first software on the list is, of course, the source of the Cocos2d-html5 engine, without which we won't be able to move a single web-based muscle.
The next software on the list is WebStorm, which is a powerful JavaScript editor that provides features such as code completion, code refactoring, debugging, and many others. Of course, this does not impact our chapter in anyway. You can choose to use any editor of your choice.
The last item on the list is WampServer, which is optional and is valid only for developers working on a Windows machine. WampServer provides a web server that can serve files over HTTP. This is especially useful if you want to test your game on wireless devices connected to the same network as your development machine.
Once you've downloaded the above software, move to the next section where we will create a sample project.
Creating a project in Cocos2d-html5
Creating a project in Cocos2d-html5 is as simple as copying a readymade template and renaming it to what you want to call your game. If you've downloaded and extracted the archive of the Cocos2d-html5 source, navigate to the template folder inside it. Your file explorer should show you something like this:
If you run the index.html file you see in the template folder, you'll realize that it is nothing but a hello world project. This is exactly what we need to get us started. To create a new project in Cocos2d-html5, follow these steps:
Copy all the files within the template folder.
Create a folder in the root directory of the Cocos2d-html5 engine. The engine's root with the folder for ColourSmash is shown in the following screenshot:
Now, paste all the files that you copied from the template folder into the folder you just created.
That's it! You have created your first project in Cocos2d-html5. Now, it's time to get acquainted with the different kinds of files located in the project's directory.
Getting acquainted with the project structure
The main backbone files required for any Cocos2d-html5 game are the index.html, main.js, and cocos2d.js files. These are exactly the files you will see in your project's root directory. In addition to these three files, you can also see a file called build.xml and another file called cocos2d-jsb.js. Take a look at the following table for a brief description of what these files are responsible for:
Now that we have a basic understanding of the structure of a typical Cocos2d-html5 project, it is time to create our very first scene in ColourSmash.
Creating the first scene – the main menu
Our first scene happens to be the opening screen of the game—the main menu. It is what the users will see when the game has finished loading. This scene is defined in mainmenu.js in the source for this project. This is what it looks like:
var MainMenu = cc.Layer.extend({
init:function () {
this._super();
return true;
}
});
var MainMenuScene = cc.Scene.extend({
onEnter:function () {
this._super();
var layer = new MainMenu();
layer.init();
this.addChild(layer);
}
});
As you can see, we have two entities here; an object called MainMenu, which is of type cc.Layer, and a class called MainMenuScene, which extends the cc.Scene class. Understandably, if you've worked on Cocos2d-x before, this is the way the various screens within a game are structured into scenes and layers. If you do need to brush up on some Cocos2d node graph basics, feel free to pay a visit to the following link:
http://www.cocos2d-x.org/wiki/Scene_Graph
Now that we have created a cc.Scene class and a cc.Layer class, it's time to create some basic UI elements. We add a title and a play button to our main menu and add some color to the background. Hence, the following code is added to the init function of MainMenu:
// create a coloured layer as background
var background = cc.LayerColor.create(cc.c4b(25, 0, 51, 255), this.screenSize.width, this.screenSize.height);
this.addChild(background);
// create a label to display the name of the game
var titleLabel = cc.LabelTTF.create(ColourSmash
, Comic Sans MS
, 64);
titleLabel.setPosition(cc.p(this.screenSize.width * 0.5, this.screenSize.height * 0.8));
this.addChild(titleLabel, 1);
// create a play button to move to the game world
var playButton = cc.MenuItemSprite.create(cc.Sprite.create(s_Play));
playButton.setCallback(this.onPlayClicked, this);
playButton.setPosition(cc.p(this.screenSize.width * 0.5, this.screenSize.height * 0.5));
// create a menu that will contain the button above
var menu = cc.Menu.create(playButton);
menu.setPosition(0,0);
this.addChild(menu, 1);
Notice how the callback is set for the play button. In Cocos2d-html5, we need not specify the kind of function pointer that we're setting into the callback. Since all functions are objects in JavaScript, we need to pass the handler function, and the class it belongs to, as parameters to the setCallback function. The