Skip to content
Christian Gastrell edited this page Jun 16, 2015 · 13 revisions

Revision

Empezamos por la vista de revision porque pienso que nos va a dar una base mas solida de cuales son las necesidades por sobre el modelo de datos y el procesamiento.

Estructura

Para desarrollar la interfaz vamos a empezar con una estructura basica de HTML. Teoricamente este HTML deberia cubrir las necesidades de la interfaz de reproduccion:

<div>
  <button>Pausa</button>
  <button>Play</button>
  <button>Stop</button>
  <button>Rew 10'</button>
  <span>07:41</span>
</div>
<input type="checkbox" disabled name="check1" value="1" /> Preséntese y cuénteme por qué quiere hacer el curso de Phonegap
<button>Go!</button>
<br />
<input type="checkbox" disabled name="check2" value="2" /> Nombre
<button>Go!</button>
<button>Go!</button>
<br />
<input type="checkbox" disabled name="check3" value="3" /> Edad
<button>Go!</button>
<br />
<input type="checkbox" disabled name="check4" value="4" /> Conocimientos previos
<br />
<input type="checkbox" disabled name="check5" value="5" /> Experiencia en mobile
<br />
<input type="checkbox" disabled name="check6" value="6" /> Experiencia general
<br />

Varias cosas podrian estar mejor:

  • los checkbox nos podrian complicar la vida. El funcionamiento implicito del checkbox es de tipo switch o toggle
  • para reemplazar la funcionalidad del checkbox podriamos usar un boton antepuesto al texto de la pregunta
  • vamos a querer, eventualmente, poder interactuar con la lista de respuestas, asi que deberiamos encerrarlas en otro <div> que podamos identificar
  • cada una de las respuestas va a ocupar una linea, entonces tambien podemos encerrarlas en un <div> y remover los <br />
<div>
  <button>Grabar</button>
  <button>Pausa</button>
  <button>Play</button>
  <button>Rew 10'</button>
  <span>07:41</span>
</div>
<div id="respuestas">
  <div>
    <button>+</button>
    Preséntese y cuénteme por qué quiere hacer el curso de Phonegap
  </div>
  <div>
    <button>+</button>
    Nombre
  </div>
  <div>
    <button>+</button>
    Edad
  </div>
  <div>
    <button>+</button>
    Conocimientos previos
  </div>
  <div>
    <button>+</button>
    Experiencia en mobile
  </div>
  <div>
    <button>+</button>
    Experiencia general
  </div>
</div>

Vamos a tomar este HTML y lo vamos a probar en un proyecto nuevo. El proyecto lo vamos a probar con jQuery Mobile:

phonegap create irec --id com.codenautas.interviewrecorder --name "00 Prueba iRec" -src templates\jqm

Editamos el archivo www/index.html y vamos a pegar el HTML dentro del <div data-role="content"> (reemplacen todo el contenido).

Por el momento no necesitamos correr esto en el dispositivo. Abramos el archivo www/index.html en el browser y veamos como se ve. Spoiler alert: horrible.

Remover (temporalmente) estilos de jQuery Mobile

Para poder trabajar primero en la estructura vamos a sacar los estilos de jQuery Mobile. Para esto solo hay que localizar la linea donde se incorpora el CSS y comentarla (o hacer que falle cambiando el nombre):

<link rel="stylesheet" type="text/css" href="css/jquery.mobile-1.4.5.min.css" />

Comentada:

<!-- <link rel="stylesheet" type="text/css" href="csss/jquery.mobile-1.4.5.min.css" /> -->

Actualizamos la pagina en el browser y vemos el HTML sin estilos. Igual se ve feo, pero por el momento sirve.

Ahora bien, el listado de preguntas deberia salir de algun modelo de datos, algo sobre lo que podamos iterar para no tener que generar cada entrada a mano.

A continuacion evaluaremos los modelos de datos de la entrevista y una revision de ejemplo

  1. Repaso y conceptos basicos
  2. Ejercicios para repasar
  3. Problematica de desarrollo mobile
  4. Phonegap
  5. Requerimientos e instalacion
  6. Phonegap CLI
  7. [Primeros ejercicios con Phonegap](Ejercicio Phonegap)
  8. Plugins
  9. Hello world
  10. Estructura de un proyecto Phonegap
  11. Plugin Device
  12. Debugging
  13. Incorporando un framework CSS
  14. Plugin Vibration
  15. Sumando partes
  16. Plugin Battery Status
  17. Un poco de jQuery
  18. jQuery Mobile
  19. Navegacion
  20. Plugin Dashboard
  21. Revision de Plugin Dashboard
  22. Paginas extra
  23. ToDo
  24. Persistencia
  25. ToDo Persistente
  26. Plugin Camera
  27. Opciones de camara
  28. App Mi Galeria
  29. Revision de Galeria
  30. Plugin File
  31. Escribir y leer texto
  32. Escribir archivos binarios
  33. Guardando fotos
  34. Debugger: weinre
  35. Inspeccionar con weinre
  36. Phonegap Developer App
  37. Refactor de apps
  38. Plugin Media
  39. Pruebas con audio
  40. Control y monitoreo de audio
  41. Encapsular play/pausa
  42. Hacks
  43. Formato de tiempos
  44. Grabar y reproducir
  45. Proyecto Integrador
  46. Revision de interfaz
  47. Interfaz basica
  48. Entrevista: modelo
  49. Funcionalidad: revision
  50. Seleccion de framework
  51. iRec: navegacion
  52. iRec: fileApi
  53. iRec: guias
  54. iRec: entrevistas
  55. iRec: recordApi
  56. iRec: helpers
  57. iRec: mediaApi
  58. iRec: inicializar paginas
  59. iRec: refactor
  60. iRec: mediaApi refactor
  61. iRec: recordApi refactor
  62. iRec: helpers
  63. iRec: guias.js
  64. iRec: entrevistas.js
  65. iRec: crear guias
  66. iRec: re-inicializando
  67. iRec: re-ordenando
  68. iRec: pendientes
  69. iRec: reporte ux
  70. iRec:revision: volver
  71. iRec:entrevista: volver
  72. iRec:revision: cambios
  73. iRec:revision: stop
  74. iRec:revision: Rew 10"
  75. iRec:revision: tag Go
  76. iRec: limpieza
  77. Firma de apps
  78. Android
  79. Generacion de key
  80. Firma de apk
  81. Alineacion de zip
  82. Firmar con Phonegap
  83. iOS
  84. Detalles finales
  85. Config.xml
  86. Iconos
  87. Splash
Clone this wiki locally