“I wrote an iPhone app, and it didn’t make any money” is a growing literary genre, and I sympathize with the authors. I really do. Building any kind of non-trivial, commercial application takes an immense amount of work that combines coding, writing, interaction design, and graphic arts. To spend a thousand hours on a project that sells 103 copies at 99 cents apiece…well, it’s disheartening to say the least.
Dismissing that failure as losing the “app store lottery” (meaning that success or failure is out of your control) dodges important questions. When I was writing and selling indie games in the mid 1990s, I went through the experience of releasing a game to the world—euphoria!—followed by despair, confusion, and endless theorizing about why it wasn’t the smash hit I knew it deserved to be. Most of the failed iPhone app articles sound like something I would have written in 1997. Of course the iPhone and Apple’s App Store didn’t even exist then, but my feelings and reactions were exactly same.
What I learned from that experience may sound obvious, and that’s precisely why it’s a difficult lesson to learn: just because you slogged through the massive effort it takes to design and release a product doesn’t have any bearing at all on whether or not anyone actually wants what you made.
See? I told you it sounds obvious, but that doesn’t make it any easier to deal with. Getting something out the door is the price of entry, not a guarantee of success. If it doesn’t go as planned, then you have to accept that there’s some reason your beautiful creation isn’t striking a chord with people, and that involves coming face to face with issues that aren’t fun to think about for most bedroom coders.
Have you ever watched complete strangers use your app? Are they interpreting the tutorials correctly? Are they working in the way you expected them to? If it’s a game, is the difficulty non-frustrating? Maybe you designed and polished twenty levels, not realizing that only a handful of players get past level one.
It’s harder to judge if the overall quality is there. Your cousin might draw icons for free, but do they give the impression of high-end polish? Are there graphics on the help screen or just a wall of text? Are you using readable fonts? Are you avoiding improvements because they’d be too much work? Developer Mike Swanson wrote an Adobe Illustrator to SVG exporter just so images would stay sharp when scaled.
It’s also worth taking a step back and looking at the overall marketplace. Maybe you love developing 16-bit retro platformers, but what’s the overall level of interest in 16-bit retro platformers? Is there enough enthusiasm to support dozens of such games or is market saturation capping your sales? If you’ve written a snazzy to-do list app, what makes it better than all the other to-do lists out there? Can folks browsing the app store pick up on that quickly?
It would be wonderful to be in a position of developing software, blindly sending it out into the world, and making a fortune. It does happen. But when it doesn’t, it’s better to take responsibility for the failure and dig deeper into what to do about it rather than throwing up your hands and blaming the system.
Categories: Blogs Programming in the 21st Century
Erlang on Twitter
» Muh_Erlang (M. Erlangga Pangestu): Ngapain susah2 jatuh RT”@tashakawe: fall for you”
Ngapain susah2 jatuh RT”@tashakawe: fall for you”
» tomasduda (Tomáš Duda): I think I’ll nope out of this Erlang tutorial. Worse syntax than Brainfuck.
I think I’ll nope out of this Erlang tutorial. Worse syntax than Brainfuck.
» NotDoctorOk (Not Richard O'Keefe): One Unicode codepoint may represent what a particular language views as two distinct graphemes. http://t.co/RT52fOnQzY
One Unicode codepoint may represent what a particular language views as two distinct graphemes. http://t.co/RT52fOnQzY
» bradfordw (bradfordw): When you do minor finance calculations in Erlang, you DO end up with: balance.beam
When you do minor finance calculations in Erlang, you DO end up with: balance.beam
» MannenGranMyten (Johan Gran Nilsson): För Erlang i medeltiden! @Poll242
För Erlang i medeltiden! @Poll242
» Erlang_07 (Erlang ): @tresnaDO xfactor
» tresnaDO (Tresna Dwi Oktaviani): Apasih ga jelas :| “@Erlang_07: @tresnaDO ada y 2015”
Apasih ga jelas :| “@Erlang_07: @tresnaDO ada y 2015”
Number of aggregated posts: 10651
Most recent article: May 21, 2013
» Moraru on This is Why You Spent All that Time Learning to Program: It is true that computer science was a pain in the back at time that i’ve had to learn it…
» Commercial hand dryers on Couchbase Meetup at new HQ: Buy online from here where you will get so much of variety in Commercial hand dryers for people. If you…
» Fort McMurray Homes on Motivated Reasoning and Erlang vs Python vs Node: I don’t really understand why this post is motivational? I don’t even see a post, just a title. Fort McMurray…