Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
iOS Game Programming Cookbook
iOS Game Programming Cookbook

iOS Game Programming Cookbook: Over 45 interesting game recipes that will help you create your next enthralling game

eBook
Mex$179.99 Mex$902.99
Paperback
Mex$1128.99
Subscription
Free Trial

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing
Table of content icon View table of contents Preview book icon Preview Book

iOS Game Programming Cookbook

Chapter 1. iOS Game Development

Since the launch of iOS devices, game development has always attracted developers in ever-increasing numbers. There are various game engines available in the market, which allow developers to start developing their games for iOS devices.

In this chapter, we will be focusing on the following topics:

  • Getting started with the SpriteKit game framework
  • Developing a mini game using SpriteKit

Introduction

Apple has launched its first game engine that allows you to create games for iOS without being dependent on the third-party game libraries. It is a very powerful framework similar to other iOS frameworks and is similar to other frameworks when it comes to its usage. It's also very easy to adopt and learn. It also supports lots of features such as physics simulations, texture atlas, gravity, restitution, animations, particle emitters, game center support, and many more. Moreover, it comes with very rich developer documentation for SpriteKit at the Apple development center. It's very useful and very well written. You might need to understand the anatomy of game development first to get started with game development in SpriteKit. There are two basic and most important terms here; one is scenes and the other is sprites. Scenes can be considered as the layers in the games. Therefore, in any game there are various layers such as the score layer, hud layer, and gameplay layer that can act as different scenes. However, any object in the scene such as a player or an enemy can be considered as a sprite.

Getting started with the SpriteKit game framework

With the release of iOS 7.0, Apple has introduced its own native 2D game framework called SpriteKit. SpriteKit is a great 2D game engine, which has support for sprite, animations, filters, masking, and most important is the physics engine to provide a real-world simulation for the game.

Apple provides a sample game to get started with the SpriteKit called Adventure Game. The download URL for this example project is http://bit.ly/Rqaeda.

This sample project provides a glimpse of the capability of this framework. However, the project is complicated to understand and for learning you just want to make something simple. To have a deeper understanding of SpriteKit-based games, we will be building a bunch of mini games in this book. To understand the basics of the SpriteKit game programming, we will build a mini AntKilling game in this chapter.

Getting ready

To get started with iOS game development, you have the following prerequisites for SpriteKit:

  • You will need the Xcode 5.x
  • The targeted device family should be iOS 7.0+
  • You should be running OS X 10.8.X or later

If all the above requisites are fulfilled, then you are ready to go with the iOS game development. So let's start with game development using iOS native game framework. We will be building a mini game in the chapter and will be taking it forward in every chapter to add more and more features and enhancements.

How to do it...

Let's start building the AntKilling game. Perform the following steps to create your new SpriteKit project:

  1. Start your Xcode. Navigate to File | New | Project....
    How to do it...
  2. Then from the prompt window, navigate to iOS | Application | SpriteKit Game and click on Next.
    How to do it...
  3. Fill all the project details in the prompt window and provide AntKilling as the project name with your Organization Name, device as iPhone, and Class Prefix as AK. Click on Next.
    How to do it...
  4. Select a location on the drive to save the project and click on Create.
  5. Then build the sample project to check the output of the sample project. Once you build and run the project with the play button, you should see the following on your device:
    How to do it...

How it works...

The following are the observations of the starter project:

  1. As you have seen, the sample project of SpriteKit plays a label with a background color.
  2. SpriteKit works on the concept of scenes, which can be understood as the layers or the screens of the game. There can be multiple scenes working at the same time; for example, there can be a gameplay scene, hud scene, and the score scene running at the same time in the game.

