Mostrando entradas con la etiqueta programación. Mostrar todas las entradas
Mostrando entradas con la etiqueta programación. Mostrar todas las entradas

26 agosto 2011

Mi primera aplicación Android: Ruleta de la Fortuna

Buenas

Como muchos sabéis, he estado aprovechando las mañanas de vagancia de este verano para retomar mi auto aprendizaje de Android (el sistema operativo de los móviles modernos) y por fin he terminado mi primera aplicación, la Ruleta de la Fortuna.
Es un programa de apariencia muy sencilla que consiste en una rueda giratoria que predice el futuro. Siempre acierta, aunque a veces no es muy colaborativa.
Sólo lo he hecho por aprender un poco, así que no hace falta que me digáis que va un poco chunga, pero bueno, cualquier comentario es bienvenido. Para el próximo proyecto, si es que no encuentro trabajo antes, intentaré hacer un juego sencillo.


Curiosamente yo no tengo ningún teléfono Android. Así que para enseñaros cómo funciona la aplicación he tenido que usar un emulador y he grabado un vídeo cutre de mi escritorio. Lo que se ve en el vídeo se supone que es un teléfono Android donde ya está instalada la aplicación. Giro un par de veces la ruleta y luego configuro el número de respuestas.


Los afortunados que sí tengan un Android podéis bajaros e instalaros la ruleta. Mi equipo de betatesters ya me ha informado que al usar pantalla táctil va un poco durilla, pero que funcionar, funciona.

Actualización: Ya está disponible en el Android Market:
https://market.android.com/details?id=com.jurimad.fortunewheel&feature=search_result


Actualización (24/10/2014): Debido a las continuas peticiones a través de comentarios e emails pidiéndome que les explique cómo hice la aplicación, añado un enlace donde os podéis bajar el código de la misma. Advierto que el código no está comentado y que no soy ningún experto, por lo que dudo que sea un código limpio y óptimo. Además hace ya tiempo que la hice y no he seguido con el tema, por lo que no recuerdo los detalles, así que no contestaré preguntas sobre el código.

Código: https://drive.google.com/file/d/0BwwYn-HW4nxjWjd2MVYtMVBORkdmZTJHWEpiNGF3VVhXWkJV/view?usp=sharing

Saludos!


01 mayo 2011

Crítica literaria: The Pragmatic Programmer

Buenas

El otro día terminé de leer The Pragmatic Programmer. Es un libro sobre programación, obviamente. Es bastante famosillo dentro del mundillo y muy recomendado. Es básicamente una recopilación de consejos y buenas prácticas a seguir a la hora de programar, ya sea individualmente o en equipo, en proyectos pequeños o grandes.

Casi todo lo que dice es más que conocido para quien se dedica a esto, aunque siempre se aprenden cosas nuevas. Conforme lo iba leyendo me fijaba si en mi ya ex-empresa seguíamos o no la filosofía pragmática. Sorprendentemente casi todo lo hacemos (o lo intentamos) y las cosas que no, son precisamente de las que siempre nos quejamos.

Otra cosa a destacar del libro es su superficialidad en muchos temas. Supongo que habrá a quien esto le parezca un error, pero a mí me parece que las ideas son bastante claras. Teniendo en cuenta la increíble variabilidad de programas, lenguajes y entornos de desarrollo, creo que intentar profundizar en aspectos técnicos sería un error.

Yo no me considero programador, aunque he estado más o menos metido en este mundo desde que empecé a trabajar. Quizás en mi próximo trabajo me tenga que meter de cabeza en este mundo. Si es así espero poner en práctica la programación pragmática.

Recomendaciones. Este libro no es para todo el mundo, evidentemente. Pero para los que programáis, aunque sean pequeñas chorradillas es altamente recomendable. Además es de fácil lectura. Eso sí, viene con las típicas chorradas de estos libros: citas absurdas al principio de cada capítulo, reglas nemotécnicas ridículas, historias y anécdotas varias y un tufillo a superioridad y repelencia por parte de los autores. A pesar de esto, un libro casi imprescindible.

29 abril 2008

Maestreando expresiones regulares

A veces que me doy cuenta de porque hay gente que me llama friki. Sólo el hecho de haber estudiado teleco y trabajar en désedos ya es bastante friki. Y aunque yo me considero bastante normal (¿quién no?) tengo que reconocer algunas cosas que me delatan, como el libro que os presento.

Pues resulta que como la semana pasada tenía tiempo libre en el trabajo y en désedos hay una biblioteca bastante generosa, he empezado a leerme un libro que estoy seguro que el 80% o más de los que leéis el blog no vais a entender ni de qué va. Ni aun cuando os lo cuente. (Y pobres los del 20% que sí lo hagan.)

El libro en cuestión se llama Mastering Regular Expressions.


Las preguntas inmediatas son:
- ¿Qué leches es eso de Regular Expressions?
- ¿Para qué sirve eso?

Siento avanzar que no tengo respuesta satisfactoria para ninguna de estas dos preguntas.

Aun así vamos a intentarlo.

Las expresiones regulares son... esto... unas cosas... es... como un toro!

