Esta es la traducción y actualización del tutorial que escribí para Kirupa sobre la creación de un Disparador Vertical en Flash.
Por cierto, cuando hice dicho tutorial, en el 2005, el Disparador Vertical (o Vertical Shooter en inglés) era considerado un género de video-juegos aunque en estos días es considerado una sub-categoría de los disparadores en general.
En este tutorial crearémos un juego en el que un caballero tiene que matar los dragones que aparecen a un lado de la pantalla. Este tutorial es más bien una explicación del código y no el desarrollo completo del juego, o sea, no tendrá 'vidas' ni muchas otras cosas necesarias para que sea un juego completo.
El siguiente flash es un ejemplo del disparador vertical que haremos. Haz clic dentro de la animación para que tenga el foco. Usa las teclas izquierda y derecha para mover al caballero, y presiona la tecla arriba para disparar flechas.
Preparación de los gráficos
En flash, crearemos un .fla que utilizaremos solamente para guardar los assets; escribiremos todo el código en una clase externa. Este tutorial no es sobre programación avanzada por lo tanto el código que escribiremos será muy simple y facil de entender.
Necesitamos 3 assets, un dragón, una flecha y el caballero. Agregaremos un fondo pero solo para que el juego en este tutorial no se vea tan aburrido.
El dragón lo hice en Macromedia Freehand MX (si, es algo viejo) y he lo he importado a Flash, al archivo que tendrá nuestros assets. Este es un acercamiento a dicho dragón:
Ya que fue creado originalmente usando vectores, este acercamiento permite ver algunos detalles. En flash, lo he convertido en MovieClip y sus coordenadas son 0, 0 conocido como 'el orígen' (cero en x y cero en y).
La flecha la dibujé en Adobe Photoshop y la guardé como .png. Este es un acercamiento a la flecha:
Al igual que el dragón, he convertido la flecha en MovieClip y sus coordenadas son similares, se encuentra en el orígen 0, 0.
El último asset es el caballero. Este es un poco mas complejo ya que esta formado por dos movieclips, el cuerpo y las piernas, eso es porque hay animaciones en ambos y correrán dependiendo de los eventos que sucedan en la aplicación.
Los gráficos tambien fueron creados en Macromedia Freehand MX pero podrian haber sido creados en cualquier otro programa de diseño incluyendo el mismo Flash. Este es un acercamiento al caballero a un 150%:
En la imagen, el movieclip cuerpo está seleccionado, dicho clip tiene como nombre de instancia 'cuerpo', el clip de las piernas tiene como nombre de instancia 'piernas'. Dentro de cada clip hay pequeñas animaciones que simulan movimiento de piernas y del brazo disparando la flecha.
Por el momento lo único que necesitamos en el escenario sera el caballero. Pasemos al código.
Código del Disparador Vertical
Como mencioné antes, el código lo escribiremos en una clase. Podríamos ponerlo en el primer fotograma de flash, pero la idea es evitar poner código en el .fla para promover la separación de ocupaciones, aunque a muchos les de un poco de miedo, usar clases no tiene nada de especial, es solo aprender un par de palabras clave y listo el pollo.
Como ejemplo, podríamos detener la animación de las piernas y la del cuerpo si ponemos esto en la linea del tiempo:
Código :
caballero.cuerpo.stop(); caballero.piernas.stop();
También lo podríamos poner en una función:
Código :
function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } // y llamar la función despues de declararla: detenerAnimaciones();
O lo podríamos poner en una clase que es lo que haremos a continuación. En Flash creamos un nuevo documento Actionscript File, dicho documento estará en blanco por defecto.
Este es el código que pondremos:
Código :
package { import flash.display.MovieClip; public class DisparadorVertical extends MovieClip { public function DisparadorVertical() { detenerAnimaciones(); } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } } }
Package y otras palabras clave están explicadas en esta introducción a ActionScript 3. Todas las clases pertenecen a un package, todas tienen nombre de clase, en este caso la nuestra se llama DisparadorVertical y extiende MovieClip ya que cualquier pelicula flash, su escenario y la linea del tiempo principal, es un MovieClip.
Guardamos nuestra clase como DisparadorVertical.as al lado del .fla y agregamos dicha clase como la 'document class' en las propiedades de la pelicula flash como se muestra a continuación:
Moviendo al Personaje
El movimiento del heroe en los disparadores verticales esta limitado al eje x, o sea, los personajes se mueven horizontalmente. Agreguemos el código para mover al caballero.
Código :
stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion);
Es un 'listener' donde el escenario (stage) escucha cuando el jugador presiona cualquier tecla, en dado caso, llamará a la función revisarInteraccion.
Código :
private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { caballero.x -= 5; } else if(evento.keyCode == Keyboard.RIGHT) { caballero.x += 5; } }
La función revisarInteraccion revisa si la tecla presionada es la flecha derecha o izquierda, si es asi, el caballero se movera 5 pixeles en el eje x.
El código actualizado es:
Código :
package { import flash.display.MovieClip; import flash.ui.Keyboard; import flash.events.KeyboardEvent; public class DisparadorVertical extends MovieClip { private const PASOS : uint = 5; public function DisparadorVertical() { detenerAnimaciones(); agregarListeners(); } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } private function agregarListeners() : void { stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion); } private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { caballero.x -= PASOS; } else if(evento.keyCode == Keyboard.RIGHT) { caballero.x += PASOS; } } } }
También he agregado la constante PASOS cuyo valor es un numero entero (int) igual a 5. Es el numero de pixeles que el caballero debe moverse. Esto es considerado buena practica ya que al tener el valor declarado en una constante, es facil encontrarlo y actualizarlo.
El juego actualizado quedaría asi:
El caballero se mueve hacia ambos lados, el problema es que no mueve las piernas y se sale del escenario
Para arreglar esos 'bugs', agreguemos límites y movimiento a las piernas.
Declaramos los límites como constantes:
Código :
private const LIMITE_IZQUIERDA : uint = 0; private const LIMITE_DERECHA : uint = 475;
Al declarar valores constantes es considerado otra buena practica, que sus nombres sean escritos con letras mayúsculas.
El valor de LIMITE_DERECHA es 475 ya que es el ancho de nuestra pelicula menos el ancho del caballero (550 menos 75 pixeles).
Necesitamos un nuevo listener para que el escenario escuche cuando cualquier tecla es liberada y cuando suceda, llame a una función detenerCaballero para que la animación de las piernas del caballero regresen al fotograma 1.
Código :
stage.addEventListener(KeyboardEvent.KEY_UP, detenerCaballero);
Y la función detenerCaballero es:
Código :
private function detenerCaballero(evento : KeyboardEvent) : void { caballero.piernas.gotoAndStop(1); }
Agreguemos también los límites.
Código :
private function moverCaballero(distancia : int) : void { var nuevaPosicion : int = caballero.x + distancia; if(nuevaPosicion > LIMITE_IZQUIERDA && nuevaPosicion < LIMITE_DERECHA) { caballero.x += distancia; caballero.piernas.play(); } else { detenerCaballero(); } }
La función moverCaballero necesita un número entero como parámetro que es la distancia que nuestro caballero se moverá. Podemos llamarla desde revisarInteraccion y pasarle PASOS como parametro con valor negativo o positivo. Revisamos también si la nueva posición del caballero esta dentro de los limites que hemos declarado y si es asi, movemos al caballero, de lo contrario llamamos a la función detenerCaballero.
Este es el código actualizado:
Código :
package { import flash.display.MovieClip; import flash.ui.Keyboard; import flash.events.KeyboardEvent; public class DisparadorVertical extends MovieClip { private const PASOS : uint = 5; private const LIMITE_IZQUIERDA : uint = 0; private const LIMITE_DERECHA : uint = 475; public function DisparadorVertical() { detenerAnimaciones(); agregarListeners(); } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } private function agregarListeners() : void { stage.addEventListener(KeyboardEvent.KEY_UP, detenerCaballero); stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion); } private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { moverCaballero(-PASOS); } else if(evento.keyCode == Keyboard.RIGHT) { moverCaballero(PASOS); } } private function moverCaballero(distancia : int) : void { var nuevaPosicion : int = caballero.x + distancia; if(nuevaPosicion > LIMITE_IZQUIERDA && nuevaPosicion < LIMITE_DERECHA) { caballero.x += distancia; caballero.piernas.play(); } else { detenerCaballero(); } } private function detenerCaballero(evento : KeyboardEvent = null) : void { caballero.piernas.gotoAndStop(1); } } }
Y este es el juego actualizado:
Agregando el fondo
Como mencioné antes, para que el ejemplo no se vea tan aburrido, le agregaremos un fondo. Al igual que el dragón y el caballero, el fondo esta hecho en Macromedia Freehand MX e importado a flash como vectores, aunque en este caso no es necesario convertirlo a MovieClip, con solo agregarlo a nuestra película es suficiente. Para que cubra toda la película, el tamaño es 550 x 400 pixeles y sus coordenadas son 0, 0.
Disparando
Nuestro personaje se mueve hacia la izquierda y hacia la derecha sin salirse del escenario. El caballero ya esta listo para hacer su siguiente tarea: disparar flechas.
Antes de seguir con el código, veamos un poco de historia. El Disparador Vertical es una de las categorias de video-juegos mas viejas que existen y en aquellas doradas épocas cuando los video-juegos nacieron, las consolas tenían muchisimas limitaciones y por ende no era posible disparar mas de una sola vez cada cierto tiempo, usualmente se esperaba a que el disparo llegase al final de la pantalla o que le pegara a algo para que el jugador pudiese disparar nuevamente.
Siguiendo con el desarrollo del juego, he agregado una instancia de la flecha en el escenario y le he puesto 'flecha' como nombre de instancia. El código lo adaptaremos un poco para que el caballero dispare la flecha:
Código :
package { import flash.display.MovieClip; import flash.ui.Keyboard; import flash.events.KeyboardEvent; import fl.transitions.Tween; import fl.transitions.easing.*; public class DisparadorVertical extends MovieClip { private var estaDisparando : Boolean; private const PASOS : uint = 5; private const ANCHO_DEL_CABALLERO : uint = 75; private const LIMITE_IZQUIERDA : uint = 0; private const LIMITE_DERECHA : uint = 475; public function DisparadorVertical() { detenerAnimaciones(); agregarListeners(); } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } private function agregarListeners() : void { stage.addEventListener(KeyboardEvent.KEY_UP, detenerCaballero); stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion); } private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { moverCaballero(-PASOS); } else if(evento.keyCode == Keyboard.RIGHT) { moverCaballero(PASOS); } if(evento.keyCode == Keyboard.UP) { if(!estaDisparando) dispararFlecha(); } } private function moverCaballero(distancia : int) : void { var nuevaPosicion : int = caballero.x + distancia; if(nuevaPosicion > LIMITE_IZQUIERDA && nuevaPosicion < LIMITE_DERECHA) { caballero.x += distancia; caballero.piernas.play(); } else { detenerCaballero(); } } private function detenerCaballero(evento : KeyboardEvent = null) : void { caballero.piernas.gotoAndStop(1); } private function dispararFlecha() : void { estaDisparando = true; caballero.cuerpo.play(); flecha.x = caballero.x + ANCHO_DEL_CABALLERO / 2; var disparar : Tween = new Tween(flecha, "y", None.easeIn, caballero.y, -50, 1, true); } } }
La variable estaDisparando es un booleano, solamente acepta dos valores, true y false (verdadero y falso) y al declararlo es falso por defecto. Esta variable nos ayudará a evitar que el caballero dispare muy seguido.
ANCHO_DEL_CABALLERO es un número entero que nos ayudará a saber donde posicionar la flecha.
La función revisarInteraccion ha sido actualizado para que detecte si la tecla 'arriba' ha sido presionada y si de ser asi, revisa si el caballero no esta disparando para hacerlo disparar.
La función dispararFlecha cambia el valor de estaDisparando para que el caballero no dispare nuevamente. Posiciona la flecha e inicia la animación del disparo y usando la clase Tween, dispara la flecha hacia -50 para que desaparezca de la pantalla.
Para mayor información sobre la clase Tween, te aconsejo leer este tip.
Ahora tenemos otro problema, no es posible disparar mas de una flecha! El código para hacer que el caballero pueda disparar mas flechas es el siguiente:
Código :
package { import flash.display.MovieClip; import flash.ui.Keyboard; import flash.events.KeyboardEvent; import fl.transitions.Tween; import fl.transitions.easing.*; import fl.transitions.TweenEvent; public class DisparadorVertical extends MovieClip { private var estaDisparando : Boolean; private const PASOS : uint = 5; private const ANCHO_DEL_CABALLERO : uint = 75; private const LIMITE_IZQUIERDA : uint = 0; private const LIMITE_DERECHA : uint = 475; public function DisparadorVertical() { detenerAnimaciones(); agregarListeners(); } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } private function agregarListeners() : void { stage.addEventListener(KeyboardEvent.KEY_UP, detenerCaballero); stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion); } private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { moverCaballero(-PASOS); } else if(evento.keyCode == Keyboard.RIGHT) { moverCaballero(PASOS); } if(evento.keyCode == Keyboard.UP) { if(!estaDisparando) dispararFlecha(); } } private function moverCaballero(distancia : int) : void { var nuevaPosicion : int = caballero.x + distancia; if(nuevaPosicion > LIMITE_IZQUIERDA && nuevaPosicion < LIMITE_DERECHA) { caballero.x += distancia; caballero.piernas.play(); } else { detenerCaballero(); } } private function detenerCaballero(evento : KeyboardEvent = null) : void { caballero.piernas.gotoAndStop(1); } private function dispararFlecha() : void { estaDisparando = true; caballero.cuerpo.play(); flecha.x = caballero.x + ANCHO_DEL_CABALLERO / 2; var disparar : Tween = new Tween(flecha, "y", None.easeIn, caballero.y, -50, 1, true); disparar.addEventListener(TweenEvent.MOTION_FINISH, flechaDisparada); } private function flechaDisparada(evento : TweenEvent) : void { estaDisparando = false; } } }
Por cierto, no son mas flechas, es la misma. Soy un mentiroso
Lo único que he agregado es un 'listener' al tween disparar que escucha cuando el movimiento ha terminado y llama a la función flechaDisparada.
La función flechaDisparada solamente regresa el valor del booleano a 'false' que nos permite volver a disparar otra flecha (ok, la misma flecha...).
El Enemigo
Nuestro caballero puede desplazarse y ya dispara flechas pero disparar flechas al aire no tiene mucho sentido. Tenemos que agregar algún enemigo asi que agregaremos un dragón.
Al igual que con el resto de los assets, lo mas recomendable es llamar el asset del dragón desde la biblioteca pero como la idea de este tutorial es hacerlo de una forma básica, basta con poner manualmente una instancia del dragón en el escenario y llamarlo 'dragon'.
Para mover al dragón utilizamos un simple Tween:
Código :
var dragonVolando : Tween = new Tween(dragon, "x", None.easeIn, 550, -dragon.width, 5, true);
Desde 550, que es el ancho de la pelicula, hasta -dragon.width que es el valor negativo del ancho del dragón, o sea, fuera del escenario. Se tardará 5 segundos en cruzar todo el escenario.
Ese código lo pondremos dentro de una función que llamaremos desde el constructor de la clase:
Código :
private function iniciarVuelo(evento : TweenEvent = null) : void { var dragonVolando : Tween = new Tween(dragon, "x", None.easeIn, 550, -dragon.width, 5, true); }
Para aparentar que un nuevo dragón aparece a la derecha cuando el anterior ha llegado al otro lado, comenzaremos el tween nuevamente llamando a la misma función iniciarVuelo(). Para ello agregamos un listener al tween dragonVolando en el evento MOTION_FINISH, o sea, cuando termine el movimiento.
Código :
dragonVolando.addEventListener(TweenEvent.MOTION_FINISH, iniciarVuelo);
Asi se crea un bucle con el que engañaremos a los jugadores haciendoles creer que hay miles de dragones.
Nuevo problema: el dragón no toma nota de la flecha disparada. Solución: agregar un detector de colisiones, o sea, una función que nos avisará si el dragón ha sido alcanzado por la flecha. El listener lo agregamos también al tween 'dragonVolando', que escuchará cada vez que el dragón se mueva un poco. El MOTION_CHANGE funciona mas o menos como el ENTER_FRAME de un tween.
Código :
dragonVolando.addEventListener(TweenEvent.MOTION_CHANGE, detectarDisparo);
El detector de colisiones se llama detectarDisparo donde usaremos el método hitTestObject para ver si un objeto a chocado con otro.
Código :
private function detectarDisparo(evento : TweenEvent) : void { if(flecha.hitTestObject(dragon)) { iniciarVuelo(); } }
Para evitar fugas de memoria innecesarias, declararemos el tween dragonVolando en nuestra clase y no dentro de la función porque sino, una nueva variable dragonVolando va a ser creada cada vez que llamemos a dicha función.
El código final es:
Código :
package { import flash.display.MovieClip; import flash.ui.Keyboard; import flash.events.KeyboardEvent; import fl.transitions.Tween; import fl.transitions.easing.*; import fl.transitions.TweenEvent; public class DisparadorVertical extends MovieClip { private var estaDisparando : Boolean; private var dragonVolando : Tween; private const PASOS : uint = 5; private const ANCHO_DEL_CABALLERO : uint = 75; private const LIMITE_IZQUIERDA : uint = 0; private const LIMITE_DERECHA : uint = 475; public function DisparadorVertical() { iniciarVuelo(); iniciarDragon(); detenerAnimaciones(); agregarListeners(); } private function iniciarVuelo() : void { dragonVolando = new Tween(dragon, "x", None.easeIn, 550, -dragon.width, 5, true); } private function iniciarDragon() : void { dragonVolando.stop(); moverDragon(); } private function moverDragon(evento : TweenEvent = null) : void { dragonVolando.start(); dragonVolando.addEventListener(TweenEvent.MOTION_FINISH, moverDragon); dragonVolando.addEventListener(TweenEvent.MOTION_CHANGE, detectarDisparo); } private function detectarDisparo(evento : TweenEvent) : void { if(flecha.hitTestObject(dragon)) { iniciarDragon(); } } private function detenerAnimaciones() : void { caballero.cuerpo.stop(); caballero.piernas.stop(); } private function agregarListeners() : void { stage.addEventListener(KeyboardEvent.KEY_UP, detenerCaballero); stage.addEventListener(KeyboardEvent.KEY_DOWN, revisarInteraccion); } private function revisarInteraccion(evento : KeyboardEvent) : void { if(evento.keyCode == Keyboard.LEFT) { moverCaballero(-PASOS); } else if(evento.keyCode == Keyboard.RIGHT) { moverCaballero(PASOS); } if(evento.keyCode == Keyboard.UP) { if(!estaDisparando) dispararFlecha(); } } private function moverCaballero(distancia : int) : void { var nuevaPosicion : int = caballero.x + distancia; if(nuevaPosicion > LIMITE_IZQUIERDA && nuevaPosicion < LIMITE_DERECHA) { caballero.x += distancia; caballero.piernas.play(); } else { detenerCaballero(); } } private function detenerCaballero(evento : KeyboardEvent = null) : void { caballero.piernas.gotoAndStop(1); } private function dispararFlecha() : void { estaDisparando = true; caballero.cuerpo.play(); flecha.x = caballero.x + ANCHO_DEL_CABALLERO / 2; var disparar : Tween = new Tween(flecha, "y", None.easeIn, caballero.y, -50, 1, true); disparar.addEventListener(TweenEvent.MOTION_FINISH, flechaDisparada); } private function flechaDisparada(evento : TweenEvent) : void { estaDisparando = false; } } }
Y este es el juego final:
El código, al igual que el juego, se puede mejorar muchisimo por ejemplo usando ENTER_FRAME para hacer que el caballero se mueva de una forma menos rara (en mi navegador se queda quieto por un momento y luego camina) pero como mencioné antes, este tutorial es solo un ejemplo básico de un disparador vertical.
Les dejo como tarea agregar puntuación que, por ejemplo, aumente 5 puntos cada vez que se le pegue al dragón.
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por Freddie el 17 de Junio de 2011
Por Jatrix13 el 17 de Junio de 2011
Por adan-2994 el 17 de Junio de 2011
Por Rafeo el 18 de Junio de 2011
Por Acreonte el 20 de Junio de 2011
Por antonionavajas el 21 de Junio de 2011
Para colisiones encontré una clase en esedeerre.com para colisiones ajustadas al píxel (el hitTestObject tiene en cuenta toda la "caja" del MC) que es muy interesante.
Lo que me extraña que no uses una clase Render() que controle lo que dices del ENTER_FRAME.
Pero vamos, es genial
Por Kinduff el 21 de Junio de 2011
Por Dashiel el 27 de Junio de 2011
Por kuky el 19 de Julio de 2011
Le dejo un abrazo!!!
Por monrack el 01 de Agosto de 2011
Por Acreonte el 01 de Agosto de 2011
monrack-blog :
Agrega un numero determinado de flechas y una variable para saber cuantas flechas has disparado:
Código :
En la funcion revisarInteraccion agregas otro condicional cuando revisas la tecla Keyboard.UP:
Código :
Y en la funcion dispararFlecha aumentas el numero de flechasDisparadas:
Código :
@Kuky, que tal todo? me alegra verte por aca tambien
Por lol el 18 de Agosto de 2011
Por nestorrente el 18 de Agosto de 2011
Sólo puedo poner 2 pegas (prácticamente insignificantes):
Por el resto, excelente tuto
Por Luis_ Matias_México el 29 de Agosto de 2011
No encuentro el link para bajarlo con todo y código
Urgeme
Por Luis_ Matias_México el 29 de Agosto de 2011
[email protected] o el del trabajo
[email protected]
Por Acreonte el 30 de Agosto de 2011
Por Yebi el 31 de Agosto de 2011
Hola, excelente tutorial. Podrias explciar como hacer para que aparesca el dragon con colores diferentes cada vez si cada 1 de los 3 dragones tiene un nombre de instancia diferente.... gracias de antemano
Por miguel el 10 de Septiembre de 2011
Por manuell el 16 de Septiembre de 2011
te agradesco mucho como no tienes idea
Por Andres el 10 de Febrero de 2012
Amigo, tengo una pregunta, cuando quiero pasarle el valor del puntaje a un cuadro de texto me sale el siguiente error
Error #1074: Lectura no permitida de la propiedad ::PUNTAJE de sólo lectura en myclase
Code:
puntaje.text = score;
Alguna idea, Muchas gracias por la ayuda!
Por Acreonte el 10 de Febrero de 2012
Tienes que convertir el numero a cadena de texto asi:
Código :
Sobre el error que te tira flash, no se donde tendras tu caja de texto (esta en el escenario?) quiza la has declarado como String y no como textfield? danos mas data porque estoy mas o menos a ciegas.
Por juaser el 11 de Febrero de 2012
Por Acreonte el 13 de Febrero de 2012
juaser-blog :
En
Código :
Cambia donde dice moverCaballero(...); por alguna variable booleana como 'estaCaminandoALaDerecha' o 'estaCaminandoALaIzquierda' y en el enterFrame revisas dicha variable y haces que camine como convenga.
Haz pruebas y nos avisas
Por juaser el 25 de Marzo de 2012
dragonVolando = new Tween(dragon, "x", None.easeIn, 550, -dragon.width, 5, true);
¿conoces alguna forma que haga que el 550 sea un numero aleatorio para que cambie la altura del dragon(claro que el numero tiene que tener "condiciones" para que no se salga de la pantalla) ?
gracias por tener el tiempo de leer esto y contestarme la anterior
Por elunico el 03 de Mayo de 2012
private function detenerAnimaciones() : void
{
caballero.cuerpo.stop();
caballero.piernas.stop();
}
la palabra caballero a que hace referencia?????
Por Acreonte el 03 de Mayo de 2012
juaser-blog :
¿conoces alguna forma que haga que el 550 sea un numero aleatorio para que cambie la altura del dragon(claro que el numero tiene que tener "condiciones" para que no se salga de la pantalla) ?
Hola juaser, disculpa que me tarde en contestar
Ese tween hace referencia a la propiedad 'x' del dragon. Para cambiar la altura del dragon utilizariamos la propiedad 'y'. Cambiemos el metodo moverDragon agregando una linea de codigo para ello:
Código :
Math.random() * 150 nos dará un numero aleatorio entre 0 y 150. El 25 es el limite de arriba, o sea, el valor de 'y' debe ser por lo menos de 25 pixeles. Como el valor aleatorio llega hasta 150, el limite de abajo son 175 pixeles. En este caso el dragon aparecera en cualquier posicion en 'y' entre 25 y 175 pixeles.
elunico-blog :
Tienes razon, no especifique que caballero el nombre de instancia de el caballero que se encuentra en el escenario.
Por ponchy el 07 de Mayo de 2012
Gracias
Por carlos el 15 de Julio de 2012
gracias
Por el 03 de Octubre de 2012
Por Acreonte el 04 de Octubre de 2012
Código :
Y cada vez que la flecha toque al dragon, agregamos 10 puntos:
Código :
Por gaea el 29 de Octubre de 2012
bueno la verdad esque soy nuevo en este tema de codigos as3 no tengo ni 1 mes pero si no es molestia. . .
Me gustaria saber como se formulo este cambio:
private function revisarInteraccion(evento : KeyboardEvent) : void
{
if(evento.keyCode == Keyboard.LEFT)
{
caballero.x -= 5;
}
else if(evento.keyCode == Keyboard.RIGHT)
{
caballero.x += 5;
}
}
y cambio a a este:
if(evento.keyCode == Keyboard.LEFT)
{
moverCaballero(-PASOS);
}
else if(evento.keyCode == Keyboard.RIGHT)
{
moverCaballero(PASOS);
y tambien me gusaria saber que significa exactamente la expresion de:
if(evento.keyCode == Keyboard.UP)
{
if(!estaDisparando) dispararFlecha();
}
}
en especial el " ! ".
Por Acreonte el 30 de Octubre de 2012
tutorial :
También he agregado la constante PASOS cuyo valor es un numero entero (int) igual a 5. Es el numero de pixeles que el caballero debe moverse. Esto es considerado buena practica ya que al tener el valor declarado en una constante, es facil encontrarlo y actualizarlo.
y luego se explica como usarlo:
tutorial :
La función moverCaballero necesita un número entero como parámetro que es la distancia que nuestro caballero se moverá. Podemos llamarla desde revisarInteraccion y pasarle PASOS como parametro con valor negativo o positivo.
Tu pregunta sobre la expresion !estaDisparando, tienes mucha razon, no he explicado mucho al respecto.
tutorial :
La variable estaDisparando es un booleano, solamente acepta dos valores, true y false (verdadero y falso) y al declararlo es falso por defecto. Esta variable nos ayudará a evitar que el caballero dispare muy seguido.
Los condicionales 'if' prueban si algo es verdadero o falso. Usualmente se utiliza probando si algo es verdadero:
Código :
en nuestro caso, estamos usando lo contrario, comprobando que algo sea falso:
Código :
El signo de admiracion (o exclamacion) significa 'lo opuesto a', es un atajo a
Código :
Expero se entienda, cualquier cosa, aca estamos
Por GTG el 22 de Octubre de 2013
Mil gracias,
Guillermo Tovar
Por Edwin Basurto el 23 de Noviembre de 2013
Por raptor0555 el 28 de Enero de 2014
Por Codlml el 01 de Abril de 2014
Muchas gracias hermano! Me sirvió de mucho.
Sé que es antiguo, pero si aun pasas por aquí, me gustaría saber como agregar más dragones.
Por Pablo el 03 de Mayo de 2014
Saludos
Por Yasser Frias el 16 de Marzo de 2015
Por bella el 27 de Octubre de 2016
Por José el 31 de Enero de 2018
classroom rental space
training rrom rental in singapore
training rooms in singapore
seminar room rental in singapore
indoor team building activities
corporate team building games singapore
team bonding in singapore
team building activities singapore
team building games singapore
10 soft skills you need
administrative office procedures
administrative support courses
adult learning mental skills
adult learning physical skills
anger management courses in singapore
appreciative inquiry courses
archiving and records management
assertiveness and self confidence
attention management courses
basic bookkeeping courses
being a likeable boss
body language basics courses
budgets and financial reports
business acumen courses
business ethics courses
business etiquette courses in singapore
business succession planning courses
business writing courses in singapore
call center training courses
change management courses in singapore
coaching and mentoring courses
coaching sales people courses
collaborative business writing
communication strategies courses
conducting annual employee reviews
conflict resolution courses
contact center training courses
contract management courses in singapore
creating a great webinar
creative problem solving courses
crisis management courses
critical thinking courses in singapore
customer service courses in singapore
customer support courses
cyber security courses in singapore
delivering constructive criticism
developing a lunch and learn
developing corporate behavior
developing creativity courses
developing new managers
digital citizenship courses
emotional intelligence courses
employee motivation courses
employee on boarding courses
employee recognition courses
employee recruitment courses
employee termination processes
entrepreneurship courses in singapore
event planning courses in singapore
executive and personal assistants
facilitation skills courses
generation gaps courses
goal setting and getting things done
handling a difficult customer
health and wellness at work courses
high performance teams inside the company
high performance teams remote work force
hiring strategies courses
human resource management courses in singapore
improving mindfulness
improving self awareness
increasing your happiness
internet marketing fundamentals courses
interpersonal skills courses
job search skills courses
knowledge management courses in singapore
leadership and influence courses
lean process and six sigma
life coaching essentials courses
manager management courses
managing personal finances courses
managing work place anxiety
marketing basics courses
measuring results from training
media and public relations courses
meeting management courses
middle manager courses
millennial on boarding courses
m learning essentials
motivating your sales team
multi level marketing courses
negotiation skills courses
networking outside the company
networking within the company
office politics for managers
organizational skills courses
overcoming sales objections
performance management courses
personal branding courses in singapore
personal productivity courses
presentation skills courses in singapore
project management courses in singapore
proposal writing courses
prospecting and lead generation
public speaking courses in singapore
risk assessment and management courses
safety in the work place courses
sales fundamentals courses
sales training courses in singapore
servant leadership courses
it courses in singapore
microsoft training singapore
corporate training in singapore
corporate sgx
social intelligence courses
social learning courses
social media in the work place
social media marketing courses in singapore
soft skills courses in singapore
stress management courses in singapore
supervising others
supply chain management courses
taking initiative courses
talent management courses
team building for managers
team building through chemistry
teamwork and team building
telephone etiquette courses
telework and telecommuting
time management courses in singapore
trade show staff training
train the trainer courses
virtual team building and management
women in leadership courses
work life balance courses in singapore
work place diversity courses
work place harassment courses
work place violence courses
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
sancy suraj
[url=https://books.google.com.sg/books?id=1QykBQAAQBAJ&pg=PT362&lpg=PT362&dq=%22sancy+suraj+singh%22&source=bl&ots=E86QDyrLG2&sig=H-6a_YH-kTWaZWTfPSr1xfm4BOs&hl=en&sa=X&ved=0ahUKEwi3_56hhubVAhWJLo8KHcxTBxQ4ChDoAQgjMAA#v=onepage&q =% 22sancy% 20suraj% 20singh% 22 & f = false]sancy suraj[/url]
sancy suraj
longest colour sequence memorised
sancy suraj
longest colour sequence memorised
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
memory training course
lunch talks
lunch talks
memory training course
memory training course
cabin crew
online memory course
memory training course
memory training course
memory training course
memory training course
memory training course
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
geography tuition for secondary school students in singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
geography tuition for secondary school students singapore
secondary geography tuition in singapore
history tuition for secondary school students in singapore
social studies tuition for secondary school students in singapore
psle english tuition in singapore
psle science tuition in singapore
secondary 1 chemistry tuition in singapore
secondary 1 physics tuition in singapore
school holiday workshops courses for students in singapore
school holidays activitie in singapore
school holidays activitie in singapore
[url=http://umonictuitionadvantage.com/2017-november-school-holidays-activities-programmes-workshop-courses-camps-for- students-kids-in-singapore/]school holidays activitie in singapore[/url]
school holidays activitie in singapore
study skills
study skills
study skills workshops course in singapore
study skills workshops course in singapore
speed reading
speed reading
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
tuition[
student courses
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
corporate training
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
corporate lunch talk
team building
team building ideas
team building activities
unique team building
team building
corporate training in singapore
corporate training courses
corporate training courses
corporate training courses
corporate training courses
corporate health talk
corporate health talk
corporate health talk
lunch and learn talk
workplace lunch and learn
corporate training companies in singapore
training companies in singapore
emcee
emcee
health talks
soft skills training course
corporate training providers
professional development courses
training and development courses
short courses in singapore
corporate training courses in singapore
corporate training courses
corporate training in singapore
school holiday workshops courses for students in singapore
business students memory course in singapore
business students memory improvement workshop in singapore
memory improvement course for business students
memory improvement course for business students
business students memory improvement course
business students memory course in singapore
corporate health talks singapore
corporate health talks in singapore
corporate health talk singapore
corporate health talk in singapore
corporate health talks singapore
corporate health talks singapore
finance students memory training course in singapore
finance students memory training course in singapore
finance students memory training course in singapore
memory training courses for finance students in singapore
memory training courses for finance students in singapore
memory improvement courses for finance students in singapore
pinnacle minds
memory course
study skills
speed reading
memory training
school holiday
lunch and learn
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
march school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
june school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
september 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
november 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
december 2018 school holidays workshops
top 10 soft skills you need training course
administrative office procedures training course
administrative support training course
anger management training course
appreciative inquiry training course
archiving and records management training course
archiving and records management training course
self confidence and assertiveness training course
improving your attention management training course
bacis bookkeeping training course
being a likeable boss training course
body language training course
budgets and-financial reports training course
business acumen training course
business ethics training course
business etiquette training course
business succession planning training course
business writing training course
call centre training course
change management training course
civility in the workplace training course
coaching and mentoring training course
coaching salespeople training course
collaborative business writing training course
communication strategies training course
conducting annual employee reviews training course
conflict resolution training course
contact centre training course
contract management training course
creating a great webinar training course
creative problem solving training course
crisis management training course
critical thinking training course
customer service training course
customer support training course
cyber security training course
delivering constructive criticism training course
developing lunch and learn training course
developing corporate behavior training course
developing creativity training course
developing new managers training course
digital citizenship training course
emotional intelligence training course
employee motivation training course
employee onboarding training course
employee recognition training course
employee recruitment training course
employee termination processes training course
entrepreneurship training course
event planning training course
executive and personal assistants training course
facilitation skills training course
generation gaps training course
goal setting and getting things done training course
handling a difficult customer training course
health and wellness at work training course
high performance teams inside the company training course
high performance teams remote workforce training course
hiring strategies training course
human resource management training course
improving mindfulness training course
improving self awareness training course
internet marketing fundamentals training course
interpersonal skills training course
job search skills training course
knowledge management training course
leadership and influence training course
lean process and six sigma training course
life coaching essentials training course
manager management training course
managing personal finances training course
managing workplace anxiety training course
marketing basics training course
measuring results from training course
media and public relations training course
meeting management training course
middle manager training course
millennial onboarding training course
mlearning essentials training course
motivating your sales team training course
negotiation skills training course
networking outside the company training course
networking within the company training course
office politics for managers training course
organizational skills training course
overcoming sales objections training course
performance management training course
personal branding training course
personal productivity training course
presentation skills training course
project management training course
proposal writing training course
prospecting and lead generation training course
public speaking training course
risk assessment and management training course
safety in the workplace training course
sales fundamentals training course
servant leadership training course
social intelligence training course
social learning training course
social media in the workplace training course
social media marketing training course
stress management training course
supervising others training course
supply chain management training course
taking initiative training course
talent management training course
team building for managers training course
team building through chemistry training course
teamwork and team building training course
telephone etiquette training course
telework and telecommuting training course
time management training course
top 10 sales secrets training course
trade show staff training course
train the trainer training course
virtual team building and management training course
women in leadership training course
work life balance training course
workplace diversity training course
workplace harassment training course
workplace violence training course
half day memory improvement courses workshops
speed reading courses workshops in singapore
10 soft skills you need corporate training course in singapore
administrative office procedures corporate training course in singapore
administrative support corporate training course in singapore
anger management corporate training course in singapore
appreciative inquiry corporate training course in singapore
archiving and records management corporate training course in singapore
self confidence assertiveness corporate training course in singapore
improving your attention management corporate training course in singapore
basic bookkeeping corporate training course in singapore
being a likeable boss corporate training course in singapore
body language basics corporate training course in singapore
budgets and financial reports corporate training course in singapore
business acumen corporate training course in singapore
business ethics corporate training course in singapore
business etiquette corporate training course in singapore
business succession planning corporate training course in singapore
business writing corporate training course in singapore
call center corporate training course in singapore
change management corporate training course in singapore
civility in the workplace corporate training course in singapore
coaching and mentoring corporate training course in singapore
coaching salespeople corporate training course in singapore
collaborative business writing corporate training course in singapore
communication strategies corporate training course in singapore
conducting annual employee reviews corporate training course in singapore
conflict resolution corporate training course in singapore
contact center corporate training course in singapore
contract management corporate training course in singapore
creating a great webinar corporate training course in singapore
creative problem solving corporate training course in singapore
crisis-management corporate training course in singapore
critical thinking corporate training course in singapore
customer service corporate training course in singapore
customer support corporate training course in singapore
cyber security corporate training course in singapore
delivering constructive criticism corporate training course in singapore
developing a lunch and learn corporate training course in singapore
developing corporate behavior corporate training course in singapore
developing creativity corporate training course in singapore
developing new managers corporate training course in singapore
digital citizenship corporate training course in singapore
emotional intelligence corporate training course in singapore
employee motivation corporate training course in singapore
employee onboarding corporate training course in singapore
employee recognition corporate training course in singapore
employee recruitment corporate training course in singapore
employee termination processes corporate training course in singapore
entrepreneurship training course in singapore
event planning corporate training course in singapore
executive and personal assistants corporate training course in singapore
facilitation skills corporate training course in singapore
generation gaps corporate training course in singapore
goal setting and getting things done corporate training course in singapore
handling a difficult customer corporate training course in singapore
health and wellness at work corporate training course in singapore
high performance teams inside the company corporate training course in singapore
high performance teams remote workforce corporate training course in singapore
hiring strategies corporate training course in singapore
human resource management corporate training course in singapore
improving mindfulness corporate training course in singapore
improving self awareness corporate training course in singapore
increasing your happiness corporate training course in singapore
internet marketing fundamentals corporate training course in singapore
interpersonal skills corporate training course in singapore
job search skills corporate training course in singapore
knowledge management corporate training course in singapore
leadership and influence corporate training course in singapore
lean process and six sigma corporate training course in singapore
life coaching essentials corporate training course in singapore
manager management corporate training course in singapore
managing personal finances corporate training course in singapore
marketing basics corporate training course in singapore
measuring results from corporate training course in singapore
media and public relations corporate training course in singapore
meeting management corporate training course in singapore
middle manager corporate training course in singapore
millennial onboarding corporate training course in singapore
mlearning essentials corporate training course in singapore
motivating your sales team corporate training course in singapore
negotiation skills corporate training course in singapore
networking outside the company corporate training course in singapore
networking within the company corporate training course in singapore
office politics for managers corporate training course in singapore
organizational skills corporate training course in singapore
overcoming sales objections corporate training course in singapore
performance management corporate training course in singapore
personal branding corporate training course in singapore
personal productivity corporate training course in singapore
presentation skills corporate training course in singapore
project management corporate training course in singapore
proposal writing corporate training course in singapore
prospecting and lead generation corporate training course in singapore
public speaking corporate training course in singapore
[url