Now we can look into the project for more detail arrangements of the starter project. The following are the observations:

  1. In the main directory, you already have one scene created by default called AKMyScene.
  2. Now click on AKMyScene.m to explore the code to add the label on the screen. You should see something similar to the following screenshot:
    How it works...
  3. Now we will be updating this file with our code to create our AntKilling game in the next sections.
  4. We have to fulfill a few prerequisites to get started with the code, such as locking the orientation to landscape as we want a landscape orientation game.
  5. To change the orientation of the game, navigate to AntKilling project settings | TARGETS | General. You should see something similar to the following screenshot:
    How it works...
  6. Now in the General tab, uncheck Portrait from the device orientation so that the final settings should look similar to the following screenshot:
    How it works...
  7. Now build and run the project. You should be able to see the app running in landscape orientation.
    How it works...
  8. The bottom-right corner of the screen shows the number of nodes with the frame rate.

Developing a mini game using SpriteKit

Now you have learned enough about SpriteKit. To explore this in more depth, let's create a mini game that will help you to understand the concepts in much more detail. We are going to create an AntKilling game. In this game, we will place an ant on the screen; the ant will animate when you click on it.

Getting ready

We will use the project we created in the previous section. To create a mini game, we will have to update the source files we have got with the starter project. Now it's time to update AKMyScene to hold our ant sprites.

Before getting into the steps to update the code, download all the resources for this chapter and check for the assets folder, which has all the images used in this project.

How to do it...

Execute the following steps sequentially to create a mini game:

  1. Open the Resources folder and add them to your Xcode project.
  2. While adding the resources to the Xcode, make sure that the selected target is AntKilling and Copy items into destination group's folder (if needed) is checked.
    How to do it...
  3. Now delete all the existing code from AKMyScene.m and make it look similar to the following screenshot:
    How to do it...
  4. Now, firstly, we have created a private interface to declare private variables:
    @interface AKMyScene ()
    @property (nonatomic) SKSpriteNode *ant;
    @end
  5. Then, in the init method, we have printed a log to print the size of the screen:
    NSLog(@"Size: %@", NSStringFromCGSize(size));
  6. Now we will change the screen background color to white using the following line of code:
    self.backgroundColor = [SKColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1.0];
  7. Then we will change the screen background color to white using the backgroundColor property in the following line of code.
    self.backgroundColor = [SKColor colorWithRed:1.0 green:1.0 blue:1.0 alpha:1.0];
  8. In the following line of code, we are creating a sprite object using the spriteNodeWithImageNamed method and passing the image name to the same. Then we have positioned it to 100, 100 of the screen, which is in the bottom-left corner of the screen. Then finally we have added it as a child.
    self.ant = [SKSpriteNode spriteNodeWithImageNamed:@"ant.jpg"];
    self.ant.position = CGPointMake(100, 100);
    [self addChild:self.ant];

Tip

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.

In games, we have to keep two sets of images, one for the normal display and the second for the retina display. In the preceding block of code, we have provided the name of the sprite as ant.jpg, which is going to autoreference to ant@2x.jpg for the retina devices.

Now build and run your application; you should see something similar to the following screenshot:

How to do it...

Now as you can see, the screen color has changed to white but there is no ant on the screen. This means something has gone wrong in the code. So, now let's check our logs, which should be printing the following:

2014-07-22 19:13:27.019 AntKilling[1437:60b] Size: {320, 568}

So the scene size is wrong. The scene should print 568 as the width and 320 as the height but it's printing the opposite. To debug this, navigate to your AKViewController.m viewDidLoad method. You can find the complete code for this function at AntKilling/AntKilling/AKViewController.m.

So, from this method, we can see that our scene is absorbing the size from the bounds of the view and this viewDidLoad method is invoked even before the view has been added to the view hierarchy. So it has not responded to the layout changes. Thus, because of the inconsistent view bounds our scene is getting started with wrong bounds.

To solve this issue, we have to move the scene startup code in the viewWillLayoutSubviews method. After removing the code from the viewDidLoad method and pasting it to viewWillLayoutSubviews, you can find the complete code for this function at AntKilling/AntKilling/AKViewController.m.

Now, once again build and run the app; you should see the following output:

How to do it...

How it works...