Veamos un ejemplo a ver si así es más fácil empezar a coger la idea:
Cuando en el Windows buscas archivos .bmp, pones en el buscador que busque archivos llamados *.bmp, queriendo decir que * puede ser cualquier cosa. Esto no es una expresion regular, pero la idea se acerca.


Las expresiones regulares se usan en muchos lenguajes de programación para buscar patrones en variables o archivos de texto. Se parece a la utilidad de los editores de texto de buscar palabras, sólo que lo que buscamos no son palabras concretas, sino trozos de texto que cumplan con una serie de fórmulas que queremos.

Y como se desprende de lo dicho, las expresiones regulares sirven, entre otras cosas, para buscar cadenas de caracteres concretas en ficheros y para comprobar si una variable tipo texto cumple (es igual o parecida) unas determinadas características.

¿Ni idea?
Veamos un par de ejemplos que yo mismo uso. Uno es más o menos fácil de ver y el otro nos puede sonar a chino si no sabemos de qué va esto de las expresiones regulares.


- En mi trabajo, todos los días por la mañana analizamos los resultados de los tests que se han pasado a la versión diaria del software que hacemos. Estos resultados son archivos de texto (algunos de varios megas) que contienen la salida de los distintos subtests.
Aunque cada archivo tiene un informe al final, yo sólo tengo que escribir un comando para ver en pantalla los subtests que han fallado en todos y cada uno de los archivos sin tener que abrir uno por uno los ficheros. Para ello escribo en la consola:
egrep 'SubTest.+FAILED!' *version_20080421*
donde egrep es el comando de Linux que busca un patrón en un archivo, *version_20080421* es el conjunto de todos los archivos que contienen la versión que me interesa y SubTest.+FAILED! es la expresión regular que sólo me localiza las líneas que contienen al mimo tiempo la palabra SubTest y la palabra FAILED!. Así puedo ver, en unos segundos, qué cosas han fallado y me ahorro tener que abrir y analizar los ficheros donde todo ha ido bien.

- Tengo que comprobar que el contenido de una variable es un email válido (no que exista, simplemente que siga la fórmula nombre@servidor.dominio). Con hacer la siguiente comparación me sobra:
variable =~ /\w[-.\w]*\@[-\w]+(\.[-\w]+)*\.\w+/


Para mí las expresiones regulares son como escribir a máquina: no es necesario usarlas, pero ahorran mucho tiempo y una vez que sabes, te das cuenta de que hasta el momento has estado haciendo el canelo.


En mucho libros de programación dedican unas páginas a enseñarte qué son las expresiones regulares y cómo se usan en un determinado lenguaje. Pero cuando vi que había un libro exclusivamente dedicado a esto, me pregunté hasta dónde se puede llegar con las expresiones regulares, si pueden ahorrarme aun más trabajo, si me volveré loco aprendiéndolas, etc.

En fin, no pude resistir mi curiosidad y elegí este libro. Por eso y porque mis otras opciones eran Linux Kernel Development y Building Embedded Linux Systems.


Un saludo.

23 abril 2007

Día del libro -> Año de los 50 libros

Pequeño inciso:
Siguiendo la moda, el Tocho se ha hecho un blog. Por fin podremos saber algo más de su vida, aparte de lo poco que dice en sus emails. Ha prometido que escribirá frecuentemente y yo le creo. Parece que ya no lo tienen exprimido 24 horas al día para extraerle conocimientos como hacían antes.

-------------------------------------------------------------------------------------------

Hoy es el día del libro, creo... Y ya que estamos con la tontería de leer 50 libros en un año, os diré cuales son mis últimas adquisiciones que estoy leyendo ahora mismo.
Me estoy leyendo cuatro libros (últimamente me he aficionado bastante a la multilectura) que son:

Lost Cosmonaut - Daniel Kalder. Este libro me lo ha dejado Carlos por su relación con nuestro viaje a tierras inhóspitas de Noruega. El libro cuenta unos viajes que hace un inglés que vive en Moscú a distintas repúblicas rusas desconocidas para occidente. Está lleno de anécdotas, a veces graciosas, la mayoría patéticas. Muy recomendable.

Antología poética - Mario Benedetti. Hace tiempo que quería empezar a leer poesía, y como no soy un erudito en la materia aproveché la última vez que fui a mi pueblo para nombrar a mi primo mi mentor en este tema. Él me aconsejó comenzar leyendo a Benedetti, y ahí estoy. De momento la experiencia está siendo buena, un tipo de lectura en la que hay que poner de tu parte y no simplemente que te lo den todo ya pensado (tipo el estilo de mi archienemigo) que al final acaba siendo tan sorbe-cerebros como ver Salsa Rosa en la tele.

Nada - Carmen Laforet. Tenía ganas de leer este libro desde que me salió, hace ya tiempo, como pregunta en el Trivial. Cuando fui a comprar el de Benedetti aproveché para matar dos pájaros de un tiro. Es una novelilla corta ganadora del Premio Nadal. Ideal para llegar a los 50. (No como los tochos que me he leído últimamente.)

Graphics and GUIs with MATLAB - Patrick Marchand. Libro didáctico que leo (leo, no hojeo) para mi formación como creador de GUIs. Es algo necesario para mi trabajo, aunque también me interesa bastante a modo personal. Es lo que tiene trabajar en algo que te gusta.

Pues eso es todo de momento...