iOS & Swift

iOS Apprentice

In this iOS programming book for beginners, you'll learn how to build five complete iOS and Swift apps by following easy step-by-step tutorials. By Joey deVilla & Eli Ganim.

Read for Free with the Personal Plan* * Includes this and all other books in our online library See all benefits
Buy Individually $59.99* *Includes access to all of our online reading features.
Leave a rating/review
Download materials
Comments
Save for later
Share

Who is this for?

This book is for anyone completely new to Swift and iOS development — or for those that just need a little brushing-up!

Covered concepts

  • Working with Xcode
  • Coding in Swift
  • Building user interfaces
  • Modelling and persisting data
  • GPS and image data
  • Accessing remote APIs
  • iPad development
  • Publishing to the App Store
For Complete Beginners! If you’re completely new to Swift and iOS development (or need a brush-up), this is the series for you.

The iOS Apprentice is a series of epic-length tutorials for beginners where you’ll learn how to build four complete apps from scratch.

Each new app will be a...

more

Getting Started with SwiftUI

This section introduces you to the first of the five apps you’ll build throughout this book: Bullseye. It’s a simple game that challenges the user to move a slider to a specific position without any hints or markers. While it won’t make you an App Store millionaire, the exercise of writing it will introduce you to the basics of writing iOS apps.

This section will introduce you to several things you’ll use when coding apps. You’ll be introduced to Xcode, the integrated development environment for writing programs for Apple devices. You’ll also be introduced to Swift, Apple’s programming language, which has grown to become one of the most popular among programmers because it’s simple, powerful, and fun.

Finally, you’ll get your first taste of something that even the most experienced iOS developers haven’t had much time to try: SwiftUI. It’s the new way to build user interfaces for Apple platforms, and like the programming language from which it takes its name, it’s simple and powerful. The first two apps that you’ll make in this book will give you a great head start in building interfaces with SwiftUI.

This section aims to be beginner-friendly, and you may be tempted to skip it. Please don’t, especially if you’re new to iOS development. You’ll need the fundamentals introduced in this section for later parts of the book, and you’ll miss out on the basics of the all-new SwiftUI.

Toggle description
In this book, you're about to deep dive into the latest and greatest Swift and iOS best practices. Throughout this five-section book, you will build four iOS projects using both UIKit and SwiftUI. Good luck!
Toggle description
Take the first step of building a SwiftUI game by creating your iOS project, add some interactivity with a UIButton and learn all about the anatomy of an app.
Toggle description
Bullseye is all about the slider, get sliding in this chapter by using the Slider control and learn all about different Swift data types.
Toggle description
In this chapter, you'll be well on your way to a working game. Learn all about generating random numbers and how best to improve your code afterward.
Toggle description
At this point, you have created a fully functional game, wow! It's time to take a step back and look at best practices in the industry. It's time to clean up some code and make it more readable for the future!
Toggle description
Apps are known for their clean and simple UI. We will spice up the artwork in this chapter and make it look like a *real* game. We will also make improvements to landscape orientation.
Toggle description
To finish our game we will add some animations, an icon, and display name ready for the App Store!

Checklists

In this section, you’ll build Checklists. As you may have gathered from the name, it’s a TODO app that lets the user create, manage, and track items in one or more lists. Lists are a key part of many apps, and the lessons you’ll learn while building Checklists will serve you well when you start coding your creations.

You’ll make a multi-screen app, which will teach you the concepts of navigating from screen to screen, and sharing information between screens. You’ll see how SwiftUI makes it easy to display lists of data. You’ll also learn about data models (how data is represented in a program) and data persistence (saving data). And finally, you’ll use local notifications to present the user with timely reminders and important messages that appear at the top of the screen. By the end of this section, you’ll be able to write some basic (but useful) productivity apps.