So, congrats! You have fixed the issue. Your ant has now appeared on the screen at the given location. If you observe closely, you can see that the status bar is at the top of the game, which does not look great. To remove the status bar from the screen, open your AntKilling-Info.plist file and add an UIViewControllerBasedStatusBarAppearance attribute with value NO. Your .plist file should look like the following screenshot:

How it works...

Build and run your project again; you should be able to see the game without the status bar now:

How it works...

This looks perfect now; our ant has been residing on the screen as expected. So now our next objective is to animate the ant when we tap on it. To accomplish this, we need to add the following code in the AKMyScene.m file, just below your initWithSize method:

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
  UITouch *touch = [touches anyObject];
  CGPoint positionInScene = [touch locationInNode:self];
  SKSpriteNode *touchedNode = (SKSpriteNode *)[self nodeAtPoint:positionInScene];
  if (touchedNode == self.ant) {
    SKAction *sequence = [SKAction sequence:@[[SKAction rotateByAngle:degreeToRadian(-3.0f) duration:0.2],
    [SKAction rotateByAngle:0.0 duration:0.1],
    [SKAction rotateByAngle:degreeToRadian(3.0f) duration:0.2]]];
    [touchedNode runAction:[SKAction repeatActionForever:sequence]];
  }
}

float degreeToRadian(float degree) {
  return degree / 180.0f * M_PI;
}

You can find the complete code for this function at AntKilling/AntKilling/AKMyScene.m.

So, now let's go line-by-line to understand what we have done so far. To begin with, we have added the - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event method to the grab all the touches on the scene.

Now in the function the first line allowed you to grab touch using CGPoint positionInScene = [touch locationInNode:self];.

In the next line, we grabbed the touch and converting it to the CGPoint positionInScene = [touch locationInNode:self]; location.

In the following line, we fetched the sprite, which has been touched:

SKSpriteNode *touchedNode = (SKSpriteNode *)[self nodeAtPoint:positionInScene];

Now, once you have the sprite object, compare and check whether the select object is the ant bug. If it's the ant bug, then animate the object by adding the following line of code:

SKAction *sequence = [SKAction sequence:@[[SKAction rotateByAngle:degreeToRadian(-3.0f) duration:0.2],[SKAction rotateByAngle:0.0 duration:0.1],[SKAction rotateByAngle:degreeToRadian(3.0f) duration:0.2]]];
[touchedNode runAction:[SKAction repeatActionForever:sequence]];

Using the SKAction class, you can execute various sequence of animations such as rotation, moveBy, moveTo, and so on. Also all the rotate methods accept the angle in radians. So to achieve the rotation, we must convert the degree to radians before passing to any rotate function.

Now, this code will animate the selected sprite. Build and run the project and you will see the ant animating on tap.

You will soon notice that on tapping the ant, it starts animating, but there is no way to stop this. So now let's add a way to stop this animation once you click anywhere on the scene. Navigate to the - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *) event method, and update it to the following code:

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
  UITouch *touch = [touches anyObject];
  CGPoint positionInScene = [touch locationInNode:self];
  SKSpriteNode *touchedNode = (SKSpriteNode *)[self nodeAtPoint:positionInScene];
  if (touchedNode == self.ant) {
    SKAction *sequence = [SKAction sequence:@[[SKAction rotateByAngle:degreeToRadian(-3.0f)duration:0.2],
    [SKAction rotateByAngle:0.0 duration:0.1],
    [SKAction rotateByAngle:degreeToRadian(3.0f) duration:0.2]]];
    [touchedNode runAction:[SKAction repeatActionForever:sequence]];
  } else {
  [self.ant removeAllActions];
  }
}

Now if you observe closely, you can see that we have added an if-else condition to check whether the touch is made on the ant, which allows it to animate; when the touch is made anywhere outside the screen, stop all the actions. To stop all the actions on the sprite, we can use the removeAllActions method on the sprite.

Left arrow icon Right arrow icon

Description

