<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Jon Segador &#187; aplicación</title>
	<atom:link href="http://jonsegador.com/tag/aplicacion/feed/" rel="self" type="application/rss+xml" />
	<link>http://jonsegador.com</link>
	<description>Desarrollador web y android, con todo lo que ello implica</description>
	<lastBuildDate>Mon, 23 Jan 2012 19:24:37 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Me han suspendido la aplicación de Cercanías Renfe para Android</title>
		<link>http://jonsegador.com/2012/01/me-han-suspendido-la-aplicacion-de-cercanias-renfe-para-android/</link>
		<comments>http://jonsegador.com/2012/01/me-han-suspendido-la-aplicacion-de-cercanias-renfe-para-android/#comments</comments>
		<pubDate>Wed, 04 Jan 2012 15:03:09 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[General]]></category>
		<category><![CDATA[Opinión personal]]></category>
		<category><![CDATA[Proyectos propios]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[renfe]]></category>
		<category><![CDATA[suspendida]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=619</guid>
		<description><![CDATA[2 años, 100.730 instalaciones totales y 51.896 instalaciones activas. Eso es lo que ha durado mi aplicación de Cercanías Renfe para Android. Ayer, día 3 de enero, recibo un email de Google informándome de que &#8220;mi aplicación vulnera los derechos de propiedad industrial de RENFE-Operadora&#8221; y había sido suspendida. Concretamente por la utilización inconsentida de [...]]]></description>
			<content:encoded><![CDATA[<p><strong>2 años, 100.730 instalaciones totales y 51.896 instalaciones activas.</strong> Eso es lo que ha durado mi <a href="http://jonsegador.com/2010/01/horarios-de-trenes-de-cercanias-renfe-en-tu-movil-android/">aplicación de Cercanías Renfe para Android</a>.</p>
<p>Ayer, día 3 de enero, recibo un email de Google informándome de que &#8220;mi aplicación vulnera los derechos de propiedad industrial de RENFE-Operadora&#8221; y había sido suspendida. Concretamente por la utilización inconsentida de sus signos distintivos, lo que constituye un acto de competencia desleal.</p>
<p><strong>¿Competencia desleal?</strong> Es cierto que utilizo el logotipo de Cercanías como imagen de la aplicación, pero de ahí a ser competencia desleal&#8230; Como bien dijo <a href="http://twitter.com/#!/nacmartin/status/154304390474383360">@nacmartin</a> en Twitter: &#8220;Serías competencia si tuvieras tu propia red ferroviaria.&#8221;</p>
<p>El email que recibo proviene de Google pero, no sé si por error, puedo leer el mensaje que el abogado de Renfe (se le puede encontrar fácilmente en Linkedin) envía a Google y es ahí donde puedo leer lo de competencia desleal (ya que Google ni lo menciona). <strong>El mensaje que envía es un copy&#038;paste</strong> clarísimo, con tres párrafos donde se repite lo mismo con diferentes palabras.</p>
<p>No me gusta que <strong>Google haya suspendido la aplicación sin yo poder defenderme</strong> de ninguna manera. Si es por utilizar el logotipo de Cercanías, podría haber modificado la aplicación y subir otro logo, por ejemplo el de un tren parado en mitad de la vía (sería una buena representación de los trenes de Cercanías de Renfe).</p>
<p>No puedo modificar la aplicación ni tampoco realizar ninguna acción sobre ella: descargar el código, descripciones, etc.</p>
<p><a href="http://jonsegador.com/wp-content/renfe-android.png"><img src="http://jonsegador.com/wp-content/renfe-android.png" alt="" title="renfe-android" width="400" height="40" class="aligncenter size-medium wp-image-621" /></a></p>
<p>El mensaje del abogado se envió el 29 de diciembre de 2011 y el día 3 ya estaba suspendida. Bastante rápidos para lo que les interesa.</p>
<p>La decisión que he tomado es <strong>liberar el código y subir el apk de la aplicación a mi blog para su libre descarga</strong>. No tengo intención de seguir beneficiando a Renfe con la aplicación y además de manera gratuita (<strong>no he ganado un solo céntimo con la aplicación, era totalmente gratuita y sin publicidad</strong>). No dejaré de preocuparme por ella y la iré actualizando (se que existe alguna forma para que las actualizaciones se descarguen desde mi blog, como dice <a href="http://twitter.com/#!/biriru/status/154337908399149057">@biriru</a>)</p>
<p>Gracias a todos por los mensajes y las palabras de ánimo que me habéis dejado en Twitter, la verdad que me han desbordado y no puedo contestar a todos. <strong>¡GRACIAS!</strong></p>
<p>Aquí algunos twits que me han parecido interesantes:</p>
<p><strong>Santi Núñez</strong> <a href="http://twitter.com/#!/snunsan">@snunsan</a><br />
Incapaz de crear app mínimamte seria, @Renfe denuncia la app #Android de @jonseg por &#8220;compentencia desleal&#8221; y Google la suspende #hazteFan</p>
<p><strong>aurelio hernández</strong> <a href="http://twitter.com/#!/ahdezsanchez">@ahdezsanchez</a><br />
Renfe se supera. No solo tienen la web más vergonzosa que se recuerda, sino que hace que retiren apps independientes, como la de @jonseg</p>
<p><strong>Dani Rubio</strong> <a href="http://twitter.com/#!/vegaquark">@vegaquark</a><br />
@jonseg Suele pasar que las empresas que desconocen el terreno meten la pata&#8230; Es como los famosos en twitter&#8230;</p>
<p><strong>Rubén Hidalgo</strong> <a href="http://twitter.com/#!/rhidalgo">@rhidalgo</a><br />
@jonseg 100veces mas practica tu app,al final estas facilitando el uso a las personas que lo utilizamos,cansado de #renfe #renfelibreAndroid</p>
<p><strong>papakorkel</strong> <a href="http://twitter.com/#!/papakorkel">@papakorkel</a><br />
@jonseg ¿Desleal porque no es puta mierda como su página web?</p>
<p><strong>Josean Bilbao</strong> <a href="http://twitter.com/#!/joseanbilbao">@joseanbilbao</a><br />
@jonseg otra muestra más de su incompetencia, en lugar de acercarse al talento y colaborar, lo eliminan. #fail #renfe</p>
<p><strong>Albert Mata</strong> <a href="http://twitter.com/#!/almata">@almata</a><br />
@jonseg yo creía que en Android había libertad y no eran como los malísimos de Apple y no pasaban esas cosas&#8230;</p>
<p><strong>rnesto G. Aroca</strong> <a href="http://twitter.com/#!/ErneX">@ErneX</a><br />
@snunsan @Renfe @jonseg Renfe como siempre, cubriéndose de gloria. Son unos incapaces.</p>
<p><strong>Salvador López</strong> <a href="http://twitter.com/#!/salvad0rlopez">@salvad0rlopez</a><br />
@jonseg yo uso tu app , una lastima que te la quiten del market ya que es fantastica, espero que sigas desarrollandola. <img src='http://jonsegador.com/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p><strong>Javier Eguiluz</strong> <a href="http://twitter.com/#!/javiereguiluz">@javiereguiluz</a><br />
@jonseg Ánimo Jon! El único consuelo es que Renfe reconoce que no puede ganarte, así que trata de eliminarte <img src='http://jonsegador.com/wp-includes/images/smilies/icon_sad.gif' alt=':(' class='wp-smiley' />  #android #renfe</p>
<p><strong>Victor</strong> <a href="http://twitter.com/#!/vdesigner_es">@vdesigner_es</a><br />
Bravo por los señores de @renfe obligando a Google a eliminar la única app 100% funcional sobre sus propios servicios #BravoRenfe</p>
<p><strong>A todos los RT, menciones y palabras de ánimo, solo puedo decir: ¡GRACIAS!</strong></p>
<p>&#8212;&#8212;-</p>
<p><strong>Actualización 10 enero 2012</strong>: Ya está disponible el código fuente en github y puedes descargar el fichero .apk de la aplicación si echas un vistazo a la columna derecha del blog.</p>
<p><del datetime="2012-01-10T08:52:22+00:00"><strong>Actualización 4 enero 2012</strong>: Ahora mismo no tengo acceso a la última versión del código de la aplicación. En cuanto pueda (a partir del día 8 de enero) subiré el código a Github y publicaré el .apk en el blog.</del></p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2012/01/me-han-suspendido-la-aplicacion-de-cercanias-renfe-para-android/feed/</wfw:commentRss>
		<slash:comments>50</slash:comments>
		</item>
		<item>
		<title>Aplicación para Android: Estaciones de esquí</title>
		<link>http://jonsegador.com/2010/11/aplicacion-para-android-estaciones-de-esqui/</link>
		<comments>http://jonsegador.com/2010/11/aplicacion-para-android-estaciones-de-esqui/#comments</comments>
		<pubDate>Mon, 29 Nov 2010 08:55:16 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[Proyectos propios]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[esqui]]></category>
		<category><![CDATA[esquiar]]></category>
		<category><![CDATA[estaciones]]></category>
		<category><![CDATA[pistas]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=332</guid>
		<description><![CDATA[Actualización: - Planos de las estaciones (mantén el dedo pulsado para hacer zoom) - Instalar en la tarjeta SD. - Arreglados problemas con algunas webcams. Añadidas las estaciones -Fuentes de Invierno -Navacerrada Añadido Pirineo Francés - La Pierre Saint-Martin - Luz Ardiden - Grand Tourmalet - etc Si falta alguna estación, ponte en contacto conmigo [...]]]></description>
			<content:encoded><![CDATA[<p><strong>Actualización:</strong><br />
- Planos de las estaciones (mantén el dedo pulsado para hacer zoom)<br />
- Instalar en la tarjeta SD.<br />
- Arreglados problemas con algunas webcams.</p>
<p>Añadidas las estaciones<br />
-Fuentes de Invierno<br />
-Navacerrada</p>
<p>Añadido Pirineo Francés<br />
- La Pierre Saint-Martin<br />
- Luz Ardiden<br />
- Grand Tourmalet<br />
- etc</p>
<p>Si falta alguna estación, ponte en contacto conmigo y la incluiré cuanto antes</p>
<p>&#8212;&#8212;</p>
<p>Con esta aplicación podrás consultar en todo momento la cantidad de nieve y el estado de las pistas de esquí observándolas directamente a través de las webcams.</p>
<p>Disponibles las estaciones de esqui de toda España, contando todas ellas con varias webcams.</p>
<p>Obtendrás información del estado de las pistas, espesor y calidad de la nieve, remontes abiertos, pistas abiertas, kilómetros abiertos, etc.</p>
<p>Toda la información sobre estaciones de esquí y pistas de ski.</p>
<p>- Alto Campoo<br />
- Astún<br />
- Candanchú<br />
- Formigal<br />
- Baqueira Beret<br />
- Valdelinares<br />
- Valdezcaray<br />
- Sierra Nevada<br />
- etc.</p>
<p>Para descargarla, solamente deberemos buscar &#8220;estaciones esqui&#8221; en el Android Market o a partir del siguiente código QR:<br />
<img src="http://jonsegador.com/wp-content/estaciones_esqui_qr.png" alt="estaciones-esqui-android-qrcode" title="estaciones-esqui-android-qrcode" class="alignnone size-full wp-image-186" /></p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/11/aplicacion-para-android-estaciones-de-esqui/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Aplicación para Android: Oficinas de la BBK</title>
		<link>http://jonsegador.com/2010/10/aplicacion-para-android-oficinas-de-la-bbk/</link>
		<comments>http://jonsegador.com/2010/10/aplicacion-para-android-oficinas-de-la-bbk/#comments</comments>
		<pubDate>Tue, 26 Oct 2010 07:08:19 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[Proyectos propios]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[bbk]]></category>
		<category><![CDATA[cajeros]]></category>
		<category><![CDATA[market]]></category>
		<category><![CDATA[oficinas]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=314</guid>
		<description><![CDATA[Con esta aplicación ya puedes buscar las oficinas de la BBK más cercanas a tu posición. Es una primera versión básica. Las próximas actualizaciones serán: - Buscar por número de oficina - Información de la oficina: teléfono, horarios, etc. - Vuestras sugerencias en los comentarios! Para descargarla, solamente deberemos buscar &#8220;bbk&#8221; en el Android Market [...]]]></description>
			<content:encoded><![CDATA[<p>Con esta aplicación ya puedes buscar las oficinas de la BBK más cercanas a tu posición.</p>
<p>Es una primera versión básica. Las próximas actualizaciones serán:<br />
- Buscar por número de oficina<br />
- Información de la oficina: teléfono, horarios, etc.<br />
- Vuestras sugerencias en los comentarios!</p>
<p>Para descargarla, solamente deberemos buscar &#8220;bbk&#8221; en el Android Market o a partir del siguiente código QR:<br />
<img src="http://jonsegador.com/wp-content/bbk_qr.png" alt="bbk-qrcode" title="bbk-qrcode" width="210" height="210" class="alignnone size-full wp-image-186" /></p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/10/aplicacion-para-android-oficinas-de-la-bbk/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Tutorial Android paso a paso III: Desarrollo de la aplicación Notepad</title>
		<link>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-iii-desarrollo-de-la-aplicacion-notepad/</link>
		<comments>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-iii-desarrollo-de-la-aplicacion-notepad/#comments</comments>
		<pubDate>Tue, 23 Feb 2010 09:48:32 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[Desarrollo]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[notepad]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=136</guid>
		<description><![CDATA[En este tercer y último post del tutorial, vamos a practicar el ciclo de vida de la aplicación, y como guardar y recuperar el estado de la aplicación. Puedes ver los anteriores artículos: Tutorial Android paso a paso I: Desarrollo de la aplicación Notepad Tutorial Android paso a paso II: Desarrollo de la aplicación Notepad [...]]]></description>
			<content:encoded><![CDATA[<p>En este tercer y último post del tutorial, vamos a practicar el ciclo de vida de la aplicación, y como guardar y recuperar el estado de la aplicación.</p>
<p>Puedes ver los anteriores artículos:<br />
<a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-desarrollo-aplicacion-notepad/">Tutorial Android paso a paso I: Desarrollo de la aplicación Notepad</a><br />
<a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-ii-desarrollo-de-la-aplicacion-notepad/">Tutorial Android paso a paso II: Desarrollo de la aplicación Notepad</a></p>
<p>Objetivos:<br />
• Conocer los eventos del ciclo de vida de la aplicación.<br />
• Tecnicas para mantener el estado de la aplicación.</p>
<h4><strong>Paso 1</strong></h4>
<p>La aplicación actual contiene algunos problemas. Para solucionarlo, vamos a mover la funcionalidad de edición de notas a la clase NoteEdit.</p>
<p>1. Eliminar el siguiente código de la clase NoteEdit, que obtiene los datos de la nota a través del Bundle. Vamos a pasar a utilizar la clase DBHelper para obtener los datos directamente de la base de datos.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">Bundle extras <span style="color: #339933;">=</span> getIntent<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">getExtras</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
…
<span style="color: #003399;">String</span> title <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #003399;">String</span> body <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
mRowId <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>2. Además, eliminamos la asignación de los datos a la interfaz de usuario</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>title <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    mTitleText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>title<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span>
<span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>body <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    mBodyText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>body<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 2</strong></h4>
<p>Conectamos la clase NoteEdit con la base de datos.</p>
<p>1. Creamos un nuevo atributo:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> NotesDbAdapter mDbHelper<span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>2. Conectamos con la base de datos en el constructor, justo después de llamar al constructor padre:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">mDbHelper <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> NotesDbAdapter<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
mDbHelper.<span style="color: #006633;">open</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<h4><strong>Paso 3</strong></h4>
<p>Pasamos a comprobar el estado de la variable savedInstanceState. Esto sirve para comprobar si tenemos datos guardados en el Bundle, que debemos recuperar (Esto ocurre si la actividad pierde el foco y después se recupera).</p>
<p>1. Reeplazar el siguiente código:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">mRowId <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
Bundle extras <span style="color: #339933;">=</span> getIntent<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">getExtras</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>extras <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    mRowId <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Por este otro</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">mRowId <span style="color: #339933;">=</span> savedInstanceState <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span> <span style="color: #339933;">?</span> savedInstanceState.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">:</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
<span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>mRowId <span style="color: #339933;">==</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    Bundle extras <span style="color: #339933;">=</span> getIntent<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">getExtras</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    mRowId <span style="color: #339933;">=</span> extras <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span> <span style="color: #339933;">?</span> extras.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">:</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 4</strong></h4>
<p>Necesitamos completar los campos con los datos de la nota. Llamamos al método populateFields() que completaremos más adelante. Insertarlo justo antes de confirmButton.setOnClickListener():</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">populateFields<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<h4><strong>Paso 5</strong></h4>
<p>En esta actividad ya no es necesario devolver ningún tipo de datos, ya que vamos a guardar los datos directamente en esta actividad, por lo que es posible simplificar el método onClick() considerablemente:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> onClick<span style="color: #009900;">&#40;</span><span style="color: #003399;">View</span> view<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    setResult<span style="color: #009900;">&#40;</span>RESULT_OK<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    finish<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Más adelante veremos como guardar los datos.</p>
<h4><strong>Paso 6</strong></h4>
<p>Definimos el método populateFields():</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">void</span> populateFields<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>mRowId <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #003399;">Cursor</span> note <span style="color: #339933;">=</span> mDbHelper.<span style="color: #006633;">fetchNote</span><span style="color: #009900;">&#40;</span>mRowId<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        startManagingCursor<span style="color: #009900;">&#40;</span>note<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mTitleText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>note.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>note.<span style="color: #006633;">getColumnIndexOrThrow</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mBodyText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>note.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>note.<span style="color: #006633;">getColumnIndexOrThrow</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 7</strong></h4>
<p>Implementamos los métodos que gestionan el ciclo de vida de Android. Estos métodos nos permiten guardar y recuperar el estado de la actividad en caso de que esta se cierre o pase a un segundo plano (al recibir una llamada, por ejemplo):</p>
<p>1. onSaveInstanceState(): es llamada por Android cuando la actividad va a ser cerrada. Esto significa que aquí se debe guardar toda la información necesaria para restaurar la actividad en su estado  anterior. Podemos pensar que es el método contrario a onCreate(), de hecho el Bundle que construimos en este método, es el que será pasado al método onCreate().</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onSaveInstanceState<span style="color: #009900;">&#40;</span>Bundle outState<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onSaveInstanceState</span><span style="color: #009900;">&#40;</span>outState<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    outState.<span style="color: #006633;">putLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span>, mRowId<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>2. onPause(): es llamada cuando la actividad va a terminar (con finish()) o pasar a un segundo plano (con una llamada de teléfono).</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onPause<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onPause</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    saveState<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>3. onResume(): es llamada al reactivar la actividad. Completamos los campos:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onResume<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onResume</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    populateFields<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 8</strong></h4>
<p>Para terminar de completar la clase NoteEdit, ya solo nos queda guardar los datos en la base de datos. Creamos el método saveState():</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">void</span> saveState<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #003399;">String</span> title <span style="color: #339933;">=</span> mTitleText.<span style="color: #006633;">getText</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">toString</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #003399;">String</span> body <span style="color: #339933;">=</span> mBodyText.<span style="color: #006633;">getText</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">toString</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>mRowId <span style="color: #339933;">==</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000066; font-weight: bold;">long</span> id <span style="color: #339933;">=</span> mDbHelper.<span style="color: #006633;">createNote</span><span style="color: #009900;">&#40;</span>title, body<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>id <span style="color: #339933;">&gt;</span> <span style="color: #cc66cc;">0</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            mRowId <span style="color: #339933;">=</span> id<span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
    <span style="color: #009900;">&#125;</span> <span style="color: #000000; font-weight: bold;">else</span> <span style="color: #009900;">&#123;</span>
        mDbHelper.<span style="color: #006633;">updateNote</span><span style="color: #009900;">&#40;</span>mRowId, title, body<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 9</strong></h4>
<p>Volvemos a la clase Notepadv3. En el método onActivityResult(), teníamos implementado todo lo necesario para recibir los datos de la actividad y guardarla en la base de datos. Como este proceso ya lo realizamos en la clase NoteEdit, solo es necesario que actualizemos la lista con los nuevos datos:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onActivityResult<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> requestCode, <span style="color: #000066; font-weight: bold;">int</span> resultCode, Intent intent<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onActivityResult</span><span style="color: #009900;">&#40;</span>requestCode, resultCode, intent<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 10</strong></h4>
<p>Finalmente, es esta misma clase, al seleccionar un elemento de la lista, ya no es ncesario pasar todos los datos de la nota, únicamente el id, por lo que el método onListItemClick(), quedaría de la siguiete manera:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onListItemClick<span style="color: #009900;">&#40;</span><span style="color: #003399;">ListView</span> l, <span style="color: #003399;">View</span> v, <span style="color: #000066; font-weight: bold;">int</span> position, <span style="color: #000066; font-weight: bold;">long</span> id<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onListItemClick</span><span style="color: #009900;">&#40;</span>l, v, position, id<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    Intent i <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Intent<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span>, NoteEdit.<span style="color: #000000; font-weight: bold;">class</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    i.<span style="color: #006633;">putExtra</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span>, id<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    startActivityForResult<span style="color: #009900;">&#40;</span>i, ACTIVITY_EDIT<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Y con este último post hemos terminado el tutorial. Espero que os haya servido de ayuda y, como siempre, cualquier duda o pregunta en los comentarios.</p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-iii-desarrollo-de-la-aplicacion-notepad/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
		<item>
		<title>Tutorial Android paso a paso II: Desarrollo de la aplicación Notepad</title>
		<link>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-ii-desarrollo-de-la-aplicacion-notepad/</link>
		<comments>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-ii-desarrollo-de-la-aplicacion-notepad/#comments</comments>
		<pubDate>Sat, 20 Feb 2010 14:31:18 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[Desarrollo]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[notepad]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=119</guid>
		<description><![CDATA[Continuamos con la segunda parte del tutorial para el desarrollo de una aplicación para Android paso a paso. La primera parte la puedes consultar en Tutorial Android paso a paso I: Desarrollo de la aplicación Notepad. En este segundo post, vamos a crear una segunda actividad que nos permita crear y editar notas. Además, vamos [...]]]></description>
			<content:encoded><![CDATA[<p>Continuamos con la segunda parte del tutorial para el desarrollo de una aplicación para Android paso a paso. La primera parte la puedes consultar en <a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-desarrollo-aplicacion-notepad/">Tutorial Android paso a paso I: Desarrollo de la aplicación Notepad</a>.</p>
<p>En este segundo post, vamos a crear una segunda actividad que nos permita crear y editar notas. Además, vamos a poder tener la posibilidad de eliminar notas a través del un menú contextual.</p>
<p>Objetivos:<br />
  • Crear una nueva actividad.<br />
  • Realizar llamadas a la nueva actividad.<br />
  • Paso de datos entre las actividades.<br />
  • Crear un nuevo menu contextual.</p>
<h4><strong>Paso 1</strong></h4>
<p>Vamos a crear un menú contextual que nos permita eliminar las notas creadas por el usuario. Este menú se activará al seleccionar una nota:</p>
<p>1. Relacionamos la lista de notas (ListView) con el menu contextual:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">registerForContextMenu<span style="color: #009900;">&#40;</span>getListView<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>2. Creamos el menú contextual con la opción de eliminar una nota:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> onCreateContextMenu<span style="color: #009900;">&#40;</span>ContextMenu menu, <span style="color: #003399;">View</span> v, ContextMenuInfo menuInfo<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onCreateContextMenu</span><span style="color: #009900;">&#40;</span>menu, v, menuInfo<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    menu.<span style="color: #006633;">add</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">0</span>, DELETE_ID, <span style="color: #cc66cc;">0</span>, R.<span style="color: #006633;">string</span>.<span style="color: #006633;">menu_delete</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>3. Ahora que tenemos el menú creado y relacionado con el listado, tenemos que atender a las pulsaciones en el menú contextual:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">boolean</span> onContextItemSelected<span style="color: #009900;">&#40;</span><span style="color: #003399;">MenuItem</span> item<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">switch</span><span style="color: #009900;">&#40;</span>item.<span style="color: #006633;">getItemId</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">case</span> DELETE_ID<span style="color: #339933;">:</span>
            AdapterContextMenuInfo info <span style="color: #339933;">=</span> <span style="color: #009900;">&#40;</span>AdapterContextMenuInfo<span style="color: #009900;">&#41;</span>
            item.<span style="color: #006633;">getMenuInfo</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            mDbHelper.<span style="color: #006633;">deleteNote</span><span style="color: #009900;">&#40;</span>info.<span style="color: #006633;">id</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000066; font-weight: bold;">true</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onContextItemSelected</span><span style="color: #009900;">&#40;</span>item<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 2</strong></h4>
<p>Como hemos visto antes, vamos a dar la posibilidad al usuario de crear y editar notas. Para ello, necesitamos una actividad que controle la interfaz de usuario.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">class</span> NoteEdit <span style="color: #000000; font-weight: bold;">extends</span> Activity <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">private</span> EditText mTitleText<span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">private</span> EditText mBodyText<span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">private</span> <span style="color: #003399;">Long</span> mRowId<span style="color: #339933;">;</span>
&nbsp;
    @Override
    <span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onCreate<span style="color: #009900;">&#40;</span>Bundle savedInstanceState<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onCreate</span><span style="color: #009900;">&#40;</span>savedInstanceState<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        setContentView<span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">layout</span>.<span style="color: #006633;">note_edit</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mTitleText <span style="color: #339933;">=</span> <span style="color: #009900;">&#40;</span>EditText<span style="color: #009900;">&#41;</span> findViewById<span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">id</span>.<span style="color: #006633;">title</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mBodyText <span style="color: #339933;">=</span> <span style="color: #009900;">&#40;</span>EditText<span style="color: #009900;">&#41;</span> findViewById<span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">id</span>.<span style="color: #006633;">body</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #003399;">Button</span> confirmButton <span style="color: #339933;">=</span> <span style="color: #009900;">&#40;</span><span style="color: #003399;">Button</span><span style="color: #009900;">&#41;</span> findViewById<span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">id</span>.<span style="color: #006633;">confirm</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mRowId <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span>
        Bundle extras <span style="color: #339933;">=</span> getIntent<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">getExtras</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>extras <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            <span style="color: #003399;">String</span> title <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #003399;">String</span> body <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            mRowId <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
            <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>title <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
                mTitleText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>title<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #009900;">&#125;</span>
&nbsp;
            <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>body <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
                mBodyText.<span style="color: #006633;">setText</span><span style="color: #009900;">&#40;</span>body<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #009900;">&#125;</span>
        <span style="color: #009900;">&#125;</span>
&nbsp;
    confirmButton.<span style="color: #006633;">setOnClickListener</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> <span style="color: #003399;">View</span>.<span style="color: #006633;">OnClickListener</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> onClick<span style="color: #009900;">&#40;</span><span style="color: #003399;">View</span> view<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        Bundle bundle <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Bundle<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        bundle.<span style="color: #006633;">putString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span>,
        mTitleText.<span style="color: #006633;">getText</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">toString</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        bundle.<span style="color: #006633;">putString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span>,
        mBodyText.<span style="color: #006633;">getText</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span>.<span style="color: #006633;">toString</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>mRowId <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            bundle.<span style="color: #006633;">putLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span>, mRowId<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        <span style="color: #009900;">&#125;</span>
        Intent mIntent <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Intent<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        mIntent.<span style="color: #006633;">putExtras</span><span style="color: #009900;">&#40;</span>bundle<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        setResult<span style="color: #009900;">&#40;</span>RESULT_OK, mIntent<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
        finish<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span><span style="color: #009900;">&#125;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 3</strong></h4>
<p>Ya tenemos la interfaz de usuario, y la actividad para controlarla. Vamos a abrir la nueva actividad desde el listado, para crear una nueva nota. Modificamos el método createNote() de la siguiente manera:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">void</span> createNote<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    Intent i <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Intent<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span>, NoteEdit.<span style="color: #000000; font-weight: bold;">class</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    startActivityForResult<span style="color: #009900;">&#40;</span>i, ACTIVITY_CREATE<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 4</strong></h4>
<p>Para editar las notas ya creadas, creamos un evento para atender a las pulsaciones de los elementos de las listas. Pasamos los datos de la nota a la nueva actividad.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onListItemClick<span style="color: #009900;">&#40;</span><span style="color: #003399;">ListView</span> l, <span style="color: #003399;">View</span> v, <span style="color: #000066; font-weight: bold;">int</span> position, <span style="color: #000066; font-weight: bold;">long</span> id<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onListItemClick</span><span style="color: #009900;">&#40;</span>l, v, position, id<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #003399;">Cursor</span> c <span style="color: #339933;">=</span> mNotesCursor<span style="color: #339933;">;</span>
    c.<span style="color: #006633;">moveToPosition</span><span style="color: #009900;">&#40;</span>position<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    Intent i <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Intent<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span>, NoteEdit.<span style="color: #000000; font-weight: bold;">class</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    i.<span style="color: #006633;">putExtra</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span>, id<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    i.<span style="color: #006633;">putExtra</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span>, c.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>
    c.<span style="color: #006633;">getColumnIndexOrThrow</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    i.<span style="color: #006633;">putExtra</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span>, c.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>
    c.<span style="color: #006633;">getColumnIndexOrThrow</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    startActivityForResult<span style="color: #009900;">&#40;</span>i, ACTIVITY_EDIT<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 5</strong></h4>
<p>Los métodos creados anteriormente createNote() y onListItemClick() nos devuelven datos, por lo que necesitamos un método para manejar la respuesta. onActivityResult() es el método ejecutado cuando una actividad devuelve resultados.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">protected</span> <span style="color: #000066; font-weight: bold;">void</span> onActivityResult<span style="color: #009900;">&#40;</span><span style="color: #000066; font-weight: bold;">int</span> requestCode, <span style="color: #000066; font-weight: bold;">int</span> resultCode, Intent intent<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onActivityResult</span><span style="color: #009900;">&#40;</span>requestCode, resultCode, intent<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    Bundle extras <span style="color: #339933;">=</span> intent.<span style="color: #006633;">getExtras</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">switch</span><span style="color: #009900;">&#40;</span>requestCode<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">case</span> ACTIVITY_CREATE<span style="color: #339933;">:</span>
            <span style="color: #003399;">String</span> title <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #003399;">String</span> body <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            mDbHelper.<span style="color: #006633;">createNote</span><span style="color: #009900;">&#40;</span>title, body<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">break</span><span style="color: #339933;">;</span>
        <span style="color: #000000; font-weight: bold;">case</span> ACTIVITY_EDIT<span style="color: #339933;">:</span>
            <span style="color: #003399;">Long</span> rowId <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getLong</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_ROWID</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #009900;">&#40;</span>rowId <span style="color: #339933;">!=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
            <span style="color: #003399;">String</span> editTitle <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #003399;">String</span> editBody <span style="color: #339933;">=</span> extras.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>NotesDbAdapter.<span style="color: #006633;">KEY_BODY</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            mDbHelper.<span style="color: #006633;">updateNote</span><span style="color: #009900;">&#40;</span>rowId, editTitle, editBody<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">break</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 6</strong></h4>
<p>La nueva actividad que hemos definido anteriormente, hay que añadirla a AndroidManifest.xml. Esto permite al sistema conocer los componentes de la aplicación.<br />
Eclipse include un editor para el manifiesto que facilita la edición del fichero AndroidManifest.xml. Para añadir una nueva actividad:</p>
<p>1. Abrir el fichero AndroidManifest.xml<br />
2. Seleccionar la pestaña Application.<br />
3. Pulsamos Add en la sección de Application Nodes.<br />
4. En el cuadro de diálogo, seleccionar &#8220;Create a new element at the top level, in Application&#8221; y Activity. Pulsar OK.<br />
5. Seleccionar la nueva actividad creada, y en el campo de texto Name, escribir .NoteEdit.</p>
<h4><strong>Paso 7</strong></h4>
<p>Ya hemos terminado esta segunda entrega del tutorial. Si ejecutamos la aplicación, editamos una nota y pulsamos el botón atrás, veremos que se produce un error. Veremos como solucionar estos  problemas en el siguiente post.</p>
<p><strong>Cualquier pregunta o duda (o corrección) en los comentarios.</strong></p>
<p>Ya puedes consultar la tercera parte del tutorial: <a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-iii-desarrollo-de-la-aplicacion-notepad/">Tutorial Android paso a paso III: Desarrollo de la aplicación Notepad</a></p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-ii-desarrollo-de-la-aplicacion-notepad/feed/</wfw:commentRss>
		<slash:comments>16</slash:comments>
		</item>
		<item>
		<title>Tutorial Android paso a paso I: Desarrollo de la aplicación Notepad</title>
		<link>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-desarrollo-aplicacion-notepad/</link>
		<comments>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-desarrollo-aplicacion-notepad/#comments</comments>
		<pubDate>Wed, 17 Feb 2010 20:29:07 +0000</pubDate>
		<dc:creator>Jon</dc:creator>
				<category><![CDATA[Android]]></category>
		<category><![CDATA[Desarrollo]]></category>
		<category><![CDATA[aplicación]]></category>
		<category><![CDATA[notepad]]></category>

		<guid isPermaLink="false">http://jonsegador.com/?p=76</guid>
		<description><![CDATA[Me he decidido a hacer una serie de posts a modo de curso para empezar a desarrollar aplicaciones para Android. Voy a omitir la instalación del entorno de desarrollo (eclipse + sdk android) ya que existen numerosos manuales disponibles en internet. De todas formas, para instalarlo recomiendo este enlace. Después seguiremos los manuales disponibles en [...]]]></description>
			<content:encoded><![CDATA[<p>Me he decidido a hacer una serie de posts a modo de curso para empezar a desarrollar aplicaciones para Android. Voy a omitir la instalación del entorno de desarrollo (eclipse + sdk android) ya que existen numerosos manuales disponibles en internet. De todas formas, para instalarlo recomiendo <a href="http://groups.google.com/group/desarrolladores-android/web/instalando-el-entorno-de-desarrollo-y-primera-prueba">este enlace</a>. Después seguiremos los manuales disponibles en inglés en la web oficial de Android (<a href="http://developer.android.com/resources/tutorials/notepad/index.html">http://developer.android.com/resources/tutorials/notepad/index.html</a>), pero en castellano y con pasos muy fáciles de seguir (no será una traducción al pie de la letra).</p>
<p><strong>Nos deberemos descargar los ejemplos que encontraremos <a href="http://developer.android.com/resources/tutorials/notepad/codelab/NotepadCodeLab.zip">aquí</a> para seguir el curso</strong>.</p>
<p>Empezamos!</p>
<h4><strong>Desarrollo de la aplicación Notepad</strong></h4>
<p>A través de este tutorial vamos a crear una aplicación para tomar notas, que nos introducirá a los aspectos básicos y herramientas para el desarrollo en Android. Comenzando por un proyecto base, seguiremos los pasos  para crear una simple aplicación, viendo como desarrollar la lógica de negocio y las interfaces, así como compilar y ejecutar la aplicación.</p>
<p>En este ejercicio, vamos a construir una simple lista de notas, permitiendo al usuario añadir nuevas notas, pero no editarlas.</p>
<p>Objetivos:<br />
• Conocer ListActivities y crear menus de aplicación.<br />
• Utilizar SQLite para almacenar datos.<br />
• Cómo recuperar los datos de una base de datos y mostrarlos en pantalla.<br />
• Conceptos básicos sobre cómo interactuar con la interfaz de usuario.</p>
<h4><strong>Paso 1</strong></h4>
<p>1. Crear un nuevo proyecto Android File &gt; New &gt; Android Project<br />
2. En el cuadro de diálogo, seleccionar Create project from existing source<br />
3. Pulsar Browse y navegar hasta donde hemos descomprimido el material del curso (carpeta NotepadCodeLab) y seleccionar Notepadv1<br />
4. Las propiedades del proyecto deberían de completarse automáticamente.<br />
5. Pulsar Finish. El proyecto Notepadv1 debería abrirse y aparecer en el explorador de proyectos.</p>
<p>Si se produce algún error con AndroidManifest.xml, pulsar el botón derecho sobre el proyecto y seleccionar Android Tools &gt; Fix Project Properties.</p>
<h4><strong>Paso 2</strong></h4>
<p>Abrir el fichero notepad_list.xml en res/layout. Vamos a añadir los elementos necesarios para presentar la lista de notas. Podemos hacerlo de dos manera, añadir un ListView y un TextView desde el panel de elementos, o escribiendo el código directamente en el XML.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
</pre></td><td class="code"><pre class="xml" style="font-family:monospace;"><span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;?xml</span> <span style="color: #000066;">version</span>=<span style="color: #ff0000;">&quot;1.0&quot;</span> <span style="color: #000066;">encoding</span>=<span style="color: #ff0000;">&quot;utf-8&quot;</span><span style="color: #000000; font-weight: bold;">?&gt;</span></span>
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;LinearLayout</span></span>
<span style="color: #009900;">      <span style="color: #000066;">xmlns:android</span>=<span style="color: #ff0000;">&quot;http://schemas.android.com/apk/res/android&quot;</span></span>
<span style="color: #009900;">      <span style="color: #000066;">android:layout_width</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span></span>
<span style="color: #009900;">      <span style="color: #000066;">android:layout_height</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span><span style="color: #000000; font-weight: bold;">&gt;</span></span>
      <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;ListView</span> <span style="color: #000066;">android:layout_width</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span></span>
<span style="color: #009900;">          <span style="color: #000066;">android:layout_height</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span></span>
<span style="color: #009900;">          <span style="color: #000066;">android:id</span>=<span style="color: #ff0000;">&quot;@android:id/list&quot;</span><span style="color: #000000; font-weight: bold;">&gt;</span><span style="color: #000000; font-weight: bold;">&lt;/ListView<span style="color: #000000; font-weight: bold;">&gt;</span></span></span>
     <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;TextView</span> <span style="color: #000066;">android:layout_width</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span></span>
<span style="color: #009900;">          <span style="color: #000066;">android:layout_height</span>=<span style="color: #ff0000;">&quot;wrap_content&quot;</span></span>
<span style="color: #009900;">          <span style="color: #000066;">android:text</span>=<span style="color: #ff0000;">&quot;@string/no_notes&quot;</span></span>
<span style="color: #009900;">          <span style="color: #000066;">android:id</span>=<span style="color: #ff0000;">&quot;@android:id/empty&quot;</span><span style="color: #000000; font-weight: bold;">&gt;</span><span style="color: #000000; font-weight: bold;">&lt;/TextView<span style="color: #000000; font-weight: bold;">&gt;</span></span></span>
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/LinearLayout<span style="color: #000000; font-weight: bold;">&gt;</span></span></span></pre></td></tr></table></div>

<p>Los elementos que hemos añadido se mostrarán alternativamente, es decir, solo uno de ellos será visible.<br />
• Los identificadores list y empty son proporcionados por la plataforma Android, por lo que tenemos que añadir el prefijo android: a los identificadores (@android:id/list).<br />
• La vista con el identificador empty, es usada automáticamente por Android cuando no existen elementos que mostrar.</p>
<h4><strong>Paso 3</strong></h4>
<p>Necesitamos mostrar las notas en el listado de notas, dentro del ListView.<br />
1. Crear un nuevo fichero llamado notes_row.xml dentro de res/layout.<br />
2. Añadir un nuevo TextView a la interfaz. Aplicarle el siguiente identificador: @+id/text1<br />
3. Guardar el fichero.</p>
<h4><strong>Paso 4</strong></h4>
<p>Vamos a modificar la clase Notepadv1 para mostrar el listado de nostas y que nos permita añadir nuevas notas. Abrimos el fichero Notepadv1.java.</p>
<p>• Debemos cambiar la clase a la que extiende (Activity) por ListActivity. Esta clase nos proporciona funcionalidades extra para trabajar con listas.<br />
• Vemos que existen varios métodos en el código:<br />
    onCreate(): se ejecuta cuando se llama a la actividad (puede verse como un método main).<br />
    onCreateOptionsMenu(): crea el menu de la actividad.<br />
    onOptionsItemSelected(): se ejecuta al seleccionar un elemento del menu.</p>
<h4><strong>Paso 5</strong></h4>
<p>Ahora que ya tenemos los componentes, ya podemos comenzar a construir la aplicación. Lo primero que vamos a hacer es abrir/crear la base de datos y asignar el resultado a la vista (ListView). Vamos a añadir el siguiente código al método onCreate():</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">void</span> onCreate<span style="color: #009900;">&#40;</span>Bundle savedInstanceState<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onCreate</span><span style="color: #009900;">&#40;</span>savedInstanceState<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onCreate</span><span style="color: #009900;">&#40;</span>savedInstanceState<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    setContentView<span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">layout</span>.<span style="color: #006633;">notepad_list</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    mDbHelper <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> NotesDbAdapter<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    mDbHelper.<span style="color: #006633;">open</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>Definir la siguiente variable a nivel de clase:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> NotesDbAdapter mDbHelper <span style="color: #339933;">=</span> <span style="color: #000066; font-weight: bold;">null</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>Hemos definido un nuevo método, fillData(), que es el encargado de obtener todas las notas de la base de datos y asignárselas al ListView.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">void</span> fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #003399;">Cursor</span> c <span style="color: #339933;">=</span> mDbHelper.<span style="color: #006633;">fetchAllNotes</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    startManagingCursor<span style="color: #009900;">&#40;</span>c<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #003399;">String</span><span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> from <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> <span style="color: #003399;">String</span><span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> <span style="color: #009900;">&#123;</span> NotesDbAdapter.<span style="color: #006633;">KEY_TITLE</span> <span style="color: #009900;">&#125;</span><span style="color: #339933;">;</span>
    <span style="color: #000066; font-weight: bold;">int</span><span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> to <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> <span style="color: #000066; font-weight: bold;">int</span><span style="color: #009900;">&#91;</span><span style="color: #009900;">&#93;</span> <span style="color: #009900;">&#123;</span> R.<span style="color: #006633;">id</span>.<span style="color: #006633;">text1</span> <span style="color: #009900;">&#125;</span><span style="color: #339933;">;</span>
    SimpleCursorAdapter notes <span style="color: #339933;">=</span>
        <span style="color: #000000; font-weight: bold;">new</span> SimpleCursorAdapter<span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">this</span>, R.<span style="color: #006633;">layout</span>.<span style="color: #006633;">notes_row</span>, c, from, to<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    setListAdapter<span style="color: #009900;">&#40;</span>notes<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 6</strong></h4>
<p>Vamos a crear el menu para que nos permita añadir nuevas notas a la lista.<br />
Necesitamos un botón que al ser pulsado cree una nueva nota:</p>
<p>1. Creamos el texto asociado al botón en res/values/strings.xml<br />
<img src="http://jonsegador.com/wp-content/uploads/android1.jpg" alt="android1" title="android1" width="625" height="199" class="alignnone size-full wp-image-95" /></p>
<p>2. Definimos la posición del botón en el menú:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">static</span> <span style="color: #000000; font-weight: bold;">final</span> <span style="color: #000066; font-weight: bold;">int</span> INSERT_ID <span style="color: #339933;">=</span> <span style="color: #003399;">Menu</span>.<span style="color: #006633;">FIRST</span><span style="color: #339933;">;</span></pre></td></tr></table></div>

<p>3. Añadimos el nuevo botón al menú:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">boolean</span> onCreateOptionsMenu<span style="color: #009900;">&#40;</span><span style="color: #003399;">Menu</span> menu<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000066; font-weight: bold;">boolean</span> result <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onCreateOptionsMenu</span><span style="color: #009900;">&#40;</span>menu<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    menu.<span style="color: #006633;">add</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">0</span>, INSERT_ID, <span style="color: #cc66cc;">0</span>, R.<span style="color: #006633;">string</span>.<span style="color: #006633;">menu_insert</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000000; font-weight: bold;">return</span> result<span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 7</strong></h4>
<p>Una vez creado el menú, es necesario atender a las pulsaciones de los elementos del mismo. Aunque en este caso tengamos un único elemento, hay que tener en cuenta el elemento pulsado:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
</pre></td><td class="code"><pre class="java" style="font-family:monospace;">@Override
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000066; font-weight: bold;">boolean</span> onOptionsItemSelected<span style="color: #009900;">&#40;</span><span style="color: #003399;">MenuItem</span> item<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #000000; font-weight: bold;">switch</span> <span style="color: #009900;">&#40;</span>item.<span style="color: #006633;">getItemId</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
        <span style="color: #000000; font-weight: bold;">case</span> INSERT_ID<span style="color: #339933;">:</span>
            createNote<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
            <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000066; font-weight: bold;">true</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    <span style="color: #000000; font-weight: bold;">return</span> <span style="color: #000000; font-weight: bold;">super</span>.<span style="color: #006633;">onOptionsItemSelected</span><span style="color: #009900;">&#40;</span>item<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 8</strong></h4>
<p>Creamos una nueva nota, la añadimos a la base de datos y actualizamos la lista para reflejar los cambios.</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
</pre></td><td class="code"><pre class="java" style="font-family:monospace;"><span style="color: #000000; font-weight: bold;">private</span> <span style="color: #000066; font-weight: bold;">void</span> createNote<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
    <span style="color: #003399;">String</span> noteName <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">this</span>.<span style="color: #006633;">getString</span><span style="color: #009900;">&#40;</span>R.<span style="color: #006633;">string</span>.<span style="color: #006633;">note_name</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">+</span> <span style="color: #0000ff;">&quot; &quot;</span> <span style="color: #339933;">+</span>
    <span style="color: #003399;">String</span>.<span style="color: #006633;">valueOf</span><span style="color: #009900;">&#40;</span>mNoteNumber<span style="color: #339933;">++</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    mDbHelper.<span style="color: #006633;">createNote</span><span style="color: #009900;">&#40;</span>noteName, <span style="color: #0000ff;">&quot;&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    fillData<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<h4><strong>Paso 9</strong></h4>
<p>Ya hemos acabado. Puedes importar el proyecto llamado Notepadv1Solution para comprobar que has hecho todo bien. Mañana más. Cualquier duda en los comentarios!</p>
<p>Segundo capítulo del tutorial: <a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-ii-desarrollo-de-la-aplicacion-notepad/">Tutorial Android paso a paso II: Desarrollo de la aplicación Notepad</a><br />
Tercer capítulo del tutorial: <a href="http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-iii-desarrollo-de-la-aplicacion-notepad/">Tutorial Android paso a paso III: Desarrollo de la aplicación Notepad</a></p>
]]></content:encoded>
			<wfw:commentRss>http://jonsegador.com/2010/02/tutorial-android-paso-a-paso-desarrollo-aplicacion-notepad/feed/</wfw:commentRss>
		<slash:comments>28</slash:comments>
		</item>
	</channel>
</rss>

