data:image/s3,"s3://crabby-images/9ce7a/9ce7a442457b49a3fc72a46a29a4597aad7d5c15" alt=""
data:image/s3,"s3://crabby-images/d8702/d870261add498812da5369cb4e80275b052bb6cd" alt=""
Abhiram Ravikumar
OUTLINE
- Architecture
- Web apps Development
- App Validation
- Simulator Testing
- Publishing Apps
- Game Dev Intro
- Find your field
THE ARCHITECTURE
data:image/s3,"s3://crabby-images/89c3e/89c3e7d7ad4ec0ead4e4f8f3a8d3601a5d51d6b2" alt=""
Mozilla Developer Network
data:image/s3,"s3://crabby-images/a6a2c/a6a2c570954e2fa70654567a7c5d52177d0b7dfb" alt=""
- Web apps are apps built using standard Web technologies.
They work in any modern Web browser, and can be developed
using your favorite tools.
- The Open Web apps project proposes some small additions to existing sites to turn them into apps that run in a rich, fun, and
powerful computing environment.
- These apps run on desktop browsers and mobile devices, and are easier for a user to discover and launch than Web sites.
for Web developers
- Create the app manifest.
- Serve the manifest with .webapp
- Appify the code.
- Validate the markup.
- Simulate the tarball.
- You're DONE!
YES! YOU CAN !
- Reuse any existing web site/app or develop from scratch with
open web standards.
- Utilize HTML5 features such as localStorage, offline manifest,
IndexedDB and access Web APIs for more options.
- Responsive web design for adapting to varying resolutions and screen orientation.
START WITH THE MANIFEST
<ONCE THE CODE IS READY>
{
"name": "My App",
"description": "My elevator pitch goes here",
"launch_path": "/",
"icons": {
"128": "/img/icon-128.png"
},
"developer": {
"name": "Your name or organization",
"url": "http://your-homepage-here.org"
},
"default_locale": "en"
}
MANIFEST REFERENCE
deep dive
into
"" API ""
data:image/s3,"s3://crabby-images/318d0/318d093de9022e906cecc0c934621cbadb76be03" alt=""
// Telephony object
var tel = navigator.mozTelephony;
// Check if the phone is muted (read/write property)
console.log(tel.muted);
// Check if the speaker is enabled (read/write property)
console.log(tel.speakerEnabled);
// Place a call
var cal = tel.dial(“123456789”);
data:image/s3,"s3://crabby-images/ac5fb/ac5fb2caa36baaa7dfd4ec1d86f813b50743328e" alt=""
// SMS object
var sms = navigator.mozSMS;
// Send a message
sms.send("123456789", "Hello");
// Recieve a message
sms.onreceived = function (event) {
// Read message
console.log(event.message);
};
data:image/s3,"s3://crabby-images/ed693/ed69339937a65e80af2b0c98767ab99c16788224" alt=""
// Vibrate for one second
navigator.vibrate(1000);
// Vibration pattern [vibrationTime, pause,…]
navigator.vibrate([200, 100, 200, 100]);
// Vibrate for 5 seconds
navigator.vibrate(5000);
// Turn off vibration
navigator.vibrate(0);
data:image/s3,"s3://crabby-images/42cf0/42cf0a3447014f53b64979be4e6c388e7d19de49" alt=""
var contact = new contact();
contact.init({name: "Tom"});
var request = navigator.contacts.save(contact);
request.onsuccess = function() {
console.log("Success");
request.onerror = function() {
console.log("Error")
data:image/s3,"s3://crabby-images/f05e7/f05e7b8053d12485f744f89e8bdc2164d625eb04" alt=""
// Portrait mode:
screen.mozLockOrientation("portrait");
/*
Possible values:
"landscape"
"portrait"
"landscape-primary"
"landscape-secondary"
"portrait-primary"
"portrait-secondary"
*/
data:image/s3,"s3://crabby-images/91345/9134567a08e597f6775f1d858c922249d5e1f19d" alt=""
var connection = window.navigator.mozConnection,
online = connection.bandwidth > 0,
metered = connectrion.metered;
data:image/s3,"s3://crabby-images/09ecc/09eccd914eac9664cfd499e2a2bc2a73ca8ae9eb" alt=""
data:image/s3,"s3://crabby-images/2c2c1/2c2c180e8d7051823e39e7feac6f25d9047e34ef" alt=""
data:image/s3,"s3://crabby-images/1704d/1704d04ccff4d35a67dd9a38b378097ecae53231" alt=""
data:image/s3,"s3://crabby-images/a9b56/a9b56c1e670ba61afdd82ef21232d2b44b22129f" alt=""
data:image/s3,"s3://crabby-images/4dc6a/4dc6a88c5636af0182adfd44fdaf7983254648e5" alt=""
Ctrl + Shift + M
data:image/s3,"s3://crabby-images/0894b/0894b9dd7938227dcc2f4a1e83226a0090258ba1" alt=""
data:image/s3,"s3://crabby-images/271bf/271bf8338ba46a5f62196f83b43d6508db16f488" alt=""
LET'S
SIMULATE IT
data:image/s3,"s3://crabby-images/8f875/8f875b0c25f68a747c83f0d9c93aa88a944dd175" alt="App Manager - games"
Simulator does not simulate the hardware limitations
functionality
- Push to Device.
- Rotation simulation.
- Basic geolocation API simulation.
- Manifest validation.
- Stability fixes for installation and updates to apps.
- Newer versions of the Firefox rendering engine
- Updated Gaia (the UI for Firefox OS).
REFERENCES
Essential Components
Marketplace Intro
https://marketplace.firefox.com/developers/
Game Dev
https://marketplace.firefox.com/developers/docs/game_apps
Design your icon!
https://www.mozilla.org/en-US/styleguide/products/firefox-os/icons/
UPLOAD YOUR APP :D
queries?
Twitter handle
@MozillaIN
#FirefoxOSAppDays
MozNet IRC (irc.mozilla.org)
#openwebapps
#b2g
THANK YOU!
PES Institute of Technology, Bangalore South Campus
Facebook :fb.com/FirefoxClubPESITSOUTH
CREDITS
BootCampMozilla
By Abhiram Ravikumar
BootCampMozilla
These are the slides made for the event Mozilla Boot Camp at PESIT, Bangalore South.
- 2,240