This book is for developers who are willing to explore iOS game programming in depth. Good knowledge level and understanding of iOS game development will be an added advantage. You should already have a working installation of Xcode and Sprite kit.

Who is this book for?

This book is for developers who are willing to explore iOS game programming in depth.

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Mar 25, 2015
Length: 300 pages
Edition : 1st
Language : English
ISBN-13 : 9781784398255
Vendor :
Apple
Languages :
Concepts :
Tools :

What do you get with a Packt Subscription?

Free for first 7 days. $19.99 p/m after that. Cancel any time!
Product feature icon Unlimited ad-free access to the largest independent learning library in tech. Access this title and thousands more!
Product feature icon 50+ new titles added per month, including many first-to-market concepts and exclusive early access to books as they are being written.
Product feature icon Innovative learning tools, including AI book assistants, code context explainers, and text-to-speech.
Product feature icon Thousands of reference materials covering every tech concept you need to stay up to date.
Subscribe now
View plans & pricing

Product Details

Publication date : Mar 25, 2015
Length: 300 pages
Edition : 1st
Language : English
ISBN-13 : 9781784398255
Vendor :
Apple
Languages :
Concepts :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
$19.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
$199.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just Mex$85 each
Feature tick icon Exclusive print discounts
$279.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just Mex$85 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total Mex$ 3,262.97
iOS Game Development By Example
Mex$1004.99
iPhone Game Blueprints
Mex$1128.99
iOS Game Programming Cookbook
Mex$1128.99
Total Mex$ 3,262.97 Stars icon
Banner background image

Table of Contents

13 Chapters
1. iOS Game Development Chevron down icon Chevron up icon
2. SpriteKit Chevron down icon Chevron up icon
3. Animations and Texture Chevron down icon Chevron up icon
4. Particle System and Game Performance Chevron down icon Chevron up icon
5. Adding Music to iOS Games and an Introduction to iCloud Chevron down icon Chevron up icon
6. Physics Simulation Chevron down icon Chevron up icon
7. Adding Reality to Games Chevron down icon Chevron up icon
8. Introduction to Game Math and Physics Chevron down icon Chevron up icon
9. Autonomous Moving Agents Chevron down icon Chevron up icon
10. 3D Game Programming with OpenGL Chevron down icon Chevron up icon
11. Getting Started with Multiplayer Games Chevron down icon Chevron up icon
12. Implementing Multiplayer Games Chevron down icon Chevron up icon
Index Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Half star icon Empty star icon 3.5
(4 Ratings)
5 star 0%
4 star 50%
3 star 50%
2 star 0%
1 star 0%
siddharth shekar Jun 30, 2015
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
This is a very good book for beginners. The book goes in-depth into making sure that the concepts are explained in detail. Also apart from just explaining the technology the book also covers essential skills like AI programming, Physics and Multiplayer game development which are additionally required for game development. The book also touches on OpenGLES and covers in depth 3D texture mapping and animation for anyone trying to make the move from 2D to 3D game development. I heartily recommend this book anyone who are getting into iOS game development.
Amazon Verified review Amazon
Mahaneesh chandra Jun 10, 2015
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
One of the best purchase of mine so far. I had plenty of doubts before purchasing this book. But the author made it easy to read and follow. Even the complicated stuffs are explained way easier. I can say the author has put lot of efforts in bringing different flavours together here to help us explore more possibilities of using iOS game features in a step by step process. A very handy book I recommend to all.
Amazon Verified review Amazon
Ess Feb 23, 2016
Full star icon Full star icon Full star icon Empty star icon Empty star icon 3
Beware! The code in this book is in Objective C. So, if you're just starting out with development, chances are you want a book with code written in Swift.The book seems to have some nice features to it and the authors discuss interesting topics, however I was discouraged by seeing the choice on programming language given that Swift is the new way to go.
Amazon Verified review Amazon
Bo Kalvslund May 08, 2015
Full star icon Full star icon Full star icon Empty star icon Empty star icon 3
The book uses Objective-C to my surprice - Swift is the s***.But Good book and examples
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

