460 likes | 625 Views
webapps. Medien zwischen technologie und gesellschaft Prof. Dr. manfred Thaller Jonas Schophaus | Uni Köln | WS 2012. Agenda. Native versus webbasierte Apps HTML5 & CSS3 Media Queries Geolocation Offline Data Storage WebKit Animations jQuery Mobile WebApps nativ.
E N D
webapps Medien zwischen technologie und gesellschaft Prof. Dr. manfred Thaller Jonas Schophaus | Uni Köln | WS 2012
Agenda • Native versus webbasierte Apps • HTML5 & CSS3 • Media Queries • Geolocation • Offline Data Storage • WebKitAnimations • jQuery Mobile • WebApps nativ
Webapps vs. Native apps AlternatiVE?
Darum webapps • Keine Installation. • Keine Updates. • Ein Produkt, alle Plattformen!
Technologien Webbasierte App Native App Objective C Java Visual C++ ... • HTML5 • CSS3 • JavaScript ...
Technologien Webbasierte App Native App (WebKit) Eine Codebase bedient 97% aller mobilen Endgeräte. Mehrere Codebases, geringerer Gesamtanteil. Quelle: Franke/Ippen: Apps mit HTML5 und CSS3. Bonn 2012.
Nachteile gegenüber nativen Apps • Eingeschränkter Zugriff auf Hardware. • Schlechtere Performance. • Keine OS-integrierten Funktionen: Ausführen im Hintergrund, Notifications etc. • Möglicherweise schwerer zu vermarkten als Apps in zentralisierten AppStores.
Checkliste • Zugriff auf geschütze Hardwarekomponenten? Kamera, Mikrofon... • Geschwindigkeit/Performance? Grafik, Hardwarebeschleunigung • Offline-Funktionalitäten? • Target Devices? • Kenntnisse in relevanten Programmiersprachen? • Monetarisierung
Web(App) Technologies HTML5 & CSS3
Responsive Webdesign • Styling angepasst an Ausgabegerät.
CSS3: Media Queries Unterschiedliche Stylesheets für unterschiedliche Bildschirmgrößen.
CSS3: Media Queries Unterschiedliche Stylesheets für unterschiedliche Bildschirmausrichtungen.
CSS3: Media Queries Media Queries sind auch im Link-Tag in HTML möglich.
CSS3: MEDIA QUERIES • weitere Medienmerkmale: • aspect-ratio • color(Farbtiefe in Bit) • monochrome (Graustufen in Bit) • resolution (dpi)
Geolocation mit html5 • navigator.geolocationermöglicht Positionsbestimmung über JavaScript.
Geolocation mit Html5 • Bewegungen tracken mit geolocation.watchPosition.
Geolocation mit Html5 • Eigenschaften des position-Objekts: • position.coords.accuracy(Radius in Metern) • position.coords.altitude(Meter über NN) • position.coords.altitudeAccuracy • position.coords.heading(Winkel zu N) • position.coords.speed
WebkitTransitions • Bestimmen Länge und Art und Weise der Änderung von Elementeigenschaften.
Webkit Transition • Transition Styles: • ease-in: Animation startet langsam • ease-out: Animation wird am Ende abgebremst • ease-in-out: Kombination • linear: Animation verläuft gleichmäßig • Änderung der Eigenschaft (durch DOM-Manipulation) löst Animation aus.
Webkit Animation • Erweiterung von webkittransition, mit der Möglichkeit Keyframes zu setzen.
Offline, und jetzt? • Das Cache-Manifest: • Liste mit Dateien, die offline vorgehalten werden sollen. • Max. 5 MB. • Das localStorage-Objekt: • Persistente Speicherung von Key:Value-Paaren auf dem Gerät.
HTML5: Das Cache-Manifest • Sichert Offline-Funktionalität. • Weitere Vorteile: • Geschwindigkeit. • Server-Auslastung minimieren. • Struktur: • CACHE: nach dem ersten Laden • NETWORK: unter allen Umständen vom Server • FALLBACK: wenn Ressource nicht verfügbar ist
HTML5: Das Cache-Manifest Beispielmanifest.
HTML5: Das Cache-Manifest • Einbindung in HTML-Dokument: • AppCache-Objekt: • window.applicationCache
html5: localstorage • Persistente Speicherung auf dem Gerät. • Alternative zu Datenbank auf Webserver (MySQL & Co). • Key:Value-Paare. • localStorage.setItem(key, value); • localStorage.getItem(key); • localStorage.removeItem(key); • localStorage.clear(); • Analog dazu: sessionStorage.
Webapp Frameworks jQuery Mobile
jQuery • Framework/Klassenbibliothek für JavaScript. • Erhebliche Erleichterung von: • Elementselektion (ähnlich CSS) • DOM-Manipulation • Realisation von Effekten und Animationen • AJAX Requests • Download: http://code.jquery.com/jquery-latest.min.js
jQuery Syntax • Codebeispiel: An alle h1-Elemente einen Button anhängen. • Wie von CSS gewohnt funktionieren auch:
Jquery Events • EventHandler hinzufügen mit ‚on‘: • Unterstützte Events: • dblclick, hover, mousemove, mousedown, mouseupetc.
HTML-Elemente manipulieren • Ein- und Ausblenden von Elementen: • .hide() • .show() • .toggle() • Animiertes Ein- und Ausblenden: • .slideToggle() .fadeIn() • .slideUp() .fadeOut() • .slideDown() .fadeToggle()
HTML-Elemente manipulieren • Attribut-Funktionen: • .attr({name,wert}) • .addClass(name) • .removeClass(name) • .toggleClass(name) • DOM-Maniupulation: • .prepend(code) - HTML am Anfang des Tags einfügen • .append(code) - HTML am Ende des Tags einfügen
AJAX Requests • Daten von Webservern im JSON-Format laden:
jQuery Mobile • Interface Framework. • Passend zu sämtlichen nativen UIs und Gerätegrößen. • Handling von Navigation und Animation. • Einbindung von Stylesheet und jQMobile-Library:
Jquery Mobile • Definition von App-Views als Div-Container mittels data-role-Attribut: • Div-Block für eine einzelne Seite.
Jquery Mobile Beispiel einer mit jQuery mobile erstellten App
Jquery Mobile: Interface Elemente • Header & Footer: • Navbar im Footer:
Jquery Mobile: Interface Elemente jQm-Standard-Icons
Jquery Mobile: Interface Elemente • Header mit Back-Button: • Button mit href="index.html" • Liste:
WebApps im Appstore? Phone gap
Phone Gap • Open-Source-Framework. • Wandelt HTML+JavaScript-basierteWebapp in native App um (verschiedene Plattformen). • Ermöglicht einfachen Zugriff auf Kamera und Mikrofon.
Phone Gap: Native BuilD • PhoneGap.js einbinden • PhoneGap Paket für die jeweilige Entwicklungsumgebung installieren • Alternativ: Phone Gap Build
Phone Gap: kamera • Zugriff auf Kamera über navigator.camera-Objekt:
Apple Homescreen Optimierung • <metaname="apple-mobile-web-app-capable" content="yes"/> • im head ermöglicht das Verknüpfen der Website mit einem Home-Screen Icon auf iOS-Geräten. • Setzen des Icons: • <link rel=„apple-touch-icon“ href=„img/iphone-icon.png“/>
Apple Homescreen Optimierung • Weitere Optionen: • StatusBar: • <metaname=„apple-mobile-web-app-status-bar-style“ content=„black“>, möglich sind: default, black, translucent • Splash-Screen: • <link rel=„apple-touch-startup-image href=„img.png“>