Book Image

Swift Game Development - Third Edition

By : Siddharth Shekar, Stephen Haney
Book Image

Swift Game Development - Third Edition

By: Siddharth Shekar, Stephen Haney

Overview of this book

Swift is the perfect choice for game development. Developers are intrigued by Swift and want to make use of new features to develop their best games yet. Packed with best practices and easy-to-use examples, this book leads you step by step through the development of your first Swift game. The book starts by introducing Swift's best features – including its new ones for game development. Using SpriteKit, you will learn how to animate sprites and textures. Along the way, you will master physics, animations, and collision effects and how to build the UI aspects of a game. You will then work on creating a 3D game using the SceneKit framework. Further, we will look at how to add monetization and integrate Game Center. With iOS 12, we see the introduction of ARKit 2.0. This new version allows us to integrate shared experiences such as multiplayer augmented reality and persistent AR that is tied to a specific location so that the same information can be replicated on all connected devices. In the next section, we will dive into creating Augmented Reality games using SpriteKit and SceneKit. Then, finally, we will see how to create a Multipeer AR project to connect two devices, and send and receive data back and forth between those devices in real time. By the end of this book, you will be able to create your own iOS games using Swift and publish them on the iOS App Store.
Table of Contents (22 chapters)
Swift Game Development Third Edition
Contributors
Preface
Other Books You May Enjoy
Index

Animations for damage and game over


We will use SKAction sequences to create fun animations when the player takes damage. By combining actions, we will grant temporary safety after the player hits an enemy and is in a damaged state. We will show a fade animation that slowly pulses at first and then speeds up as the safe state starts to wear off.

The damage animation

To add the new animation, add this code at the bottom of the Player class' createAnimations function:

// --- Create the taking damage animation --- 
let damageStart = SKAction.run { 
    // Allow the penguin to pass through enemies: 
    self.physicsBody?.categoryBitMask = 
        PhysicsCategory.damagedPenguin.rawValue 
} 
// Create an opacity pulse, slow at first and fast at the end: 
let slowFade = SKAction.sequence([ 
    SKAction.fadeAlpha(to: 0.3, duration: 0.35), 
    SKAction.fadeAlpha(to: 0.7, duration: 0.35) 
    ]) 
let fastFade = SKAction.sequence([ 
    SKAction.fadeAlpha(to: 0.3, duration: 0.2), 
    SKAction.fadeAlpha...