What is included in a Packt subscription? Chevron down icon Chevron up icon

A subscription provides you with full access to view all Packt and licnesed content online, this includes exclusive access to Early Access titles. Depending on the tier chosen you can also earn credits and discounts to use for owning content

How can I cancel my subscription? Chevron down icon Chevron up icon

To cancel your subscription with us simply go to the account page - found in the top right of the page or at https://subscription.packtpub.com/my-account/subscription - From here you will see the ‘cancel subscription’ button in the grey box with your subscription information in.

What are credits? Chevron down icon Chevron up icon

Credits can be earned from reading 40 section of any title within the payment cycle - a month starting from the day of subscription payment. You also earn a Credit every month if you subscribe to our annual or 18 month plans. Credits can be used to buy books DRM free, the same way that you would pay for a book. Your credits can be found in the subscription homepage - subscription.packtpub.com - clicking on ‘the my’ library dropdown and selecting ‘credits’.

What happens if an Early Access Course is cancelled? Chevron down icon Chevron up icon

Projects are rarely cancelled, but sometimes it's unavoidable. If an Early Access course is cancelled or excessively delayed, you can exchange your purchase for another course. For further details, please contact us here.

Where can I send feedback about an Early Access title? Chevron down icon Chevron up icon

If you have any feedback about the product you're reading, or Early Access in general, then please fill out a contact form here and we'll make sure the feedback gets to the right team. 

Can I download the code files for Early Access titles? Chevron down icon Chevron up icon

We try to ensure that all books in Early Access have code available to use, download, and fork on GitHub. This helps us be more agile in the development of the book, and helps keep the often changing code base of new versions and new technologies as up to date as possible. Unfortunately, however, there will be rare cases when it is not possible for us to have downloadable code samples available until publication.

When we publish the book, the code files will also be available to download from the Packt website.

How accurate is the publication date? Chevron down icon Chevron up icon

The publication date is as accurate as we can be at any point in the project. Unfortunately, delays can happen. Often those delays are out of our control, such as changes to the technology code base or delays in the tech release. We do our best to give you an accurate estimate of the publication date at any given time, and as more chapters are delivered, the more accurate the delivery date will become.

How will I know when new chapters are ready? Chevron down icon Chevron up icon

We'll let you know every time there has been an update to a course that you've bought in Early Access. You'll get an email to let you know there has been a new chapter, or a change to a previous chapter. The new chapters are automatically added to your account, so you can also check back there any time you're ready and download or read them online.

I am a Packt subscriber, do I get Early Access? Chevron down icon Chevron up icon

Yes, all Early Access content is fully available through your subscription. You will need to have a paid for or active trial subscription in order to access all titles.

How is Early Access delivered? Chevron down icon Chevron up icon

Early Access is currently only available as a PDF or through our online reader. As we make changes or add new chapters, the files in your Packt account will be updated so you can download them again or view them online immediately.

How do I buy Early Access content? Chevron down icon Chevron up icon

Early Access is a way of us getting our content to you quicker, but the method of buying the Early Access course is still the same. Just find the course you want to buy, go through the check-out steps, and you’ll get a confirmation email from us with information and a link to the relevant Early Access courses.

What is Early Access? Chevron down icon Chevron up icon

Keeping up to date with the latest technology is difficult; new versions, new frameworks, new techniques. This feature gives you a head-start to our content, as it's being created. With Early Access you'll receive each chapter as it's written, and get regular updates throughout the product's development, as well as the final course as soon as it's ready.We created Early Access as a means of giving you the information you need, as soon as it's available. As we go through the process of developing a course, 99% of it can be ready but we can't publish until that last 1% falls in to place. Early Access helps to unlock the potential of our content early, to help you start your learning when you need it most. You not only get access to every chapter as it's delivered, edited, and updated, but you'll also get the finalized, DRM-free product to download in any format you want when it's published. As a member of Packt, you'll also be eligible for our exclusive offers, including a free course every day, and discounts on new and popular titles.