¿Que es LibGDX?
LibGDX es un framework escrito en java y C/C++ para el desarrollo de videojuegos, es multiplataforma (Windows, Linux, Mac, Android, IOS, GWT) , permite programar aplicaciones para celulares con android como también juegos de escritorio, función útil cuando no se quiere probar el juego en el lento emulador de android.
Cuenta con módulos para interactuar con gráficos, sonidos, eventos de teclado y dispositivos táctiles, OpenGL ES 1.x y 2.0. Sistema 2D y pronto soporte 3D.
Hola mundo con LibGDX
LibGDX nos permite crear nuestro juego en un proyecto de escritorio y después migrarlo a Android, en el sitio oficial (en ingles) puedes ver un ejemplo de como trabajar de esta forma, sin embargo para salir de lo común, en este tutorial, crearemos nuestro infaltable «Hello World» directamente en una aplicación Android, necesitamos:
– Eclipse Indigo con Android instalado y configurado.
– LibGDX, descarga y descomprime en algún lugar de tu pc la versión Nightly Builds
– Si cuenta con la posibilidad, un celular inteligente conectado a tu pc, caso contrario, prepárese a sufrir con el emulador.
Nivel: Java intermedio, Android intermedio
Tiempo: 15 minutos
Proyecto Eclipse
1.Crea un nuevo Application Android Project con la siguiente configuración:
Application Name: LibGDXHello
Project Name: LibGDXHello
Package Name: com.bolivia.libgdxhello
Activity: Blank Activity
Activity Name: MainActivity.java
Layout Name: activity_main.xml
2. Ve al directorio donde tiene LibGDX y copia los siguientes archivos:
– gdx.jar
– gdx-backend-android.jar
– armeabi (carpeta y contenido)
– armeabi-v7a (carpeta y contenido)
y colócalos en la carpeta LIBS/ del proyecto
Clic derecho sobre el proyecto -> Refresh para actualizar el proyecto.
3. Clic derecho sobre el proyecto Build Path -> Configure Build Path... -> Pestaña LIBRARIES -> Add Jars
Busque las librerías gdx.jar y gdx–backend-android.jar en el proyecto, seleccione -> OK -> OK
4. Pintaremos una imagen a modo de «Hola Mundo» 🙂 perdone mi nacionalismo al usar mi tricolor, usted esta en la libertad de usar la imagen que desee, siempre y cuando esta sea múltiplo de 2. 🙂
La imagen se llama bandera.jpg, debe colocarla en la carpeta ASSETS
5. Crea una clase Hello.java en el paquete donde tenemos nuestro MainActivity.java.
Hasta este momento debemos tener esto en nuestro proyecto:
6. Vamos ahora con el código.
La clase Hello.java es nuestro juego en si, y se extiende ApplicationListener, entonces implementa una serie de métodos que los iremos viendo y explicando en futuros posts. Por el momento, hacemos uso de create() para iniciar los objetos y de render() para pintar la textura.
Hello.java
package com.bolivia.libgdxhello; import com.badlogic.gdx.ApplicationListener; import com.badlogic.gdx.Gdx; import com.badlogic.gdx.graphics.GL10; import com.badlogic.gdx.graphics.Texture; import com.badlogic.gdx.graphics.g2d.SpriteBatch; public class Hello implements ApplicationListener{ private SpriteBatch batch; private Texture texture; float alto; @Override public void create() { //obtiene alto de pantalla alto = Gdx.graphics.getHeight(); //para dibujar texturas se hace uso de SpriteBatch batch = new SpriteBatch(); //se carga la imagen de la carpeta ASSETS texture = new Texture( Gdx.files.internal("bandera.jpg")); } @Override public void dispose() { } @Override public void pause() { } @Override public void render() { //se limpia pantalla Gdx.gl.glClear(GL10.GL_COLOR_BUFFER_BIT); //pinta textura batch.begin(); batch.draw(texture, 20, alto/2); batch.end(); } @Override public void resize(int arg0, int arg1) { } @Override public void resume() { } }
– Para implementar esta clase en nuestra clase MainActivity.java debemos cambiar el extends Activity por extends AndroidApplication.
A continuación dejo la MainActivity original y la modificada para que se estudie los cambios.
MainActivity Original
package com.bolivia.libgdxhello; import android.os.Bundle; import android.app.Activity; import android.view.Menu; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
MainActivity Modificado
package com.bolivia.libgdxhello; import com.badlogic.gdx.backends.android.AndroidApplication; import android.os.Bundle; public class MainActivity extends AndroidApplication { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); initialize( new Hello(), false ); } }
7. Nuestro Hola Mundo esta listo, ejecuta y debes ver algo como esto:
Descarga el proyecto LibGDXHello en este enlace económico
Enjoy! 🙂
En este tutorial se muestran los pasos para crear una animación sencilla utilizando Java2d y el IDE Netbeans. La animaci[...]
SDKMAN! es una herramienta para la administración de versiones paralelas de varios programas de desarrollo de software c[...]
Dando respuesta a una interrogante sobre el como crear objetos en tiempo de ejecución y como manipular estos, desarrolle[...]
Este post es la continuación del tutorial «Generador de código para Netbeans« en donde vimos como crear un modulo para N[...]
Java 8 trae consigo una nueva versión del motor de JavaScript llamada Nashorn, este motor introduce mejoras de rendimien[...]
En este tutorial realizaremos una introducción al diseño de interfaces gráficas en JavaFX y Scene Builder, así también v[...]