Toggle description
It's time to start your next iOS project. Are you ready for the challenge? In this chapter, we will commence our next app using SwiftUI, Checklists. Prepare for NavigationView, Arrays, Loops and removing items from the list.
Toggle description
A Checklist app without being able to tick off the items? In this chapter, you will add the toggle for a Checklist item.
Toggle description
You have eagerly made great progress on creating a TODO list app by adding the checked status. In this chapter, you will start adding more features and start thinking about iOS design patterns.
Toggle description
Your goal in this chapter is to start adding new items to your TODO list app. It also included learning about CRUD (Create, report, update and delete).
Toggle description
Congratulations! You can now add new items to your TODO list app, in this chapter, it's time to start editing your list and changing the text.
Toggle description
In this final chapter for your TODO list app, you will learn about data persistence. Right now all the items are hardcoded so it's time to persist and go!

Getting Started with UIKit

In this section, you’ll learn about UIKit, which is an alternative way to build the UI of your app. UIKit has been around since the first iOS and is currently powering all of the existing iOS apps in the App Store. UIKit is the foundation on which most of SwiftUI is built upon.

You’re about to create Bullseye again but this time using UIKit so you can see the differences between using SwiftUI and UIKit. We feel like SwiftUI is the future of iOS development but we truly think a programmer learning iOS you should have a good grasp of both.

You’ll start by creating a basic view to understand how UIKit works, how it places UI elements on the screen and how to interact with them. You’ll also read about the most common design pattern used when building apps using UIKit. You’ll then go on to create Bullseye!

Toggle description
You've built two apps using SwiftUI, yay!. In this chapter, you will start building Bullseye using UIKit, Apple's existing way of building UI for iOS apps.
Toggle description
Congratulations, you have a UIButton on the screen. It's time to start adding the UISlider which will be fundamental to the game.
Toggle description
You'll be well on your way of noticing the differences between building an app using SwiftUI and now UIKit. In this chapter you will deal with random numbers, adding rounds to the game and calculating the points scored.
Toggle description
In this chapter, we will add some UIKit polish to the app and show an alert to the user.
Toggle description
Bullseye is looking great! The gameplay is now complete but it's time to make it look pretty. In this chapter, we will add some graphics and create an about screen to display the rules of the game.
Toggle description
TableViews are fundamental in the UIKit toolbox. In this chapter, you will learn about data sources, delegates, and general TableView best practices. Be sure to take this knowledge in your future iOS career.
Toggle description
A TableView is no good without real data. It's time to create the data model that will hold the high score data.
Toggle description
UINavigationControllers are super important in an iOS app. In this chapter, you will learn about adding a NavigationController, which will help present the high scores view. You will also add the functionality to delete rows from the TableView.
Toggle description
Now that you have the navigation flow sorted, it's time to implement the edit high score functionality. In this chapter, we will add a static TableViewCell and read the contents from the UITextField.
Toggle description
You now have an edit high score screen but how do we get this data back to the high score screen? In this chapter, you will learn about Delegates and how best to use them.
Toggle description
Phew! You have successfully created Bullseye using UIKit. In this final chapter of this section you will learn about supporting different device sizes and add some beautiful animations.

My Locations

With this fourth section and the MyLocations app, you get into Swift programming in earnest.

Sure you’ve already done coding in the previous sections, but this section starts with a good review of all the Swift coding principles you’ve learned so far and added to it by introducing some new concepts, too. In addition to that, you learn about using GPS coordinates, displaying data on maps, and using the iOS image picker to take photos using your camera or to pick existing images from your photo album. There’s a lot of valuable general information on Swift development as well as specific information about building location-aware apps.

