Search icon CANCEL
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Conferences
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Swift Game Development

You're reading from   Swift Game Development Learn iOS 12 game development using SpriteKit, SceneKit and ARKit 2.0

Arrow left icon
Product type Paperback
Published in Sep 2018
Publisher Packt
ISBN-13 9781788471152
Length 434 pages
Edition 3rd Edition
Languages
Tools
Arrow right icon
Authors (2):
Arrow left icon
Siddharth Shekar Siddharth Shekar
Author Profile Icon Siddharth Shekar
Siddharth Shekar
Stephen Haney Stephen Haney
Author Profile Icon Stephen Haney
Stephen Haney
Arrow right icon
View More author details
Toc

Table of Contents (20) Chapters Close

Preface 1. Designing Games with Swift 2. Sprites, Camera, Action! FREE CHAPTER 3. Mix in the Physics 4. Adding Controls 5. Spawning Enemies, Coins, and Power-Ups 6. Generating a Never-Ending World 7. Implementing Collision Events 8. Polishing to a Shine – HUD, Parallax Backgrounds, Particles, and More 9. Adding Menus and Sounds 10. Standing out in the Crowd with Advanced Features 11. Introduction to SceneKit 12. Choosing a Monetization Strategy 13. Integrating with Game Center 14. Introduction to Spritekit with ARKit 15. Introduction to Scenekit with ARKit 16. Publishing the Game on the App Store 17. Multipeer Augmented Reality 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...
lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime