I’m immensively proud to be featured in the recent #WeArePlay campaign for Darwin, Australia for my game Freebloks 3D.
Tag Archives: Android
Freebloks 3D reaches 500’000 installs
The Android version of Freebloks 3D has now reached 500’000 installs over its lifetime and is generally considered the top search result when searching for “Blokus” in Google Play! WOOP WOOP!!
Thank you guys so much! Still, the game is fully ad-free and fully featured and hasn’t sold out yet.
Freebloks 3D is available for free in the Google Play Store.
If you’d like to support development, a paid “donation” version is available as Freebloks VIP.
WordMix 2.0
WordMix 2.0 is out! This is a due major update to my little word game for Android and includes a major face lift by bringing the game into the world of Material Design. To keep this simple, I dropped support for Android lower than 5, with a version supporting Android 4 still being available via Google Play Store. However to get the newest features you need to upgrade your device to Android 5.
Of course this update includes a number of bug fixes and general improvements, but here the major changes:
Material Design
Isn’t it pretty? The first thing you may notice is the immersive full screen mode, now spanning the status bar and extending over the navigation buttons, if present.
The action bar has been replaced with on screen controls to give more space to the background pictures and the board. So has the time progress bar given way to a simple timer. A dark button theme is easy on the eye and yet leaves focus on the game itself.
The game contains more background images and some of the old images have been replaced with new ones. All backgrounds are included in the free version, there are no more “premium” backgrounds.
This is just the first step, other screens will follow.
Bottom sheet for contextual information
Tapping a word will now reveal a contextual bottom sheet with information about the word. This for example shows the number of points for this word, whether the word is valid and has been played before and it may include actions of other apps.
If for exampe Google Translate or Wikipedia apps are installed, they appear as actions that allow the player to quickly look up or translate a played word.
Under the hood this will simply show any app that implements ACTION_PROCESS_TEXT, the same way this is integrated into Chrome.
The word suggestion feature now shows a list of possible words, their points, and allows the user to choose, with of course the option to first translate or look up the word to play. It allows to immediately set the word from the bottom sheet, which is very convenient.
New languages
Two new languages and dictionaries are now supported. Any feedback or suggestions for new languages is always welcome!
- Czech
- Polish
Available in Google Play and Amazon App Store
- WordMix in Google Play Store
- WordMix Pro in Google Play Store
- WordMix in Amazon App Store
- WordMix Pro in Amazon App Store
WordMix is (c) Sascha Hlusiak 2012-2019.
Selector.select() returns 0 immediately without blocking
TL;DR
If using non-blocking IO and setting SelectionKey.interestOps(0), a Selector will wake up on POLLHUP | POLLERR (e.g. connection reset by peer), but the JDK /Android SDK will not be able to surface this condition to the caller and will return 0 instead, potentially causing a loop with 100% CPU utilisation.
Details
I was recently investigating an issue with an Android Selector going into a busy loop where select() would return immediately without any keys being selected.
From the Android API documentation:
This method performs a blocking selection operation. It returns only after at least one channel is selected, this selector’s
wakeup
method is invoked, or the current thread is interrupted, whichever comes first.
I knew that neither the current thread was interrupted nor that the selector was woken up, yet the select() returned with an empty selected key set, consuming 100% CPU in the resulting busy loop.
There are a few reports of similar problems, e.g.
- https://stackoverflow.com/questions/35858537/selector-selecttimeout-returns-0-before-timeout/35858748#36496350
- https://stackoverflow.com/questions/9939989/java-nio-selector-select-returns-0-although-channels-are-ready
- https://stackoverflow.com/questions/16386342/android-selector-select-returns-0-immediately
- https://github.com/apache/mina/blob/2.0/mina-core/src/main/java/org/apache/mina/core/polling/AbstractPollingIoProcessor.java#L620
In particular that first link suggests that other implementations have encountered this when using the JDK and found workarounds like recreating the entire selector based on a heuristig.
After trying many things and digging through all related Android/Java/JNI classes I have finally found the cause of the spurious wake ups, which appears to be a bug in the JDK or an illegal, yet undocumented, use case when using
selectionKey.interestOps(0);
Program flow pseudo code
Our selector loop detects when channels are ready for reading but would aim to offload the actual reading of the data to a secondary thread.
do { // block until any channel is ready int ret = selector.select() // for any key that is ready for (key: selector.selectedKeys()) { if (key.isReadable()) { // make sure we are not waking up // until reading has finished key.interestOps(0); // offload the reading to a worker // the worker will call // key.interestOps(OP_READ) when done workQueue.add(key.channel()); } } // make sure all selected keys are cleared // because we've handled them all selector.selectedKeys().clear(); } while (true);
As illustrated, once a key has been detected to be ready, we unregister all interested in all operations and offload the read work to a secondary thread. We did this by calling key.interestOps(0), and pass the channel to a worker thread. When the worker thread has completed the read, it registers the channel again with key.interestOps(OP_READ).
We observed a situation where select() would constantly return 0, with the selectedKeys set being empty, causing 100% CPU load.
Missing support for interestOps(0) in the JDK
The JDK / Android SDK promises that select will only wake up if any key is ready, the selector is woken up or interrupted, but neither of these things have happened. The documentation does not mention a special handling of interestOps(0) and it can be assumed that this is a valid operation to perform.
Under the hood Java and Android SDK are using poll(2) to block for the I/O ready state. The pollfd struct takes an events field (which in our case is 0) and it would populate a revents field with the values of the ready file description.
I found that poll(2) wakes up with revents being POLLHUP | POLLERR as a signal that the remove channel is closed. This is a valid case even when registered events is 0 and any read on such an fd would return -1.
The Android AbstractPollSelectorImpl.java however FILTERS the read the nioReadyOps() by the nioInterestOps():
sk.channel.translateAndSetReadyOps(rOps, sk); if ((sk.nioReadyOps() & sk.nioInterestOps())!=0) { selectedKeys.add(sk); numKeysUpdated++; }
So even if nioReadyOps() would return a value, it would be masked out by the nioInterestOps(). Unfortunately, the translateAndSetReadyOps() in SocketChannelImp.java will ensure that even nioReadyOps() is 0, because it is set to intOps in case of error:
if ((ops & (Net.POLLERR | Net.POLLHUP)) != 0) { newOps = intOps; sk.nioReadyOps(newOps); // No need to poll again in checkConnect, // the error will be detected there readyToConnect = true; return (newOps & ~oldOps) != 0; }
Endless loop on interestOps(0) and POLLHUP | POLLERR
A selector will wake up if a registered channel has been disconnected even if interestOps has been set to 0!
However there is no way to access this condition in the userland because the condition has been masked out by the zero of interestOps. The selector will return an empty selectedKeys set instead even though poll signalled a ready file descriptor.
Fly as a chicken!
Chicken Tournament for Android received some updates recently, with some great improvements. Chicken can now fly!! This took a while to get right and I have replaced the very complex and realistic approach with much simplified mechanics (on the cost of loopings or barrel rolls).
Use either the on-screen D-Pad or fly using the device sensors.
Now I just need to teach the Computer chicken how to fly. 🙂
Check out the promo video below
As always only available in the Google Play Store:
SEQTA Learn and Engage Android Apps
The SEQTA Android Apps for Learn and Engage are now available in the Google Play Store. While the iOS App has been developed in-house by an external developer, I developed the Android versions as a side project at home. The Apps were later handed over and integrated into the portfolio of the company.
SEQTA Learn and Engage are (c) SEQTA Software, 2017.
The two Apps are mostly identical other than branding and the target audience and feature native login experience, QR Code scanning for signing in via a code, push notifications and a webview to display the content. They support multiple accounts and support modern Android features like launcher shortcuts.
Android Apps free in Google Play
- https://play.google.com/store/apps/details?id=com.seqta.android.learn
- https://play.google.com/store/apps/details?id=com.seqta.android.engage
Read the official announcement or FAQ.
Screenshots
Bustle Android App
Living in Sydney and would like to quickly look up the waiting times of the closest bus stop near you? Checkout the Bustle Android App in Google Play:
Screenshots
Freebloks 3D on F-Droid
Freebloks 3D is now also available on F-Droid, an alternative app store for Android containing only completely free and open source software. This version is free of any non-free dependencies or libraries.
Source code:
WordMix on Amazon Underground
WordMix Pro is now also available on Amazon Underground. This is identical to WordMix Pro, which is sold on the Amazon App Store or is available as an In-App Purchase to WordMix, but apps on Amazon Underground are “actually free” while fully featured. Get it now!
WordMix on tablets, learning Japanese
A recent WordMix update brings much improved support for Android tablets as well as experimental support for Japanese dictionary.
Improvements to the layout for 7″ and 10″ Android tablets were long overdue, fixing some issues where activities and controls looked out of place because they were initially created and optimised for mobile phones.
Further I based the App’s theme on Holo for Android 4 and on Material for Android 5, ditching the DeviceDefault as a recommendation. In my experience, vendors quite often ship a DeviceDefault implementation, that is inconsistent, incomplete and quite often breaks visual appearance. In order to work around inconsistent presentation on some Android devices, I have decided to pin the theme to a set of known appearance with some custom styling, bringing a consistent look across all Android 4 and Android 5 devices (Android 2 and 3 support has been removed).
Only new feature is the experimental support for Japanese as a language, including a Japanese dictionary (needs to be downloaded after installing the App). Japanese is particularly difficult to implement in this game due to the high number of different letters and combinations. Similar sound combinations have been combined as single letters, allowing to choose the specific sound by tapping on the dice. Feedback is appreciated!
As always, get it in Google Play Store, while it’s hot!
- https://play.google.com/store/apps/details?id=de.saschahlusiak.wordmix
- https://play.google.com/store/apps/details?id=de.saschahlusiak.wordmixpro
Sony Xperia Z2 still touch screen issues
Still looking for a high-end Android tablet with software navigation buttons (which rules out pretty much the whole Samsung product range), the Sony Xperia Z2 tablet still beats the competition by far.
The situation back then
In early June this year I bought a device like that only to discover soon that there seems to be a systematic problem with the tough screen that’s troubling lots of users, including me.
- In certain situations the touch screen would not detect multi touch events, e.g. it would skip keys when typing on the onscreen keyboard
- It generally has a problem with two touches that are aligned on a straight line, i.e. two fingers with the same y-value or with the same x-value, resulting in erratic touches, which would be interpreted as random tap events
- Occasionally the device would not recognise touches at all or they need to be very hard / firm. Turning the display off and on usually helped for a short time.
A lot of users complained about this in online forums, some reviews mention it and youtube videos demonstrated the problem:
https://www.youtube.com/watch?v=nbtc96YE6O8&spfreload=10
It was unclear if this is a grounding issue or something that could be fixed with a software update. The software update 17.1.1.A.0.402 came but even 4 month after the device was released by Sony, this issue still wasn’t fixed.
The situation now
Firmware 17.1.2.A.0.314 was released middle of July. Even though news sites repeat the release notes that the issue has been fixed, users are still reporting problems with the latest version:
Users in forums still complain. No solution is known. And the worst:
Sony has not even publicly acknowledged the problem.
Local stores still sell the Z2 with the flawed touch screen, but no information anywhere if this problem is known, analysed and will eventually be fixed.
Inexistent product support
This inexistent product is incredible. This product has been released half a year ago and is still the top tablet on the market as of today and an incredible device. I can’t believe Sony still hasn’t acknowledged a problem or provided a fix that makes this device actually usable. Sony here seems to sell a broken device despite of many users complaining about the poor touch screen but without any hope that Sony will fix the device. Instead Sony decides to work on the Z3 and Z3 tablet compact, while the Z2 still has so much potential to be actually bought.
Not only can’t I buy the Z2 because it is basically broken by design, I must hesitate to buy any Sony product at all because of their poor customer service and product quality.
I can’t believe how bad Sony’s customer and product service is and can only recommend to not buy any products from companies, that care so little about their users.
Unfortunately there is no matching tablet on the market as of today so all I can do is wait.
Water splashes
Sometimes tiny little details can make all the difference. If an egg in Chicken Tournament for Android hits the water, a watery particle system is spawned for the splash. This is just a modification of already existing particle systems but it feels super nice and looks flashy. Of course this is miles away from looking like real water but that’s not the goal and the pure reaction and feedback of an egg hitting the water does make all the difference.
Chicken Tournament for Android
Long time no post about the Android version of Chicken Tournament. But it’s doing very well, despite lack of time. 🙂 And the best, you can already check it out in Google Play!
New particle systems
A couple of updates later, the completely rewritten game now features improved particle systems like blood, feathers and fire and comes with limited keyboard support. Especially the new feathers took careful design and tuning to get the physics right but I’m very pleased with the optic result and performance. Of course, cranking up the amount of effects, I’m sure it can bring every device down.
UI sound effects improve overall feeling and experience. Having in mind that this game was completely written from scratch using a self written engine and pretty much not reusing any code, I am extremely proud of the result.
Career mode
The new career mode features an experience and skill system for your hero, level by level. You can collect different hats that will further improve your skills and stats.
In Google Play
The demo version can be downloaded free of charge, it’s ad-free but has a limited feature set. Those features are without limitations tough, like pay-2-win or In-App-Purchases. There is a fully featured full version, meant to support me and my work.
But some important features are still missing though, like:
- Multiplayer mode
- Playing as chicken
- Highscores and ranking lists
- More and more and more optimisations
I’m just one man, please be patient. If you find bugs of have suggestions, please email me at ct@saschahlusiak.de.
Thoughts on Google Play Game Services and games
I recently updated the Google Play Game Services library of Freebloks 3D for Android and the BaseGameUtils, as recommended by Google. Not reading the ChangeLog, I was confused that my game tried to auto log in to Google on the start, disrupting the user experience I built around that. Even after dismissing the login dialog once would show the dialog again in the next Activity that is derived from BaseGameActivity or uses a GameHelper object.
Searching the Interwebs I found the FAQ, which explained the change of behaviour, and I am sad that the game itself once again becomes more and more insignificant:
The default behavior of BaseGameActivity and GameHelper is to show the user the sign-in flow (consent dialogs, etc) as soon as your application starts. Naturally, once the user signs in for the first time, they won’t see the consent flow again, so it will be a seamless experience. […]
The first time a game is started, the user will be prompted with a full screen dialog asking the user for consent to post on their behalf to Google+. The user hasn’t seen anything of my App yet and still Google tries to put itself into the foreground. After the user signed in, this might become a seamless experience but being prompted with this dialog does not seem like a good experience. Especially because there is no warning or explanation of what this dialog does.
It is important for the user to sign in as early as possible so your application can take advantage of the Google Play Games API right away (for example, saving the user’s progress using Cloud Save, unlocking achievements, etc).
I noticed that usually I want to explore the game a little before signing in to Google. I’d like to find out if the game is a game I’d continue to play and once I get engaged with a game, I am willing to sign in to use the additional features. I know I am not an everyday user and I am aware that logging in to Google gives up some privacy. And before I haven’t decided to continue playing a game, I do not want any information to leak or social activity to be generated.
Obviously this reads to me as:
it’s important for the developers and Google to get user generated activity and data as soon as possible.
And is again another step towards games telling the users what to do.
If the user cancels the sign-in flow, BaseGameAcitivity/GameHelper will remember that cancellation. If the total number of cancellations reaches a predefined maximum (by default, 3), the user will no longer be prompted to sign in on application startup. If that happens, they can still sign in by clicking your application’s Sign In button, if you provide one.
Is not signing in to Google not a choice anymore but an error? If I dismiss the dialog because I do not give consent, is that assumed to be an error? Do I have to be prompted again even though I made the choice to not log in? Do I really have to dismiss the dialog 3 times until the game believes me that I do not want to log in?
The games are taking over!
I noticed the trend of games beginning to control users, of being needy, wanting attention, and developers seeing games only as a way to generate a stream of content or resources back to the developer.
Games these days:
- show popup notifications that they want to be played.
- make the user attend the game by long running tasks in the background that finish whenever. Building a building may take 5 hours, after which I have to open the game again.
- want you to share everything on Facebook or Google+ (“Your creature took a dump. Share on Facebook?”). This is not to make you happy or to provide a game element, it is purely to attract other people and make them install the game.
- tell you exactly and in detail how to use it. A lot of games begin with a 10 minute intro (“now click here”, “now buy upgrade”, “now shoot”) to make sure that the user understands the concept of buying upgrades and in game currency. This leaves very little room for experimentation and explorations, because users need to follow the strict predefined path that generates revenue.
- lock you in. Using In-App-Purchases basically makes you rent the game, it is like Prepaid and the decision to stop playing a game is harder, because you have money that will expire. When you buy a game and own it, you have the freedom of choice to not play it. Buying your right to play the game over and over will most likely leave you hanging in an awkward spot when you decide to stop. Oddly enough these games are advertise as Free or Free2Play or, less often, Pay2Win.
- use gamification to seem more interesting. Most games implement achievements in a way, so that they are not game elements. The Google Play services offer achievements that are outside of the game, meaning they don’t change the game flow, giving the user no actual value of an earned achievement. While the wording suggests the user benefits from earning an achievement, this is likely to drive engagement with the game but will not result in higher user experience or even fun. I fear the day users wonder about the motivation to achieve anything.
- artificially restrict themselves but still take over your time. Why does building a house takes 5 hours sometimes, while the game does not any other game elements during that time? I’s making me hooked, telling me to go on with my day but of course I will always have the game on my mind and I have to come back after 5 hours. The game dictates when the user can play with it and when he can’t. It is not the users decision anymore to play and spend time with the game.
Where did the games go that gave power and freedom to the players to do what they want to do? With room to explore? With having game elements to actually fill 5 hours of time, then waiting and being ready when I come back to it? Where did the love go to provide the user with a fun way to pass his time?
This is not about the user anymore. He is not the customer, he is the good to be sold, the “conversion” to be made. The game is just the means and additional game elements are in the way. Games became a pure medium for developers and Google to say to users: “Give me your money”.
Where was I? Oh yes, disable the auto-login.
Easy enough the above behaviour can be reverted by
getGameHelper().setMaxAutoSignInAttempts(0);
but that’s not the point. Give the power back to the user!
Sony Xperia Z2 Tablet with touch screen problems
Last week I decided to buy a tablet with Android. After looking a while I decided to go with the Sony Xperia Z2 Tablet, which in my opinion is an awesome tablet. It is powerful, light, high quality finish, even waterproof and incredibly thin. Being definitely in a high price range, this is a professional tablet, which cost me roughly 420 EUR.
Only after buying and using it at home for a while, I occasionally experienced erratic touch screen behaviour. Touches would be not recognized, sometimes swipe gestures would be detected as taps, multitouch gestures would stop and break in the middle and sometimes middle touches would only be detected, if pressed very hard. And even then the touches would not be detected reliably, resulting in random taps, performing undesired actions. This is usually with the tablet laying on a flat surface, quite often over night. I know that electric fields while charging a device quite often disturb the touch screen, but with the Sony Xperia Z2 this happened without the charger connected. I had the latest available software installed, the 17.1.1.A.0.402, which obviously did not fix the issue.
Turning the screen off and on usually fixed the situation temporarily, but that is not a solution as it would randomly happen again.
I downloaded a touchscreen test app and also found that the tablet has a very hard time recognizing touches, when two fingers are exactly in a horizontal or vertical line. It would simple drop both fingers. This is not acceptable multitouch behaviour, where one touch affects the other.
Confused I searched the Internet and found quite some people reporting the same issue, even a YouTube video demonstrating the problem, making me believe this is a systematic design flaw, not just a flawed device:
- https://www.youtube.com/watch?v=nbtc96YE6O8
- https://www.youtube.com/watch?v=yb5ac41CD1Q
- http://community.sony.co.uk/t5/tablets/xperia-z2-tablet-touch-screen-issue/td-p/1582051
- http://talk.sonymobile.com/t5/Xperia-Z2-Tablet/Touch-screen-problem/td-p/620325
- http://community.sony.com/t5/Xperia-Tablet/Xperia-Z2-Tablet-touch-screen-issue/td-p/302888
- http://www.tabtech.de/tablet-tests/review-sony-xperia-z2-tablet-im-test
- http://www.android-hilfe.de/sony-xperia-tablet-z2-forum/552586-touchscreen-reagiert-nicht-immer-zuverlaessig.html
Sony Support recommended me to install the latest software (this was already the case) and then said, my device might need repair. This issue has apparently been around since several month and still Sony did not confirm the problem.
But I believe my device wasn’t actually broken but suffered from design flaws, I returned it for a refund. I am not willing to try different devices until I find one that actually works. Not with so many people complaining about the touch screen. Not for this price.
Sorry, Sony, you made the Xperia Z2 Tablet too thin and you have problems to get it to work properly. I’m sorry my first experience with a Sony mobile device had to be a negative one and with this issue not even publicly confirmed, I can’t recommend buying it. Too bad, it could have been such an awesome tablet.