Presentation is loading. Please wait.

Presentation is loading. Please wait.

Mobile Applications Industry is in a state of competitive flux not seen since the days when mini-computer manufacturers first flooded the market – There.

Similar presentations


Presentation on theme: "Mobile Applications Industry is in a state of competitive flux not seen since the days when mini-computer manufacturers first flooded the market – There."— Presentation transcript:

1 Mobile Applications Industry is in a state of competitive flux not seen since the days when mini-computer manufacturers first flooded the market – There is now open source, but there are also lots of proprietary secrets – Standards are evolving rapidly Prediction: there will be winners and losers Based on history: Winners will not likely produce the best products – Superior marketing strategies gain traction quickly Example: Microsoft versus Apple in the 1980s – Getting to the public to fill a need before standards are established Example: Early browser war between Netscape and Explorer Bottom line: Development is expensive; mistakes can be disastrous Assumption: We have an idea for a hot new mobile application General Considerations

2 Hardware Specifications Display Sizes – Laptop/Desktops: 15”, 17”, 19”, 21”, etc. – Phones: 1½”, 2.3”, 3”, 4” – Tablets: 7”, 8”, 10.1”, etc. Mobile Device Resolution – Low end: 128x128 – Mid end: 240x360 – High end: 320x480, 1024x768, 1200x800, etc. Operating Systems : Android, WebOS, Windows 8, iOS, Blackberry Manufacturers: Apple, Nokia, RIM, Samsung, Sony, Motorola, LG, HTC Memory: 256MB – 1GB; Storage: 1GB-32 GB Processor Speed: 500 mhz – 1 ghz

3

4

5 Tablet Market Share Note: The Android market is fragmented among dozens of manufacturers

6 Pixels and Aspect Ratio Pixels per inch (ppi), or dots per inch (dpi) – High resolution may mean that you need a magnifier glass to read text – The retina has a limit of 300 ppi – Zooming in and out may be necessary Aspect ratio – Width to height ratio differs between devices – When turning the device, the aspect may change Does the device automatically zoom to fit? Does the device adjust the font to accommodate?

7 Features Key Entry – Virtual or physical keyboard – Numeric or alphanumeric entry – External keyboard attachment Interacting with applications – Touch or multi-touch – Handwriting and/or voice recognition Geo-location Facial and gesture recognition Connections: Phone, web, texting, email

8 Best Practices Handle unavailable or lost network connection Limit permissions requested as much as possible Optimal use of storage. Use the SD card if possible Use standard GUI layouts Efficient, fast, responsive Multi thread slow time consuming operations Save application data when state changes occur Share data with apps by implementing content providers Implement activities launchable from other apps Utilize notification facilities, progress bars, flash screens

9 Design Considerations Orientation changes Varied screen sizes and resolutions Operating system choice to reach a wide audience Intuitive operation Reason for continued use Well-defined purpose Multi user support Upgrades/new features (without feature creep) Multiple language and color support Varied font sizes

10 Getting the product to market Register for an Android Market account: market.android.com/publish/ Click: Setup Merchant Account to set up a Google Checkout Adhere to Android application policy requirements (www.android.com/market/terms/developer-content-policy.html) Digitally sign (can be self-signed) and upload to the Android market (see developer.android.com/guide/publishing/publishing.htm) Price the application – The average paid app price is $3.13 – 30% for Google; 57% are free. – In app advertising price per view – virtual products (Google retains 5%) – Limited free version, with paid version having full capabilities Market: social media, app review sites, advertising networks, etc..

11 Browsers Preinstalled – NetFront, Myriad, Explorer, Safari, Nokia, Sony, Obijo, Motorola, Symbian, Android, webOS, Blackberry, Samsung, MicroB User-installed – Opera Mobile, Opera Mini, Firefox (Fennec) for Mobile, Chromium, UC, SkyFire, Bolt Webkit – Open source framework used by many browsers

12 Questions to Ask? On which device(s) will our application run? Should it run in a browser or as a native application? Which language(s) should we use? – HTML5/JavaScript, Objective C, Java ME, Flash, Silverlight, C#, Dalvik VM, Java FX Which cross-platform development framework should we use? Do they have their own API to learn? If JavaScript, which JavaScript libraries should we incorporate? How do we develop/debug? – Which emulators/simulators are available? – What development toolkits do we use?

