-
Notifications
You must be signed in to change notification settings - Fork 14
iOS 1 day Weekend Workshop
This document is a guide to the 1-day Objective-C for iOS workshop format to be run on a weekend for a group of from 9am-5pm. Organizers should be at the venue by 8am to help setup.
The participants can be at any level of programming experience (we will sort you based upon skill level after arrival), but they may or may not be professional developers. We assume that most participants do not know Objective-C already.
Prior to the workshop, students will need all three of the following items:
- Mac computer running OSX 10.7 or later
- X-Code 6 or 6.01, this can be downloaded from the App Store. *Note: if you have slow internet this could take 10 hours; however, if not it should take 10 minutes. If you find yourself with a 10hr download time go to your local Apple store (free wifi, no password required and the "Geniuses" don't mind. I just did it last weekend).
- CocoaPods - Follow the instructions listed here. Cocoapods was developed using ruby and can be installed with
sudo gem install cocoapods
. We plan to provide more instruction later on to better clarify for beginners. If additional information is not posted and you are stuck, please email me (laurakirby26@gmail.com)
This is an approximate schedule. Remember to take the breaks because they are a good time to allow everyone to catch up.
- 9:30-10:00 am: Breakfast and Arrival
- 10:00-10:50 am: Introduction
- 10:50-11:00 am: Break
- 11:00-12:00 pm: Tip Calculator
- 12:00-1:00 pm: Lunch
- 1:00-1:30 pm: Objective-C Walkthrough
- 1:30-2:50 pm: Rotten Tomatoes App
- 2:50-3:00 pm: Break
- 3:00-3:50 pm: Rotten Tomatoes Movie Detail View
- 3:50-4:00 pm: Wrap Up
- Bonus: Box Office and Top DVD Tabs
Duration: 30 mins
- Instructor Introduction (5 minutes)
- CodePath Introduction (5 minutes)
- "Professional organization for startup engineers. This includes mentorship and training, fellowship, and career development"
- Student Introductions (20 minutes)
- Each person: Say your name, describe your programming background, and why you want to learn iOS development?
- Poll the class: How many of you already know an object-oriented programming language? Java/Ruby/Python/C#? How many do front-end web development? Back-end web development?
- Getting Started (5 minutes)
- We are going to build a few simple applications together over the course of the workshop
- Ask attendees how many of them have Xcode installed. Pair people that aren’t setup with a buddy
- Ask if anyone has any questions so far before we continue.
Duration: 50 mins
The purpose of the Tip Calculator app is to use a simple, but functional app to introduce Xcode. The takeaways of this session are:
- Creating a new project in Xcode
- Creating a view controller
- Designing a view in Interface Builder
- Using IBOutlets and IBActions to implement the dynamic behavior
When running this session, feel free to take your time introducing Xcode and Interface Builder. Consider glossing over the Objective-C questions and deferring to the Objective-C walkthrough in next session, so that you can stay high level.
- Start by demonstrating the functioning Tip Calculator
- Create an empty Xcode project and run it in the simulator. Point out the various simulators.
- Create a new view controller called TipViewController with a xib.
- Set the TipViewController to be the rootViewController, change the background color of the view controller, and run it in the simulator.
- Add the TipViewController to a navigation controller, set the title, and run again.
- Layout the various views of the Tip Calculator and play with the available properties. (UILabel, UITextField, UISegmentedControl, UIView). Run again.
- Create an IBOutlet for the totalLabel and demonstrate setting the text of the label in viewDidLoad.
- Add a tap gesture recognizer to the view. In the action, NSLog that the user tapped in the view.
- In the tap gesture handler, dismiss the keyboard using [self.view endEditing];
- Wire up the remaining IBOutlets and implement the tip calculation.
- Bonus: update the tip amount as the user is typing. Do not use UITextFieldDelegate. Instead, use the Editing Changed event by right clicking on the UITextField.
Duration: 30 mins
The purpose of this section is to provide a broad overview of Objective-C and using the Xcode debugger. Tip: when typing out code in Objective-C, type the Java equivalent in a comment for each line.
- Declare variables of many different types, explain *
- Basic types: int, float, BOOL
- Common Foundation types: NSString, NSArray, NSDictionary, NSObject
- Common structs: CGRect, CGSize, CGPoint
- Demonstrate logging
- Demonstrate setting breakpoints
- Create the void method sayHello
- Create the void method sayMyName with one parameter
- Create the void method sayMyName with two parameters (firstName, lastName)
- Create a Movie class, add properties for title, posterUrl, and synopsis
- Instantiate some Movie objects into an array, iterate through them, and print them out
Duration: 90 mins
- Start by demonstrating the functioning Rotten Tomatoes app
- Create a new project and a view controller called MoviesViewController with a .xib.
- Add a table view, create an outlet, and set the dataSource and delegate in viewDidLoad.
- Implement the 2 required datasource methods: numberOfRows and cellForRowAtIndexPath. In numberOfRows, return 10. In cellForRowAtIndexPath, allocate a UITableViewCell (don’t use the dequeue method), and set the titleLabel of the cell to @”Hello”. Run in the simulator.
- Create an array of names, and modify the dataSource methods to show the array of names.
- Paste in this snippet to download the box office movies from the Rotten Tomatoes API.
- Open the API url in Chrome to show the data. Tip: use a pretty json Chrome extension.
- Modify the dataSource methods to print out the movie titles.
- Discuss why you need to call reloadData.
- Create a MovieCell with an UIImageView, and UILabels for the title and synopsis.
- Register the MovieCell, dequeue it, and use it to print the title and synopsis.
- Implement posters
- Create a Podfile and add AFNetworking
- #import “UIImageView+AFNetworking.h”
Duration: 50 mins
- Implement the didSelectRowAtIndexPath method, logging the touch.
- Create the MovieDetailViewController that just has a UILabel for now. Add a public property for the movie dictionary.
- In didSelectRowAtIndexPath, push a new MovieDetailViewController with the appropriate movie.
- Style the MovieDetailViewController until it looks like the demo.
- Bonus: Add a UIScrollView so that the synopsis can scroll.
Duration: 30 mins
- In the App Delegate, create a UITabBarController and instantiate with two UINavigationControllers that each have a MoviesViewController as the rootViewController.
- Add the tab bar images to Images.xcassets.
- Add a type property to MoviesViewController to configure it for the Box Office or Top DVDs.
Duration: 10 mins
- In a day, we’ve covered many of the basic topics required for building iOS apps including views, layouts, navigation, and networking.
- Sign up with a Parse account
- Easy way to setup server-side database and API
- Think of a project you want to build and get started on it. Be sure to come to our meetup events.