I've got to start with a huge Thank You to ar2rsawseen for responding while on vacation to my pleas for help troubleshooting in the final stretch before release.
I've just released Fly Fishing Simulator.  There's history behind this game.  Quit reading to avoid yet another long story of somebody trying to get out of a cubical farm and into indie game development.  Or put up with me and read on....
In 1999 I was dabbling in game development, focusing on fishing games since I'm a fishing nut.  I owned the fishing games of the day and couldn't stop criticizing all the things they'd gotten wrong.  I started building a fishing game that created scenes with looped still photos to animate the water and overlaid sprites for other elements.
When it started to look like I might have something worthwhile I began looking for a publisher.  I found one that had been quite successful with photographic hunting games but had no fishing games.  I pitched my game by email and met the head of the company for a lunch meeting when he was passing through my time zone.  He was all for publishing my game, but the condition was that I would first develop a fly fishing game, since they believed that was what the market really needed.  I'm a fly fisherman myself, so I was thrilled.  We inked a deal, they lined up brand names of fly fishing products to promote in-game, we did a photo shoot on a world class trout river while staying at a classy lodge that they'd also lined up as a sponsor.  I was in heaven, combining my love of fishing for getting into the world of game development.
An advance on royalties let me quit the day job to complete development on a really aggressive schedule.  The game had about 24 beautiful fishing sites.  They sold a decent number when the game released, while I turned my attention to completing the other fishing game I'd originally pitched.  I thought I'd really made it when I saw my fly fishing game in a software shop in a mall.
Then reality returned, of course.  The publisher had troubles with their distributors, sales of the fly fishing game stalled, and my other fishing game sat out the holiday shopping season while the publisher tried to get their hunting game sponsors to put their name on it, though those brands are associated with hunting and not fishing.  12 other fishing games came out between the time I delivered a release candidate and the time the publisher settled on one sponsorship from a fishing electronics brand and put my game on sale.  With a couple thousand hours invested, that game made me a whopping $42.
I returned to the day job in 2000, ended the publishing contract, and left the gaming world.  For a while.  In my spare time I started rewriting the fly fishing game the way I would have done it if I wasn't taking cues from a publisher with partners products to promote and a release schedule to hit.
The new game developed over several years.  Rather than one famous river I wanted variety, so I made a lot of trips to interesting waters to do the photography.  I spent more time in waders bracing a camera tripod in trout streams and rivers than I spent fishing.  Eventually I self published the game with about 300 fishing sites.  I played marketer enough to get it write-ups in the major fly fishing magazines and got the sales started.
By 2007 things were going well enough that I re-quit the day job and went back to game development full time.  There were 475 fishing sites in the third edition, and a hundred more as available add-ons.  I developed two 3D fishing games, but the fly fishing game was always my best seller.  I released a kit to let users add their own content to the game, and set up a forum on my web site.  That took off more than I ever expected.  A handful of hard-core fans around the world have produced thousands of additional fishing sites and hundreds of fish species.  Two people who met on my forum are now married.  I wouldn't have believed that was possible.
I'll skip the non-game (but still fishing software) part of the story and finally get to Gideros.  A couple years ago I found Gideros and decided to use it to build a mobile version of my 3D ice fishing game.  I captured images of the 3D models I'd made for the Windows game to make sprites for a 2D version.  I considered the project an experiment and a lesson in mobile game development.  I released "Ice Fishing Derby" for Android and iOS last spring.  It's no Angry or Flappy Bird, but it's earned good ratings and brought in more money than I'd expected.
I've spent almost all of this year porting my fly fishing game from C to lua and Gideros.  I doubted at first if phones and the Gideros framework would have the processing power I needed.  All the fish in the scene navigate their environment in 3D, reacting to the food, current and structure of the scene.  The fishing rod is internally modeled in segments, each reacting to forces in 3D.  And then there's the line, made up of points moving in 3D with each effected by gravity, the pull of points, friction, etc., before being represented in 2D elements on the screen.  I was extremely happy to find that Gideros and Lua could handle it easily.  I only see a little lag on the 4 year old phone I keep around for testing, but even on that it's still very playable.
I did have issues with the expansion files required for Android apps to exceed 50 MB.  When I couldn't get the expansion files working I cut down the content.  I took the game from 555 fishing sites to 165 and greatly reduced the collection of fish images, etc.  Having done that I've got to say the game is much better for it.  I've had to focus on quality over quantity.  Even though the 555 sites were selected as the best of the thousands I photographed over the years, cutting that down to 165 meant the app now has the best of the best.
If this game has a competitor that would be "iFishing Fly Fishing Edition".  That has 1 site for free and a total of 6 if you buy it.  Even cut down to 50 MB my new game has 26 times as many sites as they offer, so while quality has become my focus, I don't think it's lacking on the quantity side.
Now I need to take off the programming hat and dust off the marketing hat to see if I can get this game noticed in the Play Store.  But first it's time to get some sleep.
For those who took the time to read this 2 AM rambling, and for those responsible for making Gideros such an incredible game development tool, THANK YOU!!!
PaulH
PS - Here's the game on the Play Store: 
https://play.google.com/store/apps/details?id=com.pishtech.ffs                
Comments
Well done! Looks like you put a whole heck of a lot of work into this. Congrats on completing it!
Wish you all the well with your latest release and more site can be added later as an update once we resolve the issue with expansion packs
I spent a good five minutes reeling a fish in, and just as I was getting close to netting the app crashed. Gah!
Niclas
Wow thats really obscure bug, is other gideros games also suffered from that problem?
http://www.nightspade.com
java.lang.NullPointerException
at android.media.MediaPlayer$EventHandler.handleMessage(MediaPlayer.java:2218)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
It's not as simple as just playing a sound from a file that's missing, has a file name case mismatch, etc. My sound playing function starts by doing a file open and close just to test the validity of the file.
It could have to do with the way I'm looping sound files. I've found that if I use the looping option on the sound player's "play" method I get a slight gap of silence before the sound restarts, which is problematic when the sound is something like a rushing river. So I override the looping directly with this code:
if (sound_is_playing(cat)) then
if (sound_player[cat]:getPosition() > sound_length[cat] - 250) then -- start over about .25 seconds before the end, prevents auto looping which has a gap
sound_player[cat]:setPosition(250) -- restart a quarter second in - avoids a slight gap
end
end
That plays the sound seemlessly, and skips the first and last 250 ms of the track. But perhaps it's unsafe.
Has anyone else had issues with skipping in the looping sound playing? And maybe found a different solution?
And thanks for the support!
Paul
Thank you
http://stackoverflow.com/questions/18224097/android-mediaplayer-nullpointerexception/20468129#20468129
In a nutshell, calling the MediaPlayer's "stop" method then its "release" method is problematic since "stop" uses messaging and it's possible for the media player to be released before the stop method tries to access the object. The fix is to remove the call to "stop".
I don't know if Gideros does this, but the pattern of crashes and the call stack look very familiar.
Paul
So that must be the problem
Thank you for the info, will be fixed
I noticed "loop" in the call stack when the crash occurs. Is the media player object cleaned up that way only if it's set to loop, or would playing a sound once potentially use the same code? If it really only happens when the loop option is used I could work around the issue until the fix comes out by calling the play function with looping turned off and just jump the position back before it ends. I'm doing that already to avoid slight pauses between plays, but I still have the loop option enabled too, just to be sure the sound doesn't reach the end before my code jumps it back, which is possible if the system is running very slowly.
Paul
I do not use reviews and ratings as a measure when I d/l apps. My measures are the screenshots, the quality, the size and then last but not least, word of mouth or reputation/stories about the app that bring me to it. But that's me....
For my reviews I never had a score, it is because numeric scores are not a valid way to express, since the scores are tied to certain attributes that can skew the final results. Not all 4.5* apps are the same, not all the top apps are AAA titles, not all popular apps are polished and professional and not all good apps are Top Sellers or Highly Rated.
Likes: hgvyas123
Author of Learn Lua for iOS Game Development from Apress ( http://www.apress.com/9781430246626 )
Cool Vizify Profile at https://www.vizify.com/oz-apps
I completely agree about the rating being a very distorted view of quality, especially when an app is relatively new. When a new app has only a few ratings the score is virtually meaningless. Once an app has been rated hundreds or thousands of times the ratings become a more accurate but still imperfect measurement of what people think about the app.
I also agree that a high average review is by no means a ticket to success. A lot of people will avoid a 1 or 2 star app, and not hesitate to try anything with 3 or more, but plenty of people ignore the star ratings altogether. I'm not worried about people would would download an app with 4.5 stars and not one with 4.0 stars as those people are probably quite rare.
Far more people choose their apps by browsing the top ranked titles. The vast majority of apps in the top 10 for any category will have 4 to 4.5 star ratings, so people browsing that way don't have much incentive to both looking at ratings.
The tenths of a star mostly matters to me because it's one small factor in the algorithm that app stores use to rank apps, and every little bit can help push an app up another spot. Somewhere on those app rankings, both by category and in search results, there's a tipping point. The vast majority of people stop browsing after viewing the top ten or twenty apps. An app ranked #5 may get 100 times the downloads of the #25 app, which may get 100 times the downloads of the #250 app.
Obviously the rate of downloads is a huge factor in ranking, and the number 1 app is on top because it's really popular, but it's kind of a catch 22. If you can climb in the rankings, you'll get a lot more downloads by virtue of being seen by a lot more people, but downloads are the main thing that makes you climb in the rankings. Ratings and reviews are a smaller piece of that formula, but they're a piece a developer can influence by doing whatever it takes to prevent crashes and generally making sure the customers will be happy with the app.
10 days in my app is being run about 1,000 times per day for a total of about 120 hours per day. I'm getting about 4 crash reports per day, which isn't a lot, but for every reported crash there are probably several unreported crashes. If they can be prevented that would boost the average rating a fraction of a star, which could just possibly be what makes the difference between the app eventually being the last app on the first screen for its category and being the first app on the second screen. And that can make a huge difference in revenue.
Paul
Paul
If you can reproduce the issue, I can build you a gideros.jar file to replace in your project and try if that fixes the error?
Paul
Is this jar file stable enough to release with, or should I wait for an official release?
Paul
Niclas
Paul
Likes: ar2rsawseen
At start up I have the game consult the server to make sure it's OK for that version to run. If I encounter a security issue, like a hack to access paid content, or for some other reason want to make an update mandatory, I can just change the minimum acceptable version in that PHP script, and have it return a message to show to the users explaining the need to update the app.
I get the crash reports mostly through the Play Store itself. When I get a bad review due to a crash I always reply with a request to contact me at my support address so I can investigate.
Paul
A less configurable, but in my opinion very powerful way to collect and collate analytics, is Mixpanel. Used cleverly it's free. Here is my implementation:
The data I'm tracking with each call:
The code to send the data to Mixpanel:
Niclas
Likes: uzubari
Meanwhile I'm looking into an overhaul of my other Gideros game. It's a $3 title with no free version, but I want to switch to the model with a free app and in-app purchasing. That's working better than expected for the new game, and now that I know how to do it I might as well see if it can boost the revenue for the other one.
Paul