Texto Tema 6 Desarrollo de aplicaciones web para móviles Texto Parte I: Introducción. HTML y CSS para webs móviles 1 1 ¿Qué tienen de especial los dispositivos móviles... ...con respecto a los equipos “de escritorio”? Desarrollo de aplicaciones web para móviles 2 Dispositivos móviles Mercado muy heterogéneo Móviles “convencionales” (gama baja-media-alta) Smartphones: iPhone, Android, algunos Nokia Otros dispositivos: tablets, ebooks Nos vamos a centrar en smartphones, por cuestiones de tiempo y espacio Sobre todo Android e iOS, aunque también haya Windows Phone Esto no quiere decir que los demás dispositivos no sean importantes en el mundo real HTML y CSS para webs móviles 3 La pantalla Lo más inmediato, la pantalla La resolución varía de 240x320 (gama baja) a 1080x1920 (Samsung Galaxy S4), siendo la media de 320x480 (HVGA o Half-VGA) o más Además hay que tener en cuenta los DPI Aunque la resolución sea alta no podemos colocar demasiada información ya que la pantalla es físicamente muy pequeña Y más alta que ancha, al contrario que en el escritorio. Es incómodo hacer scroll horizontal, por lo que la información tiende a colocarse en una columna HTML y CSS para webs móviles 4 La pantalla http://developer.android.com/about/dashboards/index.html HTML y CSS para webs móviles 5 Dispositivos de entrada Introducir datos en un móvil es incómodo y tedioso. La aplicación debe reducir esta necesidad al mínimo imprescindible Hay que tener en cuenta las características del dispositivo de entrada Los controles táctiles tienen que ser grandes, para poder ser pulsados con el dedo. No así si se usa un stylus HTML y CSS para webs móviles 6 Otros elementos Capacidad de procesamiento Ciertos APIs no tienen todavía suficiente rendimiento para los móviles (WebGL, canvas,...) Batería Javascript gasta batería, motivo por el que la mayoría de navegadores móviles paran su ejecución en las pestañas en segundo plano También ciertos APIs gastan mucha batería por el hardware que usan “por debajo” (ej. geolocalización) HTML y CSS para webs móviles 7 Recomendaciones para la interfaz de usuario Apple Human Interface Guidelines for Web Applications Android Guidelines for Web Apps http://developer.android.com/guide/ webapps/index.html Recomendaciones del W3C para la web móvil Versión resumida en castellano en http:// www.w3c.es/Divulgacion/Tarjetas/MWBP/ Windows Phone design library (no es para apps. web, pero da una idea del estilo) http://dev.windowsphone.com/en-us/design/ library HTML y CSS para webs móviles 8 2 Plataformas de programación de aplicaciones para móviles Aplicaciones nativas vs. web vs. “híbridas” Desarrollo de aplicaciones web móviles 9 Programar aplicaciones para móviles HTML y CSS para webs móviles Opción 1: Aplicaciones “nativas” Aplicaciones del SO del móvil. Por ejemplo Android: desarrollo en Java, con APIs propios del sistema iOS: Objective-C, librerías Cocoa Touch Windows Phone: .NET (p.ej. C#/XAML) Runtimes: capas por encima del SO, permiten una mayor portabilidad JavaME: el runtime más difundido del mundo...pero con futuro nulo. Carente de soporte táctil estándar y de actualizaciones Opción 2: Aplicaciones web Sitios web convencionales usando Javascript+HTML+CSS. Hay una serie de “trucos” para que parezcan apps. nativas Pueden funcionar offline (gracias a la cache de HTML5) Pueden ir a pantalla completa, sin la barra de direcciones Pueden tener un icono en el escritorio 10 Ventajas aplicaciones web HTML y CSS para webs móviles No es necesario aprender APIs propios del dispositivo, ni nuevos lenguajes de programación La aplicación es fácil de distribuir y actualizar a la nueva versión La instalación solo requiere una visita al sitio web. La actualización es automática usando cache de HTML5 No hay barreras artificiales a la distribución (ej. App Store de Apple) Es portable entre todos los dispositivos independiendemente del SO 11 Problemas aplicaciones web HTML y CSS para webs móviles Por cuestiones de rendimiento, no son apropiadas para algunos tipos de aplicaciones (juegos con gráficos intensivos, multimedia, …) Es difícil darle a la interfaz el “look” propio de la plataforma Aunque hay frameworks que solventan en parte el problema No son accesibles todas las capacidades del dispositivo Algunos APIs todavía no están estandarizados (radio FM), o bien no están implementados en móviles (por ejemplo el Media Capture API que vimos en escritorio) Es más complicado obtener un provecho económico Las aplicaciones web no se pueden distribuir directamente en la App Store o en el Android Market, por ejemplo. 12 Aplicaciones “híbridas” HTML y CSS para webs móviles Últimamente han surgido herramientas que permiten desarrollar aplicaciones web con ciertas ventajas de las nativas Por ejemplo acceso a ciertos APIs con Javascript: sonido, vibración, acelerómetro, … El “truco” consiste en que se genera una aplicación nativa pero que es una ventana del navegador Ejemplo: http://www.phonegap.com 13 Frameworks para móviles HTML y CSS para webs móviles Estilos CSS + librerías Javascript que implementan: Widgets adaptados a móviles (algunos incluso imitando el “look&feel” de alguna plataforma) Navegación entre “pantallas” Eventos de tipo táctil (swipe, tap, ...) jQuery Mobile jquerymobile.com jQT jqtjs.com lungojs lungo.tapquo.com 14 Otras ayudas HTML y CSS para webs móviles Librerías Javascript adaptadas a móviles zepto.js es una librería con un API compatible con el de jQuery pero mucho más ligera Plantillas HTML+CSS mobile boilerplate incluye estilos por defecto (CSS reset), scripts de ayuda (eliminar barra de navegación, ...), librerías útiles (zepto.js) y un esqueleto HTML5 básico adaptado a móviles 15 El “caso Facebook” HTML y CSS para webs móviles Facebook “apostó” por aplicaciones móviles basadas en HTML5... Pero el rendimiento no fue el esperado...y tuvieron que pasarse a apps nativas (http://es.engadget.com/2012/09/11/facebook-aplicacionhtml5-error/) No obstante, los desarrolladores de Sencha Touch (un framework javascript) consiguieron implementar una versión HTML5 mucho más eficiente que la original (http://www.sencha.com/blog/the-making-offastbook-an-html5-love-story) 16 3 Navegadores en dispositivos móviles Desarrollo de aplicaciones web móviles 17 Navegadores “del sistema” iOS: Safari on iOS (antes Mobile Safari) Durante mucho tiempo fue el navegador móvil más avanzado en términos de compatibilidad con HTML5 Introdujo muchas características no estándares luego copiadas por otros navegadores móviles Android “navegador por defecto” Chrome para Android, muy similar al de escritorio, mucho mejor soporte de HTML5 HTML y CSS para webs móviles 18 Otros navegadores HTML y CSS para webs móviles Explorer (IE10 en WP8, IE9 en WP7.5) Opera Mobile, Firefox, Dolphin, Amazon Silk (Kindle Fire)... Recursos para comprobar la compatibilidad caniuse.com mobilehtml5.org Tests de compatibilidad RingMark: www.rng.io, énfasis en móviles acid3.acidtests.org html5test.com 19 4 HTML5 para móviles Desarrollo de aplicaciones web móviles 20 Estándares de marcado en móviles HTML y CSS para webs móviles Existen diferentes variantes de HTML y CSS apropiadas para móviles XHTML Basic (subconjunto de XHTML) y CSS MP (del W3C) XHTML MP (Mobile Profile, ampliación de XHTML Basic) y WAP CSS (de la OMA-Open Mobile Alliance) Nosotros usaremos aquí HTML5 https://en.wikipedia.org/wiki/XHTML_Mobile_Profile 21 El viewport HTML y CSS para webs móviles 22 Aunque la resolución real de la pantalla sea baja, el dispositivo va a “simular” que tiene una distinta Por ejemplo el iPhone original tiene 320px de ancho, pero “simula” que tiene 980px Esto se hace para que las webs no diseñadas para móviles aparezcan como en el escritorio (y no “cortadas” en vertical) Terminología: Initial viewport o device viewport: la resolución real Current viewport o layout viewport: el “imaginario” o “simulado” (pero en cierto modo el real desde el punto de vista p.ej. de medidas en CSS) http://developer.apple.com/library/ios/#documentation/ AppleApplications/Reference/SafariWebContent/ UsingtheViewport/UsingtheViewport.html Controlar el viewport HTML y CSS para webs móviles Etiqueta <meta> en la cabecera <meta name=”viewport” content=”{propiedades}”> ! ! ! <!-- ‘user-scalable=no’ significa que no se puede hacer zoom. Esto es raro en la web, pero habitual en una app nativa --> <meta name="viewport" content="width=320,user-scalable=no"> ! <!-- teóricamente ‘device-width’ es la resolución horizontal del dispositivo --> <meta name=”viewport” content=”width=device-width”> ! En realidad, muchos dispositivos con resolución mayor de 320px aún así dan 320 como device-width Esto se hace para simplificar la vida del desarrollador, y que solo tenga en cuenta un tamaño de pantalla 23 Formularios en HTML5 HTML y CSS para webs móviles Recordar que en HTML5 se pueden usar type="email", type="number", type="url", type="tel", type=”range”, type=”date”,.... Se mostrará un teclado virtual adaptado En campos tipo fecha, se usará el selector de fechas “nativo” Teclado virtual para type=”url” en iOS Atributo placeholder para poner un texto de ejemplo dentro del campo Útil aquí por ahorrar espacio <input type="text" name="login" placeholder="usuario..."> <br> <input type="text" name="password" placeholder="contraseña..."> Selector de fechas en iOS 24 Validación HTML5 HTML y CSS para webs móviles Aunque las versiones modernas de Android e iOS admiten atributos como required, min, max,... en general estos no impedirán automáticamente el envío del formulario !<form action="prueba.php"> <!-- aunque no rellenemos este campo, se enviará el formulario igualmente --> ! <input type="text" id="nombre" required><br> <input type="submit"> !</form> No obstante, hay métodos javascript que nos facilitan la validación (HTML5 constraint validation API) <form action="prueba.php" onsubmit=”return this.checkValidity()”> ... </form> if (document.getElementById("nombre").validity.valueMissing) alert("Valor requerido!!") 25 Subir archivos HTML y CSS para webs móviles Como sabemos, para subir un archivo al servidor hay que usar un <input type=”file”> Hasta iOS 6/Android 2.2 este tipo de campo no funcionaba En iOS sigue siendo imposible subir algo que no sea audio/video Se puede especificar el tipo MIME aceptable con accept ! ! <input type="file" accept="application/pdf"> <input type="file" accept="image/jpeg"> <!-- cualquier tipo de imagen --> <input type="file" accept="image/*"> <!-- cualquier tipo de video --> <input type="file" accept="video/*"> HTML Media Capture: el atributo capture especifica que queremos tomar los datos de cámara/micrófono ! <input type="file" accept="image/*" capture> <input type="file" accept="video/*" capture> <input type="file" accept="audio/*" capture> ! iOS ignora este atributo pero “a cambio” cuando se usa accept da la opción de usar cámara/micro además de subir un archivo 26 Formularios: usabilidad HTML y CSS para webs móviles Usar <label> Evitamos que p.ej. haya que tocar directamente sobre un checkbox para seleccionarlo ! ! <input type="checkbox" name="ok" id="aceptar" > <br> <label for="aceptar"> Acepto las condiciones de uso y términos del servicio </label> ! Se recomienda poner el <label> encima/debajo del campo (para mantener diseño en 1 columna) En campos de texto, en lugar de <label>, usar atributo placeholder ¿Es necesario el type=”password”? 27 “Trucos” para que la app parezca algo más nativa HTML y CSS para webs móviles Icono en el escritorio ! ! <!-- solo iOS, el sistema le añade ciertos efectos visuales (brillo, ...)--> <link rel="apple-touch-icon" href="icono.png" /> <!-- iOS y Android --> <link rel="apple-touch-icon-precomposed" href="icono.png" /> ! Problema: el usuario debe añadir manualmente el “favorito” (p.ej en Android: tecla menú > Más > Añadir acceso directo) Eliminar barra de URL Truco: hacer scroll a y=1 pixel para forzar que la barra se oculte (window.scrollTo(0,1) en javascript al cargar la página) En iOS hay etiquetas meta para esto y para controlar el aspecto de la barra de status (donde se muestra hora, batería, señal, ...) 28 5 CSS para móviles Desarrollo de aplicaciones web móviles 29 CSS media queries HTML y CSS para webs móviles Parte del estándar CSS3, nos permite aplicar un CSS si se cumplen ciertas condiciones <!-- vincular con una u otra hoja de estilo dependiendo de la resolución horizontal --> <link type="text/css" rel="stylesheet" media="screen and (max-device-width:480px)" href="smartphone.css" /> <link type="text/css" rel="stylesheet" media="screen and (min-device-width:481px)" href="desktop.css" /> ! <!-- también se puede poner en el CSS “empotrado” en el HTML --> <style> @media screen and (max-device-width:480px) { body { background-color: red; } } </style> 30 Sintaxis de media queries HTML y CSS para webs móviles Expresiones: min- (>=). p.ej. min-device-width:640px max- (<=). p.ej. max-device-width:640px : (==). p.ej. device-width:640px Operadores: not, and, or, only (only screen serían dispositivos que solo soportan media=”screen”, típicamente móviles) Algunas características comprobables device-width, device-height: medidas del dispositivo width, height: medidas del viewport orientation (puede ser landscape o portrait) resolution (típicamente en dpi) aspect-ratio, device-aspect-ratio 31 “Retina” Web HTML y CSS para webs móviles “Tipos” de pixels: Device pixels: los del hardware CSS pixels: los que se usan en las reglas CSS Como hemos visto, un dispositivo puede reportar que tiene 320 px de ancho (CSS pixels) cuando en realidad podría tener 640 window.devicePixelRatio: ¿Cuántos píxeles reales es 1 pixel CSS? Podemos usar esta información para servir imágenes de “alta resolución” vs. “resolución estándar” 32 “Retina” Web HTML y CSS para webs móviles Usamos una imagen u otra dependiendo del “device pixel ratio”, pero ambas escaladas al mismo tamaño en píxeles CSS http://www.smashingmagazine.com/2012/08/20/towards-retinaweb/ .icon { background-image: url(example.png); background-size: 200px 300px; height: 300px; width: 200px; } ! @media only screen and (-Webkit-min-device-pixel-ratio: 1.5), only screen and (-moz-min-device-pixel-ratio: 1.5), only screen and (-o-min-device-pixel-ratio: 3/2), only screen and (min-device-pixel-ratio: 1.5) { .icon { background-image: url(example@2x.png); } } 33 Referencias Los “fabricantes” suelen tener sitios web para desarrolladores con documentación, ejemplos, simuladores, etc. En general developer.xxx.com, por ejemplo http:// developer.nokia.com , http://developer.samsung.com http:// developer.android.com http://proquestcombo.safaribooksonline.com/ (solo desde la UA) ! Programming the mobile web, 2nd ed, O’Reilly 2013 ! ! Build Mobile Websites and Apps for Smart Devices, Ed. SitePoint, 2011 ! Building iPhone Apps with HTML, CSS and Javascript y Building Android Apps with HTML, CSS and Javascript HTML y CSS para webs móviles 34