|
|
||
![]() | Oktoberfest. Munich, Germany September 24, 2006 |
|
| Apple | Cool | Disney | Entertainment | Fitness | Geek | Microsoft | Politics | Seattle Storm | Transit | Travel | UW MBA | ||
|
« A New Vision For The Fun Forest | Main | Are The Storm Staying? » December 21, 2007Birth Of A PlatformWelcome to late December! Work is winding down for the year, holiday parties are being thrown, shoppers are scurrying around the malls looking for a Wii. And, for the Mac community, this is the usual time of year to pause, reflect, and begin making predictions about what will be announced at Macworld San Francisco in January. This isn't my Macworld prediction post (I'll get to that after the holiday), but I did want to take a bit to reflect on the forthcoming iPhone software development kit (SDK). This SDK is critically important to Apple; getting it right will transform the iPhone (and iPod Touch) from a fantastic piece of consumer electronics into a bona-fide platform, the kind of place where consumers can get a particular software itch scratched, developers can build a business, and everyone makes money. If done correctly, the iPhone SDK will become a huge strategic asset for Apple, driving sales and ancillary revenue, boosting customer satisfaction, and helping Apple ward off competing mobile platforms. So ... what will it look like? First, a disclaimer: while I work for Microsoft's Mac team, none of what I'm writing in here has been informed by any inside information, and certainly nothing is covered by NDA. I don't know anything special. This post is fueled by being a Gruber-reading, MacBreak Weekly-listening, Apple guy from way back in the day. Set the wayback machine for June: roughly 15 nanoseconds after the iPhone was launched, developers were trying to crack it open and figure out how to write native applications for it. This was fiendishly difficult work, both because a) Apple wasn't supplying any documentation on how to do this, and b) Apple was going out of their way to stop people from doing it. A game of cat-and-mouse evolved - developers would find a way to crack the phone, and, once they did, Apple would release a software update to prevent their break-in from working. Finally, in October, Steve Jobs announced that Apple would be supplying a native SDK for the iPhone in February 2008. This served two purposes - first, it took a lot of the fight out of the hacker community to keep finding new-and-novel ways of breaking in to the iPhone (I mean, what's the point? Just wait for early '08), and second, it bought Apple the time it needed to get the SDK finished and out the door. One question on people's minds was, "why February?" I mean, it's clear that Apple has an SDK for the iPhone - otherwise, they'd never be able to create Mail, Mobile Safari, or any of the rest of the applications that come on the silly thing. Why not just make that available? My bet is that these new, third-party iPhone applications will only work on a new version of the iPhone operating system - call it v1.5 - which will be based on Leopard. And while v1.5 wasn't ready in October, it will be by February. Why Leopard? Well, aside from the obvious advantage of synchronizing the versions of OS X in the iPhone and on the Mac, Leopard has a number of new technologies that are great for your desktop iMac, but fantastic for mobile applications. Specifically, I expect that all iPhone applications will make use of:
What this means as well is that iPhone applications will be Cocoa applications. No Carbon (and certainly no Classic), no Java, no Python or PHP. OK, so now we know how these applications will be built - the next question is, how do users get to them? Will this be like the Mac shareware market, where people just offer downloads off their Web sites? Or will this be classic commercial software, sold in a box through Amazon or the local Apple Store? The short answer, I think, is iTunes. Today, people get a ton of content for their phones or iPods by going to the iTunes Store. You can get music and movies, as well as podcasts, TV shows, and iPod games. And, I suspect, when Jane Developer wants to put her newly-created Widget 1.0 for iPhone in the market, she'll do so much like she would with a podcast - she'll park it on a Web server somewhere, fill out a form on the Apple site, and, within a short period of time, the product will appear in the iTunes Store for purchase. Like podcasts, Jane Developer will be able to pick a handful of categories that apply to her app ("Games", "Productivity", "Utility", etc.), write some marketing text, have a cool icon. Like everything in the iTunes Store, users will be able to rate Widget 1.0 and leave feedback for others to see. And the whole transaction will take place in the iTunes environment, with Apple collecting a cut of the proceeds. For users, this is about the slickest thing ever. It extends the iPod shopping metaphor they're used to, and lets them use their current payment preferences (via their Apple ID) to just ... buy more stuff. I'd even wager that iTunes gift cards will be applicable toward third-party software, as well. If I'm right about this, there's a lot of goodness here for prospective iPhone developers. Because the phone is based on OS X, they get a modern, object-oriented codebase, a lot of world-class system services and features, and a high-quality desktop development environment. They also get a simple hardware target (for today, at least, the iPhone is the iPhone is the iPhone), which dramatically reduces the complexity of testing. Small developers will love the fact that iTunes handles marketing, payment, distribution and installation. In fact, this approach neatly solves a lot of long-standing problems in the mobile phone market. Consider the plight of a smartphone developer today. Let's say Jane Developer wants to write Widget 1.0 for Symbian or Windows Mobile - great. Here's her problem - her prospective user base is highly fragmented:
And so on. Now layer on a little more complexity - different installation techniques for phones. Some carriers (such as AT&T) want you to buy software "over the air" from them (paying data fees, of course) and install it in your phone that way. Others might want you to download programs off the Web (hello, Palm!) and "sideload" the installation. And so Jane, poor developer that she is, is stuck writing lowest-common-denominator products for the widest possible audience, or is going to have to pick a relatively scoped market (e.g., PalmOS machines with color screens) for a higher-end application. Marketing Jane's software might be difficult, too - she's got to build herself a Web site, come up with a payment-processing system, and then fight to get the attention of prospective buyers by using search-engine optimization techniques, buying AdSense ads, or both. In short: being a small software developer is hard; being a small software developer for a mobile platform is hellish. The iPhone turns a lot of this on its head. In many ways, the business model for iPhone development has more in common with video game consoles - the XBox 360, PlayStation 3, or Wii - than it does with the traditional PC. For developers, the value proposition of a game console is simplicity - an Xbox 360 is an Xbox 360 is an Xbox 360. Each 360 has the same processor, the same video card, the same amount of memory. If you can write a game for one 360, it'll run on all of 'em. And because developers know what kind of hardware their prospective customers are working with, they can push it - really make the most of the platform they're on. It's one reason that second-gen video games for a given platform always look so much better than first-gen games - the developers have figured out how to tweak and push the hardware in new ways, get more out of it. The iPhone is very much like this. Every iPhone has a fantastic color screen, WiFi, Bluetooth, a data plan, 8 GB of memory, a camera, and is linked to a PC or Mac with great desktop software called iTunes. This means that developers will go crazy making the most of this hardware/software combination, pushing the phone to do things that other phones simply can't do - or, at least, can't do in sufficient numbers to be interesting, market-wise, especially when the iPhone is already outselling all Windows Mobile devices combined. (And yes, future iPhones will undoubtedly bring more capabilities - more storage, 3G data connections, etc. - but I believe the basic form factor is unlikely to change for quite some time.) In short - the iPhone platform is going to bring the trifecta of 1) a stable, known hardware platform, 2) desktop-class development tools and technologies, and 3) dead-bang easy software marketing, distribution and installation to a fragmented market. And, I predict, it will be the dominant mobile development platform in less than 24 months. I certainly wouldn't want to be Palm or Nokia right about now. On a final note, I'm intensely curious to see what the success of the iPhone platform will mean for Mac users. Apple has stated that they plan to sell 10M iPhones by the end of 2008; based on current sales trajectories, I see no reason they won't hit it. That represents roughly 10% of the 100M-unit smartphone market; as Apple attempts to convert the majority of their 110M+ iPod customers to iPhone customers, it's eminently reasonable to assume they'll have 30M phones in circulation by the end of 2010. Read that again: 30M phones. As a point of contrast, that's roughly the size of the Mac installed base (!). Remember that iPhone developers are actually OS X developers, and remember that iPhone developers are using many of the same tools and APIs that you would use to develop for the Mac. Suddenly, as the iPhone attracts talented developers, many of those developers will find themselves with a lot of knowledge about how to create great Mac applications, too. I predict that the iPhone developer community will be a steroid for Mac development in general, and we are going to have a flood of new Mac applications hitting the market after the next year or two. New products, new ideas, new companies - all made possible because the delta between iPhone development and Mac development is much smaller than, say, the delta between Palm development and writing for Windows. (And, if you're a Mac rock star like Cabel Sasser or Wil Shipley, the iPhone is a win-the-lottery kind of new-market opportunity.) This flood of Mac apps isn't the point of the iPhone; rather, it's the spoils of victory. If Apple really manages to harmonize its developer story across its devices and desktops, really manages to crack the marketing, distribution and commerce problems, and really delivers a viable, vibrant market by selling the hell out of its product - then they've got it. One way or the other, it'll be fascinating to watch. (And frankly, I think they're going to pull it off.) Posted by Gavin Shearer at December 21, 2007 11:21 AM. Posted to Apple. Trackback PingsTrackBack URL for this entry: CommentsGreat post. Lots of things to talk about. The phone industry is going through a lot of changes. I hope Apple does as you predict. 10M by EOY 2007? 2008? :) Will MacOS developers move to the iPhone? I suspect it more likely that the existing mobile developers will move instead. But the iPhone is not Java, its not BREW, its not Symbian... Its a totally new beast. Cocoa is not that hard to pick up for a C-developer (which most embedded folks are likely to be) but the whole Mac-technology thing has a big learning curve. Im curious how this will pan out. As I have said before, the cell phone is the "personal computer" for the rest of the world's billions. If the software comes, the "mac in your pocket" iPhone is the future. Posted by: purple Post a commentThanks for signing in, . Now you can comment. (sign out) (If you haven't left a comment here before, you may need to be approved by the site owner before your comment will appear. Until then, it won't appear on the entry. Thanks for waiting.)« A New Vision For The Fun Forest | Main | Are The Storm Staying? » |