Mobile Development
Contents
[hide]Device Considerations
Platform
Will you be developing for multiple platforms?
- Android
- iOS
- Windows 10 Mobile
- Blackberry 10
- Firefox OS
- Sailfish OS
- Tizen
- Ubuntu Touch
- CynaogenOS
Hardware
- Depending on the device, the specifications of hardware can be very different
- Some devices may not have certain components
- Vintage of components, such as processors and busses will make a difference to the chosen route
Language
- What programming languages are supported natively by the device?
- What language suits what you want to do best?
- Do you need a combination of languages for collaborative tasks?
Form factor
- Most platforms/OSes run on multiple devices, some more than others
- Can your application be utilised on all form factors regardless of screen/size?
Native vs Hybrid Frameworks
Native Application Frameworks
Native application frameworks allow developers to access the native platform/OS API directly through code and develop their applications directly to the platform standards and practices
- Pros:
- Without other intermediate layers, this provides the best application per device in terms of performance
- There is no third-party dependence on access to updates and bug fixes
- Cons:
- As a native application is written and compiled for a specific platform/OS, deployment on another platform typically requires the maintenance of a totally separate project for each of the supported platforms.
- How the application is distributed can be different for each platform, requiring the maintenance of a separate distribution channel per platform
Hybrid Frameworks
Web-based frameworks are essentially tools/processes/procedures that allow us to write an application as a website rather than using any native code (e.g. PhoneGap/Cordova)
- Pros:
- Anyone with basic web-development skills (HTML, CSS, JS) can write a decent application.
- There are several frameworks to choose from.
- It is possible to wrap the content in an application or just access it with the built-in browser.
- Applications can be accessible across multiple platforms.
- Cons:
- Going through so many higher-level languages and interpreters makes run-time much slower than a native application
- Each platform has a unique style and mode of operation. This gets lost in a web-based application or, at least, requires a lot of work to make it seem intuitive for each platform.
Cordova/PhoneGap
Apache Cordova/PhoneGap enables software programmers to build applications for mobile devices using CSS3, HTML5, and JavaScript instead of relying on platform-specific APIs like those in Android, iOS, or Windows Phone. It enables wrapping up of CSS, HTML, and JavaScript code depending upon the platform of the device. It extends the features of HTML and JavaScript to work with the device. The resulting applications are hybrid, meaning that they are neither truly native mobile application (because all layout rendering is done via Web views instead of the platform's native UI framework) nor purely Web-based (because they are not just Web apps, but are packaged as apps for distribution and have access to native device APIs).
Is PhoneGap equal to Cordova?
https://www.businessofapps.com/news/apache-cordova-adobe-phonegap-know-real-differences/
PhoneGap is a distribution of Apache Cordova. So Apache Cordova serves as the engine to power PhoneGap just like WebKit is an engine that powers Chrome and Safari (iOS browser). Nonetheless, as an app developer or as an organization, you don't have to worry about the differences between these two. The story is like this:
- PhoneGap was previously a product of Adobe.
- To keep it open-source always and follow standards, PhoneGap codebase was handed over to Apache.
- At Apache, it got a name change as Cordova.
- And now it’s better known as Apache Cordova.
The most important to understand here is that PhoneGap is powered by apache Cordova. PhoneGap is Cordova plus some extra Adobe stuff. If you are developing a hybrid mobile app, you can either create it using proper Cordova or choose Adobe's ecosystem for using PhoneGap distribution of Cordova.
The open-source Cordova/PhoneGap will be always free and delivered by Apache. Over time, Adobe may add values to this (current) codebase that consists of other Adobe services and that will be named as PhoneGap, which will be chargeable.
Installing Cordova
https://cordova.apache.org/docs/en/latest/guide/cli/
- Install Node.js and NPM: See HTTP REST APIs with Node.js - Express.js
- The Cordova command-line tool is distributed as an npm package.
- Install Cordova with NPM:
sudo npm install -g cordova
The -g flag above tells npm to install cordova globally. Otherwise it will be installed in the node_modules subdirectory of the current working directory.
- Check Cordova Version:
cordova --version
- (Optional) Download and install a git client: See Collaborative and Remote development#Git and GitHub
- If you don't already have one. Following installation, you should be able to invoke git on your command line. The CLI uses it to download assets when they are referenced using a url to a git repo.
Using Cordova
https://cordova.apache.org/docs/en/latest/guide/cli/
Create the App - Project folder
https://cordova.apache.org/docs/en/latest/guide/cli/
Execute the below command to create an «Cordova application environment/Project folder»:
cordova create myapp
or using the entire syntax:
cordova create path [id [name [config]]] [options] cordova create hello com.example.hello HelloWorld
This creates the required directory structure for your cordova app. By default, the cordova create script generates a skeletal web-based application whose home page is the project's www/index.html file.
Now add the required platform in your application. This will create required files for the corresponding platform under the platforms/android and platforms/ios directories (may be necessary to use sudo):
cd myapp cordova platform add ios cordova platform add android
Use below command to list the installed and available platforms for Cordova application:
cordova platform -ls
If you accidentally added any platform which you no longer needs, just remove that using commands like below:
cordova platform remove ios cordova platform remove android
Install pre-requisites for building
To build and run apps, you need to install SDKs for each platform you wish to target. Alternatively, if you are using browser for development you can use browser platform which does not require any platform SDKs.
To check if you satisfy requirements for building the platform:
cordova requirements
Android platform requirements
Java Development Kit - JDK
See Java
Gradle
sudo apt install gradle
Android SDK
Installation:
- Go to the Android Studio official page: https://developer.android.com/studio/index.html
- Download and unzip the sdk-tools-linux zip file.
- To complete the installation we need to add the paths of the bin folder to our PATH environment variable:
.bashrc
PATH=/home/adelo/1-system/.1-conf-system/1-archivos_programas-ubuntu/android-sdk/tools:$PATH PATH=/home/adelo/1-system/.1-conf-system/1-archivos_programas-ubuntu/android-sdk/tools/bin:$PATH
- We can also do it using apt. However, when I did id with apt, I was not able to find the sdkmanager command in my system. So I recommended to do it by downloading the zip file from the official page.
sudo apt install android-sdk
Adding SDK Packages:
After installing the Android SDK, you must also install the packages for whatever API level you wish to target. It is recommended that you install the highest SDK version that your version of cordova-android supports (see Requirements and Support).
Open the Android SDK Manager (Tools > SDK Manager in Android Studio, or sdkmanager on the command line), and make sure the following are installed:
- Android Platform SDK for your targeted version of Android
- Android SDK build-tools version 19.1.0 or higher
- Android Support Repository (found under the "SDK Tools" tab)
See Android's documentation on Installing SDK Packages for more details: https://developer.android.com/studio/command-line/sdkmanager
Esta fue la parte más complicada. Si no se instalan los package necesarios en esta parte, la ejecución del comando cordova requirements no encontrará la instalación e «Android target». Esto creo que lo solucioné de esta forma:sdkmanager "platform-tools" "platforms;android-28"
Setting environment variables
- Cordova's CLI tools require some environment variables to be set in order to function correctly. The CLI will attempt to set these variables for you, but in certain cases you may need to set them manually. The following variables should be updated:
- Set the JAVA_HOME environment variable to the location of your JDK installation: See Java
- Set the ANDROID_HOME environment variable to the location of your Android SDK installation:
On Ubuntu, android-sdk (if installed using apt) is usually at:
/usr/lib/android-sdk/
- It is also recommended that you add the Android SDK's tools, tools/bin, and platform-tools directories to your PATH:
- El zip file sdk-tools descargado de la página oficial, sólo contiene el directorio tools. No contiene ningún directorio platform-tools. La explicación indica que debemos adicionar estos paths (https://cordova.apache.org/docs/en/latest/guide/platforms/android/index.html#setting-environment-variables):
export PATH=${PATH}:/mi_path/platform-tools:/mi_path/tools
- Sin embargo, '/mi_path/platform-tools no fue encontrado y /mi_path/tools ya ha sido adicionado en la instalación de sdk-tools.
~/.bashrc
# Cordova - Android platform requirements: #* Set the ANDROID_HOME environment variable to the location of your Android SDK installation: export ANDROID_HOME=/usr/lib/android-sdk/ #* It is also recommended that you add the Android SDK's tools, tools/bin, and platform-tools directories to your PATH (Ver explicación arriba)
Build the Cordova Application
On all requirements completed successfully run the build command to build your application:
cordova build ## Build all added platforms cordova build android ## Build for specific platform