¿Alguna vez te has planteado crear un videojuego para tu móvil Android? Aunque pueda parecer cosa de expertos, la verdad es que gracias a la herramienta MIT App Inventor, cualquiera con un poco de ayuda puede lanzarse a crear sus propias ideas. ¿Te atreves?

Antes de nada, para los que no conozcan aún la herramienta, hace algún tiempo os hablamos de ella. Te aconsejo que te pases por este post y veas un poco estas diapositivas.

Ahora sí, ¡empezamos!

Al ver el juego del Hour of Code propuesto por Code.org se nos ocurrió realizar algo similar pero en un formato de ‘app’ para móviles. Realmente el juego ce Code.org está muy completo, por lo que, para empezar, lo simplificaríamos mucho. Este es el objetivo que vamos a intentar conseguir:

Appinventor_bird

La idea es hacer una aplicación que permita al pájaro llegar al cerdo. Como de momento queremos algo que funcione (más adelante podrás hacerlo más atractivo), vamos a usar una serie de botones simples:

  • Instrucción de movimiento: derecha y abajo. Al ir pulsando estos botones se va almacenando el camino que creamos que va a llevar al pájaro hasta el cerdo.
  • Ejecutar. Una vez «programado»  el pájaro con los botones anteriores necesitaremos ejecutar para comprobar si el camino que le hemos indicado al pájaro es correcto.
  • Limpiar. Servirá para eliminar el camino que tengamos hasta ese momento.

Como veis, el funcionamiento es muy simple, aunque nos sirve perfectamente para introducirnos en la creación de aplicaciones para móviles.

¿Qué necesitamos entonces para empezar? Pues lo primero será crear un nuevo proyecto en MIT App Inventor 2.

Appinventor_Newproyect

Y luego tendremos que ir añadiendo los distintos elementos de los que se va a componer el juego:

  • Canvas: para quAppinventor_componentse los objetos se puedan mover por la pantalla. Se encuentra en «Drawing and Animation». Para agregarlo tan solo tendremos que arrastrarlo hasta la pantalla. En las propiedades dejamos todo tal y como está menos el Width y el Height, que los estableceremos a «Fill parents».
  • ImageSprite: son un tipo especial de imágenes que pueden moverse  a través del canvas. Añadiremos 5 elementos de este tipo dentro del canvas anterior. Para cada uno tendremos que establecerle la propiedad «Picture» con la imagen correspondiente y el tamaño: 50×50 pixeles.
  • Label: como su nombre indica, es una etiqueta. La utilizaremos en esta primera versión para ir encadenando dos posibles letras: A, para indicar abajo y D para la derecha. En sus propiedades únicamente dejaremos en blanco el «Text».
  • HorizontalArrangement: nos servirá para poder colocar todos los botones alineados horizontalmente. Se encuentra dentro del «Layout». No tocamos sus propiedades.
  • Button: serán los botones descritos anteriormente. Necesitamos 4 y los arrastraremos de forma ordenada dentro del elemento anterior para que estén organizados. Para cada uno tendremos que cambiarle la propiedad «Text» adecuadamente. Más adelante podríamos asignarles imágenes, para que los más pequeños que aún no sepan leer puedan usarlo.

Y así es como diseñamos nuestra app, ¿fácil verdad?. Ahora nos queda la segunda parte: programarla. Para ello nos pasaremos a la parte de «Blocks» (en la esquina superior derecha).

Lo primero que haremos será crearnos una variable para ir almacenando la lista de instrucciones de movimiento. Como comentamos antes, en esta variable almacenaremos los valores: «A» y/o «D».

Appinventor_variable

 

A continuación programaremos los botones de movimiento:

 

Appinventor_instrucciones

 

Como se puede ver, su funcionamiento es casi idéntico y consta de dos pasos:

  • Almacenamos, en la variable global, el carácter correspondiente: «A» o «D»
  • Cambiamos el texto del elemento etiqueta y le añadimos (join) el carácter anterior. Esto nos servirá para ir visualizando en todo momento las instrucciones que hemos ido introduciendo para conseguir el camino hasta el cerdo.

Programaremos también el botón limpiar de la siguiente forma:

Appinventor_limpiar

 

El funcionamiento es parecido al de los botones anteriores, aunque en este caso tendremos que limpiar la variable y la etiqueta, en vez de acumular nada. También es necesario situar al pájaro en la posición correcta de salida.

Y por último, nos quedaría el botón de ejecutar:

Appinventor_ejecute

 

Este es el más complejo, aunque creo que con un poco de explicación se entiende bien:

  • Primero, situamos el pájaro en la posición de inicio.
  • A continuación vamos a ir recorriendo la variable global en la que tenemos almacenado el camino seleccionado.
  • Para cada elemento comprobaremos si se trata de una «A», en cuyo caso moveremos al pájaro en el eje Y, aumentando su posición en 50 pixeles (el tamaño de cada bloque). En otro caso será una «D», por lo que tendremos que mover al pájaro en el eje X, aumentando su posición en los mismos pixeles.

Por último ya solo nos quedaría pasar la aplicación al móvil o bien ejecutarla en un emulador y comprobar que todo funciona correctamente.

Aquí os dejo la aplicación que hemos realizado hasta ahora (más info):

  • Versión empaquetada y lista para que puedas probarla en tu tablet o smartphone. Descargar.
  • Versión código fuente, para que puedas importarla y seguir modificándola. Descargar

Esta primera versión es quizás demasiado básica , ¿no crees?. Quedaría mucho trabajo e imaginación por delante. ¿Te atreves a continuar?

Algunas ideas para mejorar el juego:

  • Introducir más bloques para que quede la pantalla completa.
  • Cambiar el texto de los botones por imágenes.
  • En vez de usar un elemento etiqueta para mostrar el camino seleccionado, ¿podrías ir mostrando flechas?
  • Se podrían cambiar las instrucciones «Abajo» y «Derecha» por: «Mover», «Giro derecha» y «Giro izquierda».
  • Al ejecutar, hacer el que pájaro vaya dando saltos a las distintas posiciones hasta llegar al destino.
  • Controlar si el pájaro choca con un bloque.
  • Incluir nuevos elementos que tenga que esquivar.

Y como siempre, no te olvides de contarnos tu experiencia.