¿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! 🙂
¿Que haremos? Crearemos una aplicación en Visual Studio, la cual hará uso de una webcam para capturar el video en frames[...]
El archuivo helpers.php en Laravel contiene funciones globales de PHP los cuales se pueden utilizar en cualquier parte d[...]
Un Tile o azulejo, es una parte seccionada de una imagen, por ejemplo la imagen de abajo (chica anime) esta dividida en[...]
En este post personalizaremos una tabla JTable Swing para pintar una imagen de fondo y darle un poco de estilo al e[...]
En este segundo post sobre Android y SQLite, veremos el uso de los métodos de gestión de base de datos más utilizados, e[...]
Segunda parte del tutorial «Crea un servicio web REST con PHP y MYSQL«, en esta segunda y ultima parte se completara la[...]