Cordova: Your Backstage Pass to Mobile Device Hardware

Cordova, Phonegap, iOS, Android

Overview

  1. Introduction
  2. Setting up Cordova
  3. Making a Cordova project
  4. Running the App on the Device
  5. Using Plugins
  6. Device Considerations
  7. Development Workflow
  8. Using Cordova with Git

Introduction

An App In Action

What we'll cover in this talk

  • Cordova works with Windows, Linux, and Mac OS
  • This talk: Mac Development Environment
  • Command Line - mostly
  • Building for iOS and Android...
  • other device platforms exist!

So many apps!

So what?


HTML5 NOW

HTML5 improvements

  • Standards improved
  • Faster
  • More Responsive
  • Use a JS Framework! Like Backbone.js, Knockout.js, Ember.js
  • ... but not Angular
  • ... because it sucks

What is Cordova?

Cordova - The details

  • Make native apps using HTML, CSS, and Javascript
  • Making the interface = building a webpage
  • Native advantage - Access parts of the device that a webpage can't
  • Make an app for iOS, Android, Windows Phone, Blackberry, Firefox OS, and more

What about Phonegap?

  • Adobe's mobile development framework that is powered by Cordova

Cordova vs. Phonegap

  • Phonegap makes cloud-based builds
  • This guide uses command line Cordova
  • Free, license isn't restrictive
  • Build locally with no internet connection
  • Compatible with more third-party plugins
  • More setup than Phonegap

Development Workflow

Cordova Setup

  • Install SDKs and environments
  • Connect and Unlock Device for Development
  • Create project
  • add platforms
  • add plugins
  • READY!

Browser Testing

  • Open /www folder in web browser
  • Test and fix like a webpage
  • Native functionality?
  • Branch it out so non-native parts can still be tested in the browser

Device Build

  • Build app with cordova build <platform>
  • Run on device, using either cordova run or IDE
  • Check debug logging on PC (if using console plugin)

Super-ugly sketch of Cordova build paths

Using Cordova with Git

(Discussion)

THANK YOU

Any Questions?


wrenjs [Twitter]

wrenr [GitHub]