Head First iPhone Development Wouldn’t it be dreamy if there was a book to help me learn how to develop iPhone apps that was more fun than going to the dentist? It’s probably nothing but a fantasy… Dan Pilone Tracey Pilone Beijing • Cambridge • Kln • Sebastopol • Taipei • Tokyo Head First iPhone Development by Dan Pilone and Tracey Pilone Copyright © 2010 Dan Pilone and Tracey Pilone. All rights reserved. Printed in the United States of America. Published by O’Reilly Media, Inc., 1005 Gravenstein Highway North, Sebastopol, CA 95472. O’Reilly Media books may be purchased for educational, business, or sales promotional use. Online editions are also available for most titles (http://my.safaribooksonline.com). For more information, contact our corporate/ institutional sales department: (800) 998-9938 or [email protected]. Series Creators: Kathy Sierra, Bert Bates Series Editor: Brett D. McLaughlin Editors: Brett D. McLaughlin, Courtney Nash Design Editor: Mark Reese Cover Designer: Karen Montgomery Production Editor: Scott DeLugan Indexer: Angela Howard Vinny Proofreader: Colleen Toporek Page Viewers: Vinny and Nick Printing History: October 2009: First Edition. Nick The O’Reilly logo is a registered trademark of O’Reilly Media, Inc. The Head First series designations, Head First iPhone Development, and related trade dress are trademarks of O’Reilly Media, Inc. Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and O’Reilly Media, Inc., was aware of a trademark claim, the designations have been printed in caps or initial caps. While every precaution has been taken in the preparation of this book, the publisher and the authors assume no responsibility for errors or omissions, or for damages resulting from the use of the information contained herein. No PCs were harmed in the making of this book. ISBN: 978-0-596-80354-4 [M] 1 getting started Going mobile I just don’t see what all this iPhone fuss is about. My phone works just fine... The iPhone changed everything. It’s a gaming platform, a personal organizer, a full web-browser, oh yeah, and a phone. The iPhone is one of the most exciting devices to come out in some time, and with the opening of the App Store, it’s an opportunity for independent developers to compete worldwide with big-name software companies. All you need to release your own app are a couple of software tools, some knowledge, and enthusiasm. Apple provides the software, and we’ll help you with the knowledge; we’re sure you’ve got the enthusiasm covered. this is a new chapter 1 everyone wants iphone apps There’s a lot of buzz and a lot of money tied up in the App Store... The App Store is a HUGE success! Datihnpee pvr eseiP lcothoopo retdnhr eesn uAhamanpvdbpe elte hrb sAee, peiaPpnno dSsd ut moTbroameuk ifictnothigrn g significant income. Aibncupercnpeeriseaqn dtuh ievieaben’vAlse jeow i yrnabpaitnyeetepsgers f noanl, fceeda euwon’.sswd ian nupgAlspo etsahrp dewse pihidtPha ha vrSotee na tello y re celebrates 1st birthday yuDotmnhAhueeaeopv xbs enpp publelroeeyeiypcc .clf teeaoWre roumfdsomnh hrewci l ahiteatPhvh eymeheeds o bsatfinototenosc eey bru an earasc .ip lpcnoeplpgvfass e i ft mcruuraoenpegnn d iatfdno inAnsgr,du pcts ehaaposlde n eSt dt cotareao orrdprevie sa euef brort.se iinlyleii,ett, yi aemy ntseo daao n rtfl hoy at etghas o dreae enai vPnndihocd loteo ,s n ttiasnhe n coaidentf tEhveeirn d uesveircse os.f the iPod Touch can also download the apps to eMnoaungyh p eaoppplse o tnry y soeuvre rpahl onneew t oa pfiplls sae vdearya,l asncrde yeonus. .c..a n install 2 Chapter 1 getting started Mobile applications aren’t just ported desktop apps There are about a billion good reasons to get into the App Store, and now it’s time for you to jump in. To get there from here, you’ll learn about designing and implementing an iPhone app, but it’s not the same as developing for the desktop, or writing a web application. It’s important to think an iPhone application through from the beginning. You need to constantly ask yourself “What is it the user is trying to do?” Get rid of everything else, minimize the input they have to provide, and keep it focused. This is NOT the same as this Check the factors that you need to consider when you’re working on a mobile app, in general. Memory Usage fees Display capabilities App speed Internet access User input tools (keyboard, mouse, display, etc.) Which of these factors are different for the iPhone? you are here 4 3 going mobile Check the factors that you need to consider when you’re working on a mobile app, in general. Typical mobile devices have Manodb iale l odte voicfe sit h aisv ea lrliemaidteyd a lmloecmaotreyd . cSoesntdsi nmgo nteeyx tfso ro rs oamccee mssoinbgil et hues eIrnst.ernet prdleiafsnof leufrtoerino tnts h,d aiatsnp..dl.a yy osuiz neese adn dto Memory Usage fees Display capabilities App speed Internet access User input tools (keyboard, Mlotob oilfe tdiemveic,e s ou saeprsp sd noene’td htaov elo aa d Tmhobe ilNe euts eirs n-o ta nadlw iaty’ss tayvpaiiclaablllye sfloorw .the mouseSs,o odmmisee p hmlaaoyvb,e i eleetxc dt.)ervai cbeust utsoen sa,r arnodw s, and work quickly. others have touch screens. For the iPhone, unlimited data and texts are Which of these factors are different for the iPhone? typical, and there is only one display size to deal with. And while there is a keyboard available, it’s all touch screen! iPhone apps are not small desktop apps There’s a lot of talk about how the iPhone is a small computer that people carry with them. That’s definitely true, but it doesn’t mean iPhone apps are just small desktop apps. Some of the most important issues that you’ll encounter designing an app for the iPhone: iPhones have a small screen and are task-focused Even with the iPhone’s fantastic screen, it’s still relatively small (320x480). You need to put real thought into every screen and keep it focused on the specific task the user is doing. iPhones have limited CPU and memory On top of that, there’s no virtual memory and every bit of CPU oomph you use means more battery drain. iPhone OS monitors the system closely and if you go crazy with memory usage, it’ll just kill your app. And no one wants that. Only one application can run at a time If it’s your application running, why should you care? Because if anything else happens, like the phone rings, a text message comes in, the user clicks on a link, etc., your app gets shut down and the user moves on to another application. You need to be able to gracefully exit at any time and be able to put users back into a reasonable spot when they return. 4 Chapter 1 getting started Anatomy of an iPhone app Before we dive into creating our first app, let’s take a look at what makes up a typical iPhone app. First we have one or more views... iPhone apps are made up of one or more views—in a gttneyeoxpnrtiem cfraiaaelllllydl ya sd p,r opebn,qu ’tuttht ioureenssee st ,htv lheiaeeibrw neoslo swh,r nmaev tccaeu.l GsGGtoUaUmmII ceicnoso tmhmearppfvoaoecn neveesinen ttwthss sa.o tGtn oa aotrhme, e bcemurse t laitkeed Vgoireraw pssoh miccaean llc ybo emu sbbiniungial ttIn ioutnsei rnofgfa ccboeod tBeh,u .i lMdeors,t with things like OpenGL or Quartz. apps use a mix. ...then the code that makes the views work... iPhone apps have a clean separation between the GUI (the view) and the actual code that provides the application logic. Iernetca g.c eTtsn hetoirsa bcl,uo etdtaeoc nihs pvarileemwsso eshst,a astal wab alVey isre owwwr iCsteteolennc titniro oOnl,l betjirelt cibnteigvh eti-hnCed puiths itonhngae t , Xwncruoimtdbiene gri s i oPtfhh oean peIpD laiEcpa ptos.fi o Intc h tioneicmcleup dlfaeotsre sa to Apple’s IDE (integrated development environment), Xcode. get you started. ...and any other resources, all packaged into your application. Iyytttaaaeohhfootrppc eeeuuyppf. i)or asllrn bii aeaucccaduamntaa’p ruilottdllepeiidayu oo lal n iwt nnjtcn bueht aaywi(dhsetyntt i aha, o oaa dtttsetorpna oih ayr ,ap de pen wuhlerceipetxce htveahloaleieepdcoptcrlnia soiruopf,e ,tip y tnisliltaoeoit.hi.n bscnuAwe,gla s eneti ilt,fe(ctyl oiicl osP olbro.a nh XunmiOp Ponf pcirenhSdlo e eedo lmdnXe sinaer aote een mhyau ctdaoebtare puomof,cdup r ucem yalluotlis tcicpdod gaalo eteihtf hkn oaistsoeketb riab ngtr oioyi emnsnruop eabsstua sut aegtu orwhhpeurppaeeshrr,v ssc ei,)ese n e s d Pictures Data Eriatievhtcpts.ecaio hpohnroAsneluety mi trc i efanmcaa irPfpieatcfloopest hiano rml,ou i canmcanaries naleena sw it osft mbioaiIciilionuloulpnie nafmrnpahs toc r,,ai ea.ehtypvycdbsas.eloa eio s saOlu lwutlafrrsettni oe ,dtt h mh aehne nrai d bt s . Now let’s get started on your first iPhone App... you are here 4 5 help mike make up his mind Mike can’t make a decision Mike’s a great guy, but he never knows what he wants to do. Help him save time waffling about what to do, and give him a straightforward answer. The way I see it is I already made the decision to buy an iPhone... I shouldn’t have to think again! We’ll write Mike an app. Mike has an iPhone, so let’s write him an app that requires a simple button push to tell him what to do when he needs to make a decision. Mike 6 Chapter 1 getting started Make a good first impression When users start up your application, the first thing they see is your view. It needs to be usable and focused on what your application is supposed to do. Throughout this book, whenever we start a new application, we’re going to take a little time to sketch up what we want it to look like. Our first application is pretty straightforward: it is going to be a single view with a button that Mike can press to get a decision. To keep things simple, we’ll change the label of the button to show what he should do after he pushes it. Let’s call it iDecide. iDecide pwhyTrrioodhiutbeirsai n biatgislp y, ap tb l heugceataa v mnseut e ncai,lth teyo.suoossu s y ebso ahturo’o ru -eld WatTpehhp’ilsillsi c lteiasatt lsitko hnyme o owuirP iterh huoanonb ueaot un stduims iituntelg asl ttaaot ryer ore-u.ar l phone. This is a button Ptcrhheeas nsl agtbeh etel o tb etuxtetltl owMni lialk ned w hat IW dhoa?t should T3h2e0 i Pxh o4n8e 0sc priexeenl si.s he should do. Wa&epu ’pplpll a itcspkoaeteorlti soac nrhy e ob uuesp of cmooorueuerl d o wG fue Us tebIh.su eifl dbo ret steha emcmho. c kP-en Now that we know what to build, let’s get into the tools. you are here 4 7 download the SDK It all starts with the iPhone SDK It’s time to go get some tools. Head over to http://developer.apple.com/iphone. You can download the SDK (and other useful Apple development resources) for free with the basic registration, but to distribute a completed app on the App Store or install your app on the iPhone for testing you need to become a paid Standard or Enterprise Developer. The SDK comes with a simulator for testing directly on your Mac, so free registration is all you’ll need for now. The SDK comes with Xcode, Instruments, Interface Builder, and the iPhone Simulator. Code for the iPhone is written in Xcode using Objective-C. Interface Builder is used for graphically editing GUIs, Instruments helps you assess memory usage and performance for your app, and the Simulator is used for testing. Register as a developer at http://developer.apple. com/iphone. Download the latest SDK; this book is based on the 3.1 SDK. Just look for the Download button at the top of the page. Install the SDK. Once the Installation completes, you can find Xcode. in app /Developer/ . Just Applications double-click it to start it up. uDtsYioono cgudk ri—wtai wglal e ip’tlror etoo b.ng ato boinl ygy owtuoar n bte 8 Chapter 1