How to choose the right platform for your mobile app

A key focus of mobile app development is shorter development cycles to get to market fast, while making sure it performs well. But do you have to chose between great user experience and speed?

At Polymorph, we work hard to deliver both and guide you through the platform maze to make sure you make the right choice for your mobile app development. Let’s take a look at the various options;

Hybrid

Hybrid apps are developed in HTML5, CSS and Java Script and then wrapped in a Native application platform. It is the way to go when you need a front-end that runs locally, but mostly interacts with information from a backend. The front-end doesn’t use a lot of the platform-specific functionality of the phone, and your app is basically an easier-to-use mobile website, packaged to run as an app, with all the advantages of that (push notifications, lower data usage, mature web technologies)

The choice to use Hybrid is usually centred on the idea that development costs will be halved. This is related to the fact that there is one codebase used for both platforms. In practice though, this is not the truth. Unfortunately, getting Hybrid to run across platforms can be a challenge and so your app might not look great across all platforms. Getting this right might raise the costs substantially – thus reducing your savings from not building multiple native apps. Below are examples of these tools and the challenges when using them:

React Native

A challenge with React Native is that it does not support all native APIs thus, not all functionality is included. This means that you still require people with in-depth knowledge of specific languages to write Native Modules if you want specific functionality. React Native is a small, but rapidly growing community and there are fewer libraries to draw from than with Native. Design guidelines differ with Android and iOS which means that the code will be filled with if statements (if android, do x, if iOS, do y) – this clutters the code. Everyone is working towards closing this gap.  For now, although it is promising, it’s not yet living up to it’s promise of halving the cost and time with app development.

Xamarin

Based on the Microsoft technology stack that  uses a single language – C#. What is great about Xamarin is the ability to create platform specific User Interfaces (UI). The performance is similar to Native development and there is full hardware support. The challenge is that the app can be larger than if one built in Native, and as with all Hybrid apps, it still takes time to tweak and optimise for different platforms.

Cordova

The great aspect of Cordova is the ease of development. However, like all cross-platform implementation, it is not as clear cut as that and depending on the requirements will need more work in the platform. This is assisted by a large community that is active. The great challenge with Cordova is the user experience. The user’s perception of how responsive the app is to touch and taps can be much more negative than for Native apps.   

For an example of detailed and well designed Hybrid app development, take a look at the banking app we developed with Capitec as well as our first product built on our Leased Product Model; Linebooker

Native

Native apps are written in a programming language that is native to the device and it’s operating system. iOS apps are usually written in Swift or Objective-C, while Android apps are written in Java. This means that you have to have two codebases because the coding cannot be shared as it is a different language. Although this may be seen as a negative, the positives are vast in terms of access. As you are building in that device’s language, you will be able to create more in your app as well as have great performance and speed.

Devoted communities to iOS and Android mean that there are vast libraries to chose from that will help improve your app immensely. In Native, your Bluetooth and location services are also more reliable. With specialised knowledge in the language comes an understanding of the platform and underlying architecture. This means that your app is built efficiently with the deepest knowledge available.

A quick reminder that the backend is usually share-able and so it can be the same for both versions of the app.

Most of our apps are Native. Pelase take a look at Energy Partners and Snuza for examples of Native apps we’ve built.

Web App

The difference between a web app and a mobile app is that a web app does not have to be downloaded. Mostly, web apps are built in JavaScript, CSS and HTML5. The great thing about a web app is how fast you can develop one and get it into user’s hands. This is because they are simple, which is also the challenge as web apps can’t do half of what a mobile app can. When deciding about this, keep in mind that users spend about 51 minutes per day on mobile browser activities, while they do spend 3 hours and 15 minutes using apps everyday.

Which one is right for my mobile app development?

The question is, what is your goal? What do you want your app to do? Do you know what your intended client uses? For example, is your client base definitely an Android user perhaps because it is a low income market? Ultimately apps are suppose to feel good to use and if they don’t your users will move on. Is speed key to the success of your app?

It is important to discuss this and more with the team you decide to work with. Ensuring that your mobile app is built in the best way possible begins with identifying which platform to use. That’s why at Polymorph we specialize in languages and are always learning to ensure that the needs of your mobile app guides us to make the best mobile app for you. To make the decision on what platform is the best for your app, talk to us. We can help you answer that question based on our experience of developing for all platforms, over many years.

Please click here to take a look at the apps we have made and if you haven’t downloaded it yet.

Take a look at our e-book of canvases ready for your next great business idea (link at the bottom of the article).

Planning to build an app? 

Try our free software development calculator to maximise your ROI.

Request for Access to Information

The following forms are available to download with regards to request for access to information:

REQUEST FOR ACCESS TO RECORD

OUTCOME OF REQUEST AND OF FEES PAYABLE

INTERNAL APPEAL FORM