We released on Wednesday the first beta of feedly for android – for both phones and 10″ tablets. Here are some of the lessons we learned during the last 5 days.
Android has an open app distribution model so we started by pushing the app to our website, invited 50 users and tried it for 12 hours to see if they were any major show stoppers – very valuable given that there are a lot of different types of phones and we only tested feedly on a Nexus ONE and Nexus S. After 12 hours of testing, we moved the app to the Market and invited more people. This incremental release worked well.
The Android community seems to be a lot more engaging than the iOS community. After 24 hours, we had 100s of comments/reviews on our blog post, in the market and on facebook. Although it is never fun to hear that your baby is ugly, it was very helpful in terms of helping us understand where the rough edges were and what we could do to better integrate with Android (see the bad).
We have spent a lot of engineering effort to create feedly as what we call an “ultra universal application” – a single code base which runs on iPhone, iPad, Android phones and Android tablets (while mutating it experience to the device form factor). The challenge is to do so while being able to deeply integrate the application with the underlying user experience and operating system. To do so, we are using a homegrown framework called streets.
We learned a lot over the last few days regarding what is important to Android users when evaluating app (and improved streets and feedly for Android beta 2) to address this.
1) Account Management. Instead of asking users for their user names and passwords (which has the added issue of not working well with the new 2-factor authentication used by Google), the app should integrate with the Android Account Management framework. [The Account Management API is well abstracted out and it was fairly easy/non intrusive to plug it in].
2) The back button. iOS devices do not have a back button (and under the cover feedly uses a URL addressing for navigation) so when we started to look at making feedly available on Android, we did not spend a lot of time thinking about the back button. That was a mistake. The back button and the concept of “activities” are a very important element of the Android user experience – and something users seem to use a lot and expect to work. In beta 2, we spent a couple of days analyzing the feedly mobile UI and breaking logically it out into activities and making sure that the back button did the right thing in terms of allowing users to transition back to the previous logical activity. It helps make the experience feel a lot more fluid.
3) Intents Android includes a pretty sophisticated app integration framework called intents. Although the data passing between intents is still a little too opaque, Android users expect apps to work nicely together. In beta 2, we spent some time to better understand intents and see how we could better integrate with the system wide sharing mechanism they enable. Something a lot of users asked for in the comments.
4) Look and feel A side effect of the ultra-universal app approach was that some of the icons and styles we used in Beta 1 were a little too iOS-ish. Beta 2 does a much better job integrating into the Android look and feel and visual language.
5) Widgets One of the key benefit of Android is the sophisticated home experience and the ecosystem of widgets it can host. This is something users seem to care a lot about. So if you are designing an Android App, you should make sure that it includes a widget. Something we are looking into for beta 3.
Feedback for Google
Feedly for Android is our first Android application. It was interesting to go through the design, implementation and release of the application. Here is some feedback for Google on some of the things they could improve.
1) Documentation/Example. The Android APIs are well documented at the Java Doc level but finding examples for the most common things developers need to do is still hard (and when you find an example on someone else blog, it is not always clear if that is “the best practice”, if it is still valid in the latest version etc…). StackOverflow helps fill some of the gaps here but there is still a lot more which could be done.
2) Market. Allow apps to include screenshots for 10″ tablets. Allow devs to reply to reviews and engage with users.
3) UI. This one is a little more fundamental but as a web developer, I find it hard to have to learn a new layout language and styling language…specially given that they end up being more constraining than HTML and CSS. Why not take HTML and tell developers: if you use this subset, your app is going to be highly optimized….and let devs port their knowledge over.
4) Intent – URL mapping. It would be nice to create a way to map intents into URLs so that the integration points between applications are just links (or REST+JSON interactions). More fluid inter app interactions is where Android is a few years ahead of iOS. There are a few things Android can learn from Chrome and the Web and continue to widen that gap.
5) Hardware acceleration/GPU. This is one area iOS and Apple Hardware working together really shine. It results in both a smoother experience and better batterie life. Android 3.0 is starting to talk about this. It would be really great if Google could invest in this and make sure that Android 4.x is really in par with iOS when it comes to CSS transformations and Hardware acceleration.
We have grown to become big fans of Android and look forward to many more releases of feedly for Android powered devices.