Toggle description
You have made great progress. You have built your first app using UIKit which is some achievement. Whilst we have been writing the apps using Swift, you will need some additional theory to level up your knowledge. In this chapter, we will go into details about some of the Swift language, such as Variables, Constants, Types, Methods & Functions, Loops, and Objects.
Toggle description
Are you ready for the final app challenge? In this chapter, you will commence the final app MyLocations. It's all about using the Core Location framework and displaying using MapKit.
Toggle description
You've learned about getting GPS coordinate information. Now it's time to deal with GPS errors, improving GPS results and testing on real devices to mimic real-world scenarios.
Toggle description
This question will most likely crop up in your next iOS interview. It's time to put the toolbox down and learn some theory. Expect to learn about classes, inheritance, overriding methods and casting an object.
Toggle description
In this chapter, you will be picking up the toolbox again and building our tag location screen. This involves building out some TableViewCells, displaying location info and adding a category picker.
Toggle description
Who doesn't love adding a bit of polish? It's time to start making it look more like an app ready for the App Store. We will improve the experience of the app and add a loading 'HUD'.
Toggle description
At this point, you have an app that obtains GPS coordinates and allows the user to tag the location. We're going to be deep-diving into Core Data, the object persistence framework for iOS apps.
Toggle description
Now that you can persist the data to Core Data, we're going to explore displaying this data in the TableView. Learn about TableView sections, NSFetchedResults and add functionality to delete tagged locations.
Toggle description
Showing a list of locations is great, but not very visually appealing. In this chapter, you will learn about MapKit, the awesome map view control giving in the iOS toolbox.
Toggle description
UIKit comes with a built-in view controller, UIImagePickerController that lets users take new photos or select existing ones. In this chapter explore this controller and how best to display the image on the screen.
Toggle description
You have made it this far! It's time to give MyLocations a complete makeover. Prepare your pixel paintbrush for this chapter and let's get your creative flair at the ready. In this chapter you will cover the map screen improvements by adding icons, polishing the main screen and adding some cool effects to the app.

Store Search

The final section of the book covers iPad support in more detail via the Store Search app.

Store Search shows you how to have separate custom screens both for specific orientations (landscape vs. portrait) as well as for specific platforms (iPhone vs. iPad). This section covers networking, working with remote API endpoints to fetch data needed by your app, and how to parse the fetched data. If that wasn’t enough, this section also takes you through the full application life cycle — from developing the code, testing it, and all the way to submitting to Apple. So don’t skip this section thinking that you know all about iOS development after the last few sections!

Toggle description
One of the most common tasks for mobile apps is to talk to a server. In this final UIKit app you will build StoreSearch. In this chapter, you will build the first screens, add fake searches and create the data models.
Toggle description
Before your app can search the iTunes store for real, we need to make the app look visually appealing. In this chapter, you will cover custom table view cells and nibs. Learn a little more about using git and the debugger right inside Xcode.
Toggle description
Networking you say? Start querying the iTunes web service by using HTTP requests. An introduction to JSON and best to convert them into data models and finally look at how best to sort results.
Toggle description
Phew! You will rarely want to block the main thread with a network request. In this chapter, we will explore asynchronous networking and finally showing an activity indicated to let the user know something is loading.
Toggle description
The iOS toolbox and the Swift language has many tools for our disposal, including URLSession. In this chapter, we will explore URLSession and it's many benefits. Downloading the iTunes artwork and how best to merge your git changes.
Toggle description
In this chapter, we will create a detail pop-up view when a user taps a row in the TableView. We don't want to display too much information now, do we?
Toggle description
We're about to get the polish back out again. The detail pop-up view is working well but we can display the information better. Learn about dynamic types, gradients for the background and let's explore adding some more animations.
Toggle description
Users expect apps to work in both portrait and landscape. They also expect the app to look great in both orientations. In this chapter, we will learn about adding a completely different user interface for landscape vs. portrait.
Toggle description
The final app is looking great. You should put your feet up and grab a coffee! Programming is all about building new pretty features but when you join an existing company with an existing code-base you have to learn about the best ways to refactor existing code. Let's go!
Toggle description
So far our app works great in English. But if you want your app to go international you must support multiple languages and formats. In this chapter, you will explore adding support for a new language and look at regional settings.
Toggle description
Even though the app works _OK_ on the iPad, but it's not exactly optimized for the iPad. In this chapter, we're going to explore universal apps, the split view controller functionality, and dark mode support.
Toggle description
Are you ready to ship to the App Store? Finally, you will learn the key fundamentals on how to ship the app to the App Store, including the Apple Developer Program, beta testing using TestFlight and finally submitting to the App Store.