13 This Class Part 1: HTML5/JavaScript. Why? – JavaScript supported on all popular smart phone and tablet devices – The popular browsers have good debugging facilities – There are extensive JavaScript frameworks and libraries that attempt to facilitate application development and provide cross-platform compatibility – There are toolkits to translate from HTML5/JavaScript to native applications – Smaller learning curve for cross-platform development – Industry is moving in this direction (at least at the moment) Part 2: Native Applications on Android. Why? – Android is rapidly gaining market share – The Eclipse JDK/Android emulator provides good development tools – Android’s Java is not too difficult to learn and use – Familiarization with at least one mobile development platform is beneficial – HTML5/JavaScript must be tested/debugged on every possible browser

14 Popular JavaScript libraries/Frameworks Google We Toolkit - GWT (http://code.google.com/webtoolkit) Free toolkit, used by thousands of developers for complex web applications. Code in Java; deploy in JavaScripthttp://code.google.com/webtoolkit jQuery (http://jquery.com/) : JavaScript library that simplifies HTML document traversing, event handling, animating, and Ajax interactionshttp://jquery.com/ Prototype (http://www.prototypejs.org/) and script.aculo.us (http://script.aculo.us/) : Easy to use class-driven JavaScript framework that aims to ease development of dynamic web applicationshttp://www.prototypejs.org/http://script.aculo.us/ YUI (http://developer.yahoo.com/yui/ ) : JavaScript and CSS utilities and controls for richly interactive web applications. Built by Yahoohttp://developer.yahoo.com/yui/ Dojo (http://dojotoolkit.org) : A toolkit, focusing on performance, for building desktop and mobile web experienceshttp://dojotoolkit.org MooTools (http://www.mootools.net/ ): Object-Oriented JavaScript cross-browser framework for intermediate to advanced JavaScript developershttp://www.mootools.net/

15 Mobile Frameworks jQuery based o jQuery Mobile (http://jquerymobile.com/): a Touch-Optimized Web Framework for Smart phones & Tablets.http://jquerymobile.com/ o jQTouch (http://jqtouch.com/): jQuery plug-in that provides a native UI feel to iPhone-based web apps.http://jqtouch.com/ o M-Project (http://the-m-project.net/): framework to build mobile apps using HTML5 JavaScript, and JQuery that run on the iPhone, Android devices and many others.http://the-m-project.net/ Sencha and Sencha Touch (http://www.sencha.com/): mobile builder for apps that feel native on iPhone, Android, and Blackberry, and other touch deviceshttp://www.sencha.com/ Titanium (http://www.appcelerator.com/products/ ): JavaScript interface that translates into mobile applications, which will perform just as if you had written them in Objective-C or Java.http://www.appcelerator.com/products/

16 Mobile Frameworks (cont.) Phonegap (http://phonegap.com/) : Platform allowing native application development in HTML/JavaScript for APIs and app store accesshttp://phonegap.com/ Appmobi (http://www.appmobi.com/): Cross platform JavaScript bridge that allows apps access to device APIs on iOS and Android platformshttp://www.appmobi.com/ NimbleKit (http://nimblekit.com ): Framework that allows development for Apple iOS devices using HTML and JavaScripthttp://nimblekit.com XUI (http://xuijs.com/) M icro DOM library for HTML5 mobile web applications. Compatible with WebKit-based mobile browsershttp://xuijs.com/ WebApp (http://webapp-net.com) light weight JavaScript framework with a full set components for advanced mobile applications.http://webapp-net.com iUI (http://code.google.com/p/iui): JavaScript library, CSS, and images for advanced mobile web appshttp://code.google.com/p/iui YUI (http://yuilibrary.com/) Yahoo developed framework with a large user base developing interactive Web applications.http://yuilibrary.com/

17 JavaScript and other tools Leading edge JavaScript Features – Record, detect orientation, device vibration, sense gestures, etc. – ARIA standards: Accessible rich internet application – Transform features – Drag and Drop HTML templates (https://github.com/janl/mustache.js/) for eliminating embedded HTML in JavaScripthttps://github.com/janl/mustache.js/ CSS Reset (http://www.cssreset.com/)http://www.cssreset.com/ – Initialize presentation parameters for cross browser compatibility NodeJs (http://nodejs.org/): Server side JavaScripthttp://nodejs.org/

18 First Presentation Topics 1.One of the top five JavaScript libraries. Research how it works and how it is applicable to mobile development. 2.One of the JavaScript frameworks. Research how it works, the development environment, and how it is applicable to mobile development Requirements 1.Clear description including an overview plus examples. 2.Short demo of a program using the technology 3.Audience: Understand computer terminology, html, and JavaScript but not this particular topic 4.Turn in your PowerPoint slides and a five to eight page well-written summary of the topic 5.Each team member must participate in the presentation


Download ppt "Mobile Applications Industry is in a state of competitive flux not seen since the days when mini-computer manufacturers first flooded the market – There."

Similar presentations


Ads by Google