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 now! 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
Conferences
Free Learning
Arrow right icon
iOS Game Development By Example
iOS Game Development By Example

iOS Game Development By Example: Learn how to develop an ace game for your iOS device, using Sprite Kit

eBook
$27.98 $39.99
Paperback
$48.99
Subscription
Free Trial
Renews at $19.99p/m

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 Development By Example

Chapter 2. Scenes in Sprite Kit

The Hello World game, made in the previous chapter. was the first step to Sprite Kit. We also made acquaintance with the Swift programming language, which we are going to use for iOS game development using Sprite Kit.

In this chapter, we will dive deep into various fundamentals of the Sprite Kit project and also discuss in depth about scenes in a game. We are further going to continue the development of the game, Platformer, and use it as a tool to learn Sprite Kit. We will be learning about different auto generated files in an Xcode project and about their importance. Only then will we be able to understand what scenes are, and their importance in game development. Further we will also learn how nodes play an important part in Sprite Kit and help us to improve optimization and control of our game. In this chapter, we will also learn how to add more than one scene in our game and successfully transit from one scene to another along with animating...

Device orientation in Sprite Kit

There are two types of modes, namely portrait and landscape; you can select the desired orientation for your game while setting up your project. Any time during the development of your game, you can change the orientation under the properties section of your Sprite Kit project. There are four types of orientations available:

  • Portrait
  • Upside Down
  • Landscape Left
  • Landscape Right

You can select any of the orientations depending on your game. If you want to make your game scene in portrait mode, you can select either Portrait or Upside Down options. If want to make your game in landscape mode, you can select the Landscape Left or Landscape Right option. If you want to make your game in both portrait and landscape, then you can select both the options too. Caution, if you want to make your game in both portrait and landscape mode, make sure that you have to handle the positions of sprites in your game during runtime.

Orientation in our project

As we are making a Platformer game, it's better to opt for landscape mode. Although you can select both Landscape Left and Landscape Right, it is better to opt for one orientation for easier programming. Following are the steps to do the same:

  1. Launch the Platformer project that we made in the last chapter, either by double-clicking Platformer.xcodeproj from the directory of project, or from your Xcode.
  2. Click on the Project Navigator and then click Platformer, which is just under it, on the left panel.
  3. Untick the Portrait checkbox and tick Landscape Left under the Device Orientation section:
    Orientation in our project

Revisiting project elements

Now we are going to discuss about some auto-generated files in your Sprite Kit project. They can be found on the left panel in your Xcode.

AppDelegate.swift

This file is an entry point file to our game. Its existence is crucial when the game goes from an active state to inactive state (or background state), in simple terms, when there are some sorts of temporary interruptions (such as incoming phone calls or SMS messages), or when the user force quits the application. The essence of this file in a project comes when you have to perform any specific task between the transition of active and inactive states, such as saving game data when the game is moving into a background state due to a phone call.

GameScene.sks

This file is a static archive of your scene's content. This file presents a view in your editor, it is used to save static content of a game such as spawning the position of a player, level ending position, and so on. The main essence and importance...

Adjusting the project

We are going to make some adjustments in the already-created project called Platformer. Please follow the steps listed, in order to customize the project according to our needs:

  1. Delete the GameScene.swift and GameScene.sks files present in your project. We will be recreating these files as per our need. Don't worry about the error, we are going to fix it in the next step. GameScene.swift is the default scene given by Xcode; we are deleting the default ones as we are going to create the menu Scene before the game scene. Take a look at the next screenshot:
    Adjusting the project
  2. Open GameViewController.swift and delete the code, as shown in the following screenshot:
    Adjusting the project
  3. Delete the Spaceship image from Images.xcassets. Spaceship images are not required in this project.

Now you will not see an error in your Xcode, and if you run Platformer, you will see nothing. Well, that is not what we desire. Now, before getting your feet wet in code, we need to know what we have done (almost nothing but deleting...

What is a scene?

A scene is basically a collection of different elements such as sprites, sounds, and so on, in a logical way. Suppose we want to make a menu, we'll have to put some buttons, background, and sounds in a manner that is positioned according to our needs.

A Scene object is a collection of nodes, but a scene itself acts as a node. Imagine a tree of nodes having scene objects as its root. As all nodes in the scene are positioned in defined coordinates, their linkage can be shown as:

Node (Content) → Descendant Node

This linkage of a node with its descendant(s) is very useful. Say, if you rotate a node on the top of the tree, all the nodes will be subsequently rotated.

In technical terms, Scene is an SKScene object, which holds an SKNode object (such as SKSpriteNode objects for sprites) inside a view (SKView object), so that we can render and use them. Scene is itself an SKNode object, which acts as a root node and attaches in an SKView object. Other objects required...

Device orientation in Sprite Kit


There are two types of modes, namely portrait and landscape; you can select the desired orientation for your game while setting up your project. Any time during the development of your game, you can change the orientation under the properties section of your Sprite Kit project. There are four types of orientations available:

  • Portrait

  • Upside Down

  • Landscape Left

  • Landscape Right

You can select any of the orientations depending on your game. If you want to make your game scene in portrait mode, you can select either Portrait or Upside Down options. If want to make your game in landscape mode, you can select the Landscape Left or Landscape Right option. If you want to make your game in both portrait and landscape, then you can select both the options too. Caution, if you want to make your game in both portrait and landscape mode, make sure that you have to handle the positions of sprites in your game during runtime.

Orientation in our project


As we are making a Platformer game, it's better to opt for landscape mode. Although you can select both Landscape Left and Landscape Right, it is better to opt for one orientation for easier programming. Following are the steps to do the same:

  1. Launch the Platformer project that we made in the last chapter, either by double-clicking Platformer.xcodeproj from the directory of project, or from your Xcode.

  2. Click on the Project Navigator and then click Platformer, which is just under it, on the left panel.

  3. Untick the Portrait checkbox and tick Landscape Left under the Device Orientation section:

Revisiting project elements


Now we are going to discuss about some auto-generated files in your Sprite Kit project. They can be found on the left panel in your Xcode.

AppDelegate.swift

This file is an entry point file to our game. Its existence is crucial when the game goes from an active state to inactive state (or background state), in simple terms, when there are some sorts of temporary interruptions (such as incoming phone calls or SMS messages), or when the user force quits the application. The essence of this file in a project comes when you have to perform any specific task between the transition of active and inactive states, such as saving game data when the game is moving into a background state due to a phone call.

GameScene.sks

This file is a static archive of your scene's content. This file presents a view in your editor, it is used to save static content of a game such as spawning the position of a player, level ending position, and so on. The main essence and importance of this...

Adjusting the project


We are going to make some adjustments in the already-created project called Platformer. Please follow the steps listed, in order to customize the project according to our needs:

  1. Delete the GameScene.swift and GameScene.sks files present in your project. We will be recreating these files as per our need. Don't worry about the error, we are going to fix it in the next step. GameScene.swift is the default scene given by Xcode; we are deleting the default ones as we are going to create the menu Scene before the game scene. Take a look at the next screenshot:

  2. Open GameViewController.swift and delete the code, as shown in the following screenshot:

  3. Delete the Spaceship image from Images.xcassets. Spaceship images are not required in this project.

Now you will not see an error in your Xcode, and if you run Platformer, you will see nothing. Well, that is not what we desire. Now, before getting your feet wet in code, we need to know what we have done (almost nothing but deleting...

What is a scene?


A scene is basically a collection of different elements such as sprites, sounds, and so on, in a logical way. Suppose we want to make a menu, we'll have to put some buttons, background, and sounds in a manner that is positioned according to our needs.

A Scene object is a collection of nodes, but a scene itself acts as a node. Imagine a tree of nodes having scene objects as its root. As all nodes in the scene are positioned in defined coordinates, their linkage can be shown as:

Node (Content) → Descendant Node

This linkage of a node with its descendant(s) is very useful. Say, if you rotate a node on the top of the tree, all the nodes will be subsequently rotated.

In technical terms, Scene is an SKScene object, which holds an SKNode object (such as SKSpriteNode objects for sprites) inside a view (SKView object), so that we can render and use them. Scene is itself an SKNode object, which acts as a root node and attaches in an SKView object. Other objects required for that scene...

Coordinate system


Everything in a game built in Sprite Kit is related to nodes, and it follows a node tree structure where a scene is a root node and other nodes are child nodes of it. When we put a node in the node tree, it uses its position property to place it within the coordinate system provided by its parent.

As a scene is also a node, it is placed inside the view provided by the SKView object. The code part which we deleted in viewDidLoad, GameScene, was added as a child in the SKView object. A scene uses its parent SKView object coordination system to render itself and the content within it. The coordinate system is the same as we learned in basic mathematics.

As the preceding diagram shows, if we move right from (0,0), then x will be positive, and negative if we move left from (0,0). If we move up from (0,0), then y will be positive, and negative if we move down from (0,0). Coordinate values are measured in points and when the scene is rendered, it will be converted to pixels.

All...

Creating a scene


When we create a scene, we can define many of its properties such as size, origin, and so on. as we require in our game. A scene size defines the visible area in the SKView object. Of course, we can put nodes outside this area, but they will be totally ignored by the renderer.

However, if we try to change the position property of a scene, it will be ignored by Sprite Kit because a scene is a root node in a node tree, its default value is CGPointZero. But we can move scene origin by the anchorPoint property. Default value for anchorPoint is (0.5,0.5), which indicates the center point of the screen. By reassigning a new anchorPoint property, we can change the coordinate system for its child. For example, if we set anchorPoint to (0,0), the child node of the scene will start from the bottom left of the scene.

If we make the anchorPoint (0.5, 0.5) or the middle of the screen, the child node of the scene will start from the middle of the screen. It totally depends on us and what...

Creating a node tree


A node tree for a scene is created as a parent child relation. As a scene acts similar to a root node, another node acts as a child to it. Following are some common methods used to make a node tree:

  • addChild: It adds a node to the end of the receiver's list of child nodes

  • insertChild:atIndex: It inserts a child at a specific position in the receiver's list of child nodes

If you want to remove a node from a node tree, you can use the following method:

  • removeFromParent: It removes the receiving node from its parent

Drawing order for a node tree


When a node tree renders, all its children also render. First, the parent is rendered, and then, its children, in the order they are added to parent. If you have many nodes to render in a scene, it is a difficult task to maintain them in order. For this, Sprite Kit provides a solution using the z position. You can set nodes to the z position by using the zPosition property.

When you take the z position into account, the node tree will be rendered as follows:

  • First of all, each node's global z position is calculated

  • Then, nodes are drawn in order from smallest z value to largest z value

  • If two nodes share the same z value, ancestors are rendered first, and siblings are rendered in child order

As you've just seen, Sprite Kit uses a deterministic rendering order, based on the height nodes and their positions in the node tree. But, because the rendering order is so deterministic, Sprite Kit may be unable to apply some rendering optimizations that it might otherwise apply...

Adding the first scene in our game


Now it is time to add a menu scene to our game. For this, select the Platformer folder and right-click on this folder, select New File. Select iOS | Source | Swift File and then Next. Inside Save As, give it the name MenuScene, and click on Create.

Click on your MenuScene.swift file. Now it's time to do some code stuff:

import SpriteKit
class MenuScene: SKScene
{
  //#1
  let PlayButton: SKSpriteNode
  let Background: SKSpriteNode
  //#2
  init(size:CGSize, playbutton:String, background:String)
  {
    PlayButton = SKSpriteNode(imageNamed: playbutton)
    Background = SKSpriteNode(imageNamed: background)
    super.init(size:size)
  }
  //#3
  required init?(coder aDecoder: NSCoder)
  {
    fatalError("init(coder:) has not been implemented")
  }
  //#4
  override func didMoveToView(view: SKView)
  {
    addChildToScene();

  }
  //#5
  func addChildToScene()
  {
    PlayButton.zPosition = 1
    Background.zPosition = 0
    Background.size = CGSize(width:self...

Adding another scene to our game


Create the GameScene file as we did for MenuScene:

import SpriteKit

class GameScene: SKScene
{

  let backgroundNode = SKSpriteNode(imageNamed: "BG")


  override func didMoveToView(view: SKView) {
  addBackGround()
}

  func addBackGround()
  {
    backgroundNode.zPosition = 0
    backgroundNode.size = CGSize(width:self.size.width, height:self.size.height)
    addChild(backgroundNode)
  }

  override func update(currentTime: NSTimeInterval) {

  }

}

The code is self-explanatory, we added only a background to the GameScene, the same as what we did for the MenuScene.

Left arrow icon Right arrow icon

Key benefits

  • Learn about the Sprite Kit engine and create games on the iOS platform from the ground up
  • Acquaint your Sprite Kit knowledge with Swift programming and turn your 2D game conceptualization into reality in no time
  • An abridged and focused guide to develop an exhaustive mobile game

Description

Game development has always been an exciting subject for game enthusiasts and players and iOS game development takes a big piece of this cake in terms of perpetuating growth and creativity. With the newest version of iOS and Sprite Kit, comes a series of breathtaking features such as Metal rendering support, camera nodes, and a new and improved Scene Editor. Conceptualizing a game is a dream for both young and old. Sprite Kit is an exciting framework supported by Apple within the iOS development environment. With Sprite Kit, creating stunning games has become an easy avenue. Starting with the basics of game development and swift language, this book will guide you to create your own fully functional game. Dive in and learn how to build and deploy a game on your iOS platform using Sprite Kit game engine. Go on a detailed journey of game development on the iOS platform using the Sprite Kit game engine. Learn about various features implemented in iOS 8 that further increase the essence of game development using Sprite Kit. Build an endless runner game and implement features like physics bodies, character animations, scoring and other essential elements in a game. You will successfully conceive a 2D game along with discovering the path to reach the pinnacle of iOS game development. By the end of the book, you will not only have created an endless runner game but also have in-depth knowledge of creating larger games on the iOS platform. Style and approach An easy-to-follow, comprehensive guide that makes your learning experience more intriguing by gradually developing a Sprite Kit game. This book discusses each topic in detail making sure you attain a clear vision of the subject.

Who is this book for?

This book is for beginners who want to start their game development odyssey in the iOS platform. If you are an intermediate or proficient game developer hailing from a different development platform, this book will be a perfect gateway to the Sprite Kit engine. The reader does not need to have any knowledge of Sprite Kit and building games on the iOS platform.

What you will learn

  • Learn about the Sprite Kit game engine and create indie games in no time
  • Set sail on the quest of game development career by successfully creating a runner game
  • Know more about the IDE provided by Apple for game development - Xcode
  • Get an overview of Apple's latest programming language, Swift
  • Discover the functionalities of scenes and nodes in a game
  • Explore how physics bodies work and how to add this feature into your game
  • Grasp knowledge of particle effect and shaders
  • Add a scoring system into your game to visualize high scores

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : Aug 27, 2015
Length: 220 pages
Edition : 1st
Language : English
ISBN-13 : 9781785284694
Vendor :
Apple
Languages :
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 : Aug 27, 2015
Length: 220 pages
Edition : 1st
Language : English
ISBN-13 : 9781785284694
Vendor :
Apple
Languages :
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 $5 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 $5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total $ 142.97
iOS Game Programming Cookbook
$54.99
iOS 9 Game development Essentials
$38.99
iOS Game Development By Example
$48.99
Total $ 142.97 Stars icon

Table of Contents

11 Chapters
1. An Introduction to Sprite Kit Chevron down icon Chevron up icon
2. Scenes in Sprite Kit Chevron down icon Chevron up icon
3. Sprites Chevron down icon Chevron up icon
4. Nodes in Sprite Kit Chevron down icon Chevron up icon
5. Physics in Sprite Kit Chevron down icon Chevron up icon
6. Animating Sprites, Controls, and SceneKit Chevron down icon Chevron up icon
7. Particle Effects and Shaders Chevron down icon Chevron up icon
8. Handling Multiple Scenes and Levels Chevron down icon Chevron up icon
9. Performance Enhancement and Extras Chevron down icon Chevron up icon
10. Revisiting Our Game and More on iOS 9 Chevron down icon Chevron up icon
Index Chevron down icon Chevron up icon

Customer reviews

Top Reviews
Rating distribution
Full star icon Full star icon Full star icon Full star icon Half star icon 4.3
(11 Ratings)
5 star 81.8%
4 star 0%
3 star 0%
2 star 0%
1 star 18.2%
Filter icon Filter
Top Reviews

Filter reviews by




syeda tauseef Sep 07, 2015
Full star icon Full star icon Full star icon Full star icon Full star icon 5
the book gives a very clear description of the topic and is very easy to understand
Amazon Verified review Amazon
Anil V. Sep 07, 2015
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Very helpful, and good intro into a very complicated programming environment. Must Book for all looking to dive into Sprite Kit Game engine Development.Looking Forward for more awesome Books from the author 😊
Amazon Verified review Amazon
E. Murillo Sep 25, 2015
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Must say the book helped me gain a deeper understanding of iOS game development. I like a lot that many explanations are included because not only the core subject at hand gets covered, but also the wider range of concepts and classifications that will become handy down the road.Wording is completely clear for newcomers. No assumptions are made on readers being computer theorists or object oriented purists. In fact from this book, not only I improved my Swift coding, but also my overall understanding of object oriented coding. This book is a must for anyone getting into practical swift gaming development.
Amazon Verified review Amazon
Avan Sep 13, 2015
Full star icon Full star icon Full star icon Full star icon Full star icon 5
I bought this book yesterday and I'm amazed to know that it smartly covers the iOS 9 aspects of Sprite Kit. You cannot find any material for iOS 9 but this book also introduces iOS 9 which helps the reader to make sure about the other versions and also make sure what are new stuff introduced by apple for iOS 9. As of now I have only read the first 6 chapters of the book and so far the code and the explanation is spot on. I could have deducted half star for the late intro of iOS 9 but when I flipped the pages and read about the intro the book had given, it gave me a breeze that the author has smartly taken care of the same. I have recommended the book to all the people around me and will make sure to suggest everyone around. The best thing about the book is that we are making a single game alongside instead of making multiple small games. Making multiple games confuses the reader a lot but this book has taken care of avoiding that issue by just creating a single game in the book. Too good of thought. Don't be worry about iOS 9 compatibility of this book. It covers iOS 9 well :)
Amazon Verified review Amazon
Philipp Gurevich Sep 02, 2015
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Few days before the release I was provided with reviewer copy by Packt Publishing. I thoroughly enjoyed reading this book, because of its concise manner of guiding through SpriteKit’s components, and diligently revealing their dependencies and interactions with structured approach. The book’s clear and uncluttered presentation helped me to develop strong mental map of Sprite Kit’s internal hierarchy. Coming from OpenGL background, book helped me understand the peculiarities of Sprite-based rendering. The book is invaluable tool for quick familiarization with SpriteKit, Swift and Xcode’s GUI. The book uncovers the framework by creating the example game, but instead of simple “repeat this” instructions, every major concept gets succinct introduction and frequent infographics.If you need a guide to break into SpriteKit, and develop a solid understanding of SpriteKit framework and Swift, this book fulfills these tasks gracefully.
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.