Haxe Game Development Essentials - Sample Chapter
Haxe Game Development Essentials - Sample Chapter
ee
P U B L I S H I N G
pl
C o m m u n i t y
E x p e r i e n c e
D i s t i l l e d
$ 29.99 US
19.99 UK
Sa
m
Jeremy McCurdy
Jeremy McCurdy
ActionScript, C#, and Haxe for over four years. He has developed games targeted
at iOS, Android, Windows, OS X, Flash, and HTML5. He has worked on games that
have had millions of gameplay sessions, and has built games for many major North
American television networks.
He is the games technical lead at REDspace, an award-winning interactive studio
that has worked for some of the world's largest brands. They are located in Nova
Scotia, Canada, and have been building awesome experiences for 15 years.
Preface
Developing games that can reach a wide audience can often be a serious challenge.
A big part of the problem is figuring out how to make a game that will work on a
wide range of hardware and operating systems. This is where Haxe comes in.
Over the course of this book, we'll look at getting started with Haxe and the
HaxeFlixel game engine, build a side-scrolling shooter game that covers the
core features you need to know, and prepare the game for deployment to
multiple platforms.
After completing this book, you will have the skills you need to start producing
your own cross-platform Haxe-driven games!
Preface
Chapter 7, Deploying to Multiple Platforms, shows how to take our completed game
and build it to work on desktop, web, and mobile platforms.
Chapter 8, What's Next?, looks at game features to expand on and at resources to
continue learning.
Getting Started
In this chapter, we're going to see what Haxe is, how it will enable you to create
awesome multiplatform games, and then we'll install all of the tools we'll need to
develop with. After setting things up, we'll work with a quick Hello World example
to make sure that everything works and we're ready to start making games!
Here's a rundown of the sections in this chapter:
What's Haxe?
Installation
Hello World
Summary
What's Haxe?
Haxe is an open source programming toolkit that is composed of a language,
compiler, and command-line interface. It is heavily inspired by ActionScript 3, with
some tweaks here and there to add functionality. It also draws some inspiration
from C#. It's so similar that at a glance, Haxe code could easily be confused for
ActionScript. This doesn't mean that you have to know ActionScript to learn Haxe,
but it does help. Knowing an object-oriented language, such as C# or Java, will also
give you a leg up.
Haxe compiles to several different platforms, allowing you to have one codebase
that will work in browsers, desktop operating systems, and on mobile devices.
In case you were wondering about the pronunciation, Haxe is pronounced Hex,
though many people pronounce it Hacks.
[1]
Getting Started
OpenFL
OpenFL is a framework built on top of Haxe; it adds additional API functionality
and provides build tools to streamline your workflow. Most of the API changes it
introduces are meant to help mimic the ActionScript 3 API. For example, it adds
support for Flash's Stage 3D mode, text formatting, and bitmap data.
OpenFL also uses the Lime library, which is a library that helps to ensure
consistent cross-platform support so that builds for different platforms don't
behave radically differently. It covers things such as cross-platform audio,
rendering, and asset management.
Some of our build commands will be executed using Lime, and that's pretty much
all we'll be directly using it for.
HaxeFlixel
HaxeFlixel is a game engine that's built on top of OpenFL. It was originally based
on the ActionScript 3 game engine named Flixel, and has since branched off on its
own. It's well documented and has a solid community, making it an ideal engine
for people who want to learn how to make games with Haxe.
HaxeFlixel supports the following features:
Collision detection
Particles
Tilemaps
Bitmap fonts
Pathfinding
Object pooling
Tweening
GPU acceleration
That's just a handful of the features of the engine; it's very robust. HaxeFlixel
will help us start building high-quality games much faster than doing everything
from scratch.
[2]
Chapter 1
Installation
Now that you have a good understanding of what we'll be using, let's start installing
what we'll need. Haxe, OpenFL, and HaxeFlixel are all designed to be easy to set up,
so this is going to be pretty straightforward.
Installing Haxe
Go to http://haxe.org/download/ and download the installer for your
operating system. Run the installer; be sure to install both Haxe and Neko
when given the option.
This will install the Haxe framework, which includes Haxelib, a useful tool for
installing Haxe frameworks and libraries. You will typically use this to install
all Haxe libraries, which will make the installation of OpenFL and HaxeFlixel
incredibly straightforward.
OpenFL
To install OpenFL, open a command window (or terminal on OS X and Linux).
Next, run the following commands:
haxelib install openfl
haxelib -notimeout run openfl setup
These two commands will download, install, and set up the OpenFL framework and
all of the libraries it needs. The notimeout flag prevents the setup from timing out
before it completes. This is useful because the OpenFL setup will download quite a
number of files, and it can time out if your internet connection is a little slow.
When asked if you want to install OpenFL, press Y. On Mac and Linux, you may
be asked to enter your password. After this, OpenFL will be installed and you'll be
good to go!
Setting up an IDE
Before installing HaxeFlixel, it's important to install a code-editing tool, because you
will be prompted to choose one during the HaxeFlixel setup. Your operating system
will be a factor in choosing the best tool for you.
[3]
Getting Started
Windows users are able to use FlashDevelop, which is a fully featured IDE that will
work with Haxe out of the box. The best part of using FlashDevelop is that you can
debug your games by targeting Flash and using the Flash debug player. This will
allow you to put in breakpoints, see console logs, and inspect variables. You can
download the latest version by going to http://flashdevelop.org. If you are
using Windows, I highly recommend using it.
For Mac and Linux users, the best tool available is Sublime Text 2. It's a solid
code-editing tool, though it lacks support for breakpoints, console logs, and variable
inspection. You can download the latest version by going to http://sublimetext.
com. You can also use Sublime Text on Windows if you prefer it.
To make Sublime Text a more effective Haxe editing tool, you should install the
Haxe plugin. The easiest way to install it is using package control, which you can
install using the steps located at https://packagecontrol.io/installation#st2.
After installing package control, use Ctrl + Shift + P (Windows or Linux) or cmd +
Shift + P (Mac) to bring up the command palette. Start typing in package and then
navigate down to Install Package. You will then see a list of available packages to
install. Type in Haxe to find the package named Haxe. Install that and you're
good to go!
Installing HaxeFlixel
To install HaxeFlixel, run these commands:
haxelib install flixel
haxelib install flixel-tools
haxelib run flixel-tools setup
You will then be prompted several times during the setup. Here's what you
should do:
1. When a command appears asking if you want to set up Flixel, press Y.
2. When asked if you would like to download flixel-demos and flixeltemplates, press Y.
3. When prompted to enter an author name, either type in your name or leave
the field blank. It will automatically use that name when creating project
templates.
[4]
Chapter 1
4. When asked to choose your default IDE, enter the number corresponding to
your development tool of choice.
5. Choose either Y or N when asked if you want to automatically open created
templates and demos with your IDE of choice. This will just immediately
open your project in your IDE instead of requiring you to navigate your
filesystem.
6. On Macs, if you chose to have templates and demos automatically open,
you will be asked whether or not you want to run a symlink command.
Press Y.
If you ever need to change these settings, you can run the Flixel tools setup
command again.
Flash
Haxe and OpenFL will build to Flash out of the box, so there's not really anything
special you have to do in order to deploy to Flash. That said, to debug Flash content
you should download the Flash debug player.
On Windows, you will be able to place breakpoints and inspect variables; on Mac,
you will just get popups with stack traces when you get errors, which is still very
useful. Unfortunately, Linux users will be unable to debug Flash in the browser,
but you will still be able to use the content debugger application.
You can download the debug versions of the Flash player at https://www.adobe.
com/support/flashplayer/downloads.html.
To debug Flash without a browser, download the projector content
debugger application for your operating system. If you intend to
primarily use the projector application, make sure that you set it up
as the default application to run when loading SWF files.
[5]
Getting Started
To debug Flash in a browser, you will need to download different plugins based on
the browser you intend to use. Here are some quick guidelines you can follow:
Android
OpenFL makes getting the tools you need to deploy to Android much easier than it
typically is. Normally, this would involve downloading some tools and installing
a bunch of SDKs. OpenFL has a tool that will guide you through the process as fast
as possible.
Before using OpenFL's tool, ensure that you have the Java runtime installed. You can
download it from https://java.com/en/download/. After installing the runtime,
you can begin the Android setup process.
For Windows users, run this command to get started:
openfl setup android
For Mac and Linux users, run the command using sudo, like so:
sudo openfl setup android
After using sudo, you will have to enter your password to continue.
You will then be prompted several times during the setup. Here's what you
should do:
Press Y when asked if you want to download and install the Android SDK.
When asked to enter an output directory for the Android SDK, either enter a
new path or just hit Enter to choose the default directory.
Press Y when asked whether or not you want to download and install the
Android NDK.
When asked to enter an output directory for the Android NDK, either enter
in a new path or just hit Enter to choose the default directory.
Press Y when asked whether or not you want to download and install
Apache Ant.
When asked to enter an output directory for Apache Ant, either enter in a
new path or just hit Enter to choose the default directory.
[6]
Chapter 1
Press Y when asked whether or not you want to download and install the
Java JDK. Press Y when asked to be taken to the download site of the JDK.
Follow the download links on the site to download the JDK installer, and run
and install it before continuing.
When asked to enter the path to the Android SDK, either you can enter
a custom path type in it and continue, or hit Enter to continue with the
default path.
When asked to enter the path to the Java JDK, type in the path you used to
install the JDK earlier.
iOS
The setup process for iOS development is much simpler. Of course, in order to develop
iOS games, you will need to use Max OS X and be a member of Apple's iOS developer
program. You can sign up for the program by going here: https://developer.
apple.com/programs/ios/. You will also need to install the latest version of Xcode,
Apple's development tool, to develop iOS and OS X applications. You can download it
by going to the Mac App store and searching for Xcode.
[7]
Getting Started
After Xcode has been installed, run this command in the terminal:
sudo lime setup ios
After using sudo, you will have to enter your password to continue.
When asked to download and install Apple Xcode, press N. This is only for users
who haven't installed Xcode yet. It's easier to just install Xcode in advance like
we did.
Desktop
HaxeFlixel can also be built to desktop targets. When you want to build your
games for a particular desktop operating system, you will need to use that operating
system to make the build. For example, you can't build a Mac game on Windows
or vice versa.
When building for Windows, you will need to install a version of Visual Studio,
Microsoft's application development tool that can build C++ and can target
Windows 32-bit. If you don't already have a copy of Visual Studio that meets
the requirements, you can download Visual Studio C++ 2010 Express at
http://go.microsoft.com/?linkid=9709949.
After installing Visual Studio, you will also need to run this command:
openfl setup windows
When building for OS X, you will need to install Xcode. If you didn't install Xcode as
part of the iOS setup, please refer to the section on how to download and install it.
Once Xcode is installed, run this command:
openfl setup mac
[8]
Chapter 1
Hello World
Now that we have everything we need installed, we should make sure that Haxe,
OpenFL, and HaxeFlixel are all up and running. To do this, we'll create a new project
using the command line, run it, and then add an image to the screen to ensure that
we can make changes.
Creating a project
To create a project, open up a command or terminal window and navigate to the
folder in which you want your game's folder to be created.
After doing this, enter this command:
flixel tpl -n "HelloWorld"
This will create a new folder using the standard HaxeFlixel project template. It
will also create project files for your code-editing tool of choice, allowing for quick
integration out of the box.
If HaxeFlixel doesn't automatically open your project in your code-editing
tool, open it in the tool manually. For FlashDevelop users, double-click on
the .hxproj file in the project's folder. For Sublime Text users, drag your
project's folder into an empty Sublime window.
A number of Haxe classes with the file extension .hx will be created. These are the
base files you need to get a basic HaxeFlixel project up and running. We'll be going
over the project's structure throughout the book, so it's not important to know what
everything means right now.
[9]
Getting Started
To create a build using the command line, navigate to your project's folder and enter
this command:
lime test flash
The project should build and then open with your operating system's default
application for running .swf files. When the .swf file loads, you'll briefly see the
HaxeFlixel logo and then you'll be presented with a blank screen.
Copying assets
We're going to need the image that we want to display, so let's get that now. In the
assets provided for this chapter, there is an image named HelloWorld.png. Copy it
to the images folder under assets in your project's directory.
Making changes
Now that we have the image copied to the template project, let's add the traditional
Hello World image to the screen.
Open MenuState.hx and navigate to the Create function. It will look like this:
override public function create():Void
{
super.create();
}
This will create a new variable of the FlxSprite class. It will then load in the image
we just copied over, and then finally add the image to the screen. We'll go into more
detail about how to use the FlxSprite class and work with loaded assets later, but
that's a quick rundown of what's happening.
All that's left to do is to run the project to see your changes! In FlashDevelop, you
just need to press the play button. For Sublime Text users, press Ctrl + Enter.
To create a build using the command line, enter the test command again:
lime test flash
[ 10 ]
Chapter 1
That's it! You should see your SWF load and display the text Hello world!. If
something along the way didn't work, take some time to review the chapter to see
where things went wrong.
Summary
In this chapter, you learned what Haxe, OpenFL, and HaxeFlixel are, and how they
will streamline multiplatform game development. You learned how to install and set
up Haxe, OpenFL, HaxeFlixel, and a code-editing tool. You then learned how to set
up the tools you'll need for cross-platform development. Finally, you learned how to
build and run your very first Haxe project. These skills will enable you to create and
set up projects as you see fit.
You now have everything you need to dive head first into Haxe game development!
In the next chapter, we're going to look at the Haxe language and start building the
foundation of your first HaxeFlixel game.
[ 11 ]
www.PacktPub.com
Stay Connected: