|
|
Línea 123: |
Línea 123: |
| * Creamos los métodos correspondientes en mono y banana: | | * Creamos los métodos correspondientes en mono y banana: |
| ** '''mono.comer()'''. Cuando el mono coma la banana mostrará durante unos ciclos (un segundo aprox.) otra imagen. | | ** '''mono.comer()'''. Cuando el mono coma la banana mostrará durante unos ciclos (un segundo aprox.) otra imagen. |
− | *** Modifica el '''__init__''' para que se cargue la imagen '''mono_contento.png''' al crear el mono.
| + | ** Modifica el '''__init__''' para que se cargue la imagen '''mono_contento.png''' al crear el mono. |
− | *** Crea un atributo self.comiendo = 0 que usaremos para saber si está comiendo el mono. Cuando el mono coma una banana, le pondremos una cantidad (30 ciclos por ejemplo). El método update tendrá que ir disminuyendo esta cantidad hasta el 0.
| + | ** Crea un atributo '''self.comiendo <nowiki>=</nowiki> 0''' que usaremos para saber si está comiendo el mono. Cuando el mono coma una banana, le pondremos una cantidad (30 ciclos por ejemplo). El método update tendrá que ir disminuyendo esta cantidad hasta el 0. |
− | *** Modifica el método draw para que muestre la imagen del mono normal o la que está comiendo, según el atributo self.comiendo.
| + | ** Modifica el método '''draw''' para que muestre la imagen del mono normal o la que está comiendo, según el atributo self.comiendo. |
| + | ** Cuando la banana sea comida, hay que reinicializarla para que vuelva a salir por la parte superior de la pantalla (en posición x aleatoria) |
| }} | | }} |
| | | |
Última revisión de 21:24 30 ago 2011
Creación de videojuegos con Python
Introducción al uso de Pygame
Ejercicio 1. Preparación del entorno
Ejercicio 1. Preparación del entorno
- Ejecuta el starter para comprobar que has descargado bien los archivos:
$ python juego_mono.py
- Tienes que ver una pantalla negra
- Ponle un título a la ventana:
pygame.display.set_caption('Mono zampador')
- Carga la imagen de fondo (imagenes/selva.png)
- Recuerda descomentar la línea del blit:
pantalla.blit(fondo, (0,0))
|
Ejercicio 2. Creación de sprite Mono
Ejercicio 2. Creación de sprite Mono
Nuestro juego va a tener 2 personajes (sprites):
En un archivo auxiliar (personajes.py) crearemos los sprites. Desde el programa principal importaremos nuestros sprites y los utilizaremos.
|
Ejercicio 3. Creación de sprite Banana
Ejercicio 3. Creación de sprite Banana
Haz lo mismo con el sprite Banana.
|
Ejercicio 4. Movimiento Banana
Ejercicio 4. Movimiento Banana
Vamos a escribir el método update de la Banana:
- La banana tendrá un movimiento vertical
- Cada ciclo iremos aumentado el valor de y (3 pixeles por ejemplo)
- Puedes seguir utilizando center o top ...
- Cuando la banana llega abajo, vuelve a salir por la parte superior.
- Modificamos el métido de iniciar. La x no será siempre el centro de la pantalla, sino un número aleatorio entre 0 y el ancho de la pantalla.
- Usa random.randint
- Ten cuidado con el mínimo y máximo para que la banana no quede fuera de la pantalla.
- Introduce la llamada al método update de banana en la zona de actualizar sprites del bucle principal.
- Comprueba el resultado.
|
Ejercicio 5. Movimiento Mono
Ejercicio 5. Movimiento Mono
El mono se moverá horizontalmente utilizando el teclado. Escribe el método update del mono:
- Le pasaremos como parámetro las teclas que están pulsadas en el ciclo.
- Si está pulsada la tecla flecha izquierda, moveremos su rectángulo a la izquierda 5 pasos.
# Update de la clase Mono def update(self, keys): if keys[K_LEFT]: self.rect.centerx -= 5 # podemos usar un atributo: self.velocidad elif keys[K_RIGHT]: self.rect.centerx += 5
- Tendrás que corregirlo para que el mono no se pueda salir de la pantalla.
- Introduce la captura de las teclas en el bucle principal en la zona de captura de eventos:
keys = pygame.key.get_pressed()
- Llama al método update de Mono en la zona de actualizar del bucle principal
- Comprueba el funcionamiento del programa.
|
Ejercicio 6. Detección de colisiones
Ejercicio 6. Detección de colisiones
Vamos a detectar cuándo el mono toca una banana (el mono come una banana :)). Cuando detectemos la colisión, lanzaremos los métodos correspondientes en mono y en banana.
- Añade al programa principal la detección de la colisión:
if pygame.sprite.collide_circle(mono, banana):
mono.comer()
banana.comida()
- Creamos los métodos correspondientes en mono y banana:
- mono.comer(). Cuando el mono coma la banana mostrará durante unos ciclos (un segundo aprox.) otra imagen.
- Modifica el __init__ para que se cargue la imagen mono_contento.png al crear el mono.
- Crea un atributo self.comiendo = 0 que usaremos para saber si está comiendo el mono. Cuando el mono coma una banana, le pondremos una cantidad (30 ciclos por ejemplo). El método update tendrá que ir disminuyendo esta cantidad hasta el 0.
- Modifica el método draw para que muestre la imagen del mono normal o la que está comiendo, según el atributo self.comiendo.
- Cuando la banana sea comida, hay que reinicializarla para que vuelva a salir por la parte superior de la pantalla (en posición x aleatoria)
|
Ejercicio 7. Puntuaciones
Ejercicio 7. Puntuaciones
Crea un sistema de puntuaciones.
def __init__(self):
self.puntos = 0
self.font = pygame.font.Font('fuentes/Yukon_Font.ttf', 42)
- Crea un método suma_punto()
- Crea el método draw()
def draw(self):
texto = font.render("Puntos: %d" % puntos, 1, (255, 124, 0)) # Texto, antialiasing, color en RGB
self.scr.blit(texto, (10, 10))
- Inserta en el código del juego las llamadas necesarias:
- Creación del objeto Marcador
- Sumar puntos cuando mono come banana
- Draw en cada ciclo (aunque no haya comido)
|
Ejercicio 8. Vidas
Ejercicio 8. Vidas
Crea un objeto similar para las vidas:
- Al principio tiene 3 vidas.
- Cada vez que cae una banana al suelo, resta una vida
- Tendrás que hacer varias modificaciones en el código principal del juego.
|
Ejercicio 9. Sonidos
Ejercicio 9. Sonidos
Añade sonidos a los objetos mono y banana.
- Cuando el mono come, lanzará el sonido come_fruta.wav. Tienes una utilidad para cargar los sonidos:
self.sonido_comer = cargar_sonido("come_fruta.wav")
- El sonido se ejecuta así:
- Cuando cae la banana, lanzará el sonido pierde_vida.wav
- Puedes añadir una música de fondo. Tienes una ayuda play_music.
- Cuidado con los sonidos. No debes cargarlos en el bucle principal.
|
Ejercicio 10. Control de estados: Inicio, juego, fin
Ejercicio 10. Control de estados: Inicio, juego, fin
El juego tendrá tres estados: inicio, juego y fin.
- Si estado es inicio, mostrará un mensaje en la pantalla con el nombre del juego y sólo responde a los eventos de salir y enter (iniciar juego).
- Si estado es juego, funcionará el juego como hemos visto hasta ahora.
- Si estado es fin, muestra el mensaje final Game Over y sólo responde a los eventos de salir y enter (volver a jugar)
- Tendrás que modificar el bucle principal. Ahora según el estado tendrá que realizar una actividad diferente.
|