Return to Video

Funciones especiales de ProcessingJS

  • 0:00 - 0:03
    Hasta este punto, te habrás dado cuenta de que has definido
  • 0:03 - 0:07
    una función particular cada vez que quieres animar un programa,
  • 0:07 - 0:09
    la función "draw".
  • 0:09 - 0:13
    Para recordártelo, aquí está nuestro programa del carro animado nuevamente.
  • 0:13 - 0:17
    Tiene esta variable llamada "x" y que está inicializada en 11.
  • 0:17 - 0:23
    Y luego dentro de la función "draw", se dibuja el carro en la variable "x",
  • 0:23 - 0:27
    y luego suma 3 a la variable cada vez.
  • 0:27 - 0:29
    Y eso da como resultado un carro
  • 0:29 - 0:32
    que se mueve tres pixeles continuamente a lo largo de la pantalla.
  • 0:32 - 0:35
    Así es como funciona.
  • 0:35 - 0:38
    Pero ahora que has aprendido cómo hacer tus propias funciones,
  • 0:38 - 0:42
    probablemente te preguntes, ¿qué pasa con la función "draw"?
  • 0:42 - 0:44
    ¿Por qué siempre la llamamos "draw"?
  • 0:44 - 0:46
    ¿Es una función personalizada?
  • 0:46 - 0:49
    Y esas son muy buenas preguntas.
  • 0:49 - 0:52
    Verás, en la librería "ProcessingJS",
  • 0:52 - 0:56
    la función "draw" es una de las pocas funciones predefinidas
  • 0:56 - 1:01
    que da a nuestros programas más control sobre lo que pasa en la pantalla.
  • 1:01 - 1:05
    Una función predefinida es una función que ha sido definida
  • 1:05 - 1:07
    por la librería "ProcessingJS".
  • 1:07 - 1:11
    Pero generalmente comienza como una definición vacía.
  • 1:11 - 1:17
    Por ejemplo, en la librería "ProcessingJS", hay un código que se ve así:
  • 1:17 - 1:19
    "var draw = function() {}"
  • 1:19 - 1:23
    y luego está vacío, completamente vacío.
  • 1:23 - 1:29
    Ahora, llamamos a la librería "ProcessingJS" en cada programa que hacemos en Khan Academy,
  • 1:29 - 1:31
    Así que nunca ves ese código.
  • 1:31 - 1:34
    Pero creeme, existe.
  • 1:34 - 1:41
    Ahora, voy a comentar el código, ya que "ProcessingJS" lo hace por nosotros.
  • 1:41 - 1:45
    Cuando defines "draw" en nuestro programa,
  • 1:45 - 1:50
    esta nueva definición anula la definición anterior.
  • 1:50 - 1:52
    Y ahora la función "draw"
  • 1:52 - 1:55
    en realidad hace cosas emocionantes, como dibujar un carro.
  • 1:55 - 2:01
    Ahora, la pregunta es, ¿por qué la función "draw" se llama repetidas veces?
  • 2:01 - 2:06
    Bueno, también hay código en la librería "ProcessingJS"
  • 2:06 - 2:11
    que establece un temporizador del navegador y llama a la función repetidamente,
  • 2:11 - 2:14
    una vez tras otra.
  • 2:14 - 2:19
    Tenemos que darle a la función el nombre de "draw" porque es el nombre de la función
  • 2:19 - 2:22
    que la librería "ProcessingJS" está llamando repetidamente.
  • 2:22 - 2:28
    Si renombramos esta función como... digamos "drawCar",
  • 2:28 - 2:34
    en primer lugar obtendremos un error de definición, así que tendríamos que decir "var drawCar".
  • 2:34 - 2:37
    Entonces ahora puedes ver que si renombramos esto como "drawCar",
  • 2:37 - 2:40
    no vemos ninguna animación.
  • 2:40 - 2:45
    Y esto es porque esta función no se está llamando repetidamente,
  • 2:45 - 2:47
    porque no se llama "draw".
  • 2:47 - 2:51
    Así que tenemos que poner el código que queremos que se llame repetidamente
  • 2:51 - 2:56
    dentro de una función a la que nombremos "draw" exactamente.
  • 2:56 - 3:01
    Así que voy a hacerlo de nuevo, y voy a llamar a "drawCar" desde aquí.
  • 3:01 - 3:03
    ¡Ajá! Lo tenemos nuevamente.
  • 3:03 - 3:07
    Muy bien, así que se debe llamar "draw",
  • 3:07 - 3:13
    y esto también significa que no deberías llamar "draw" a tus funciones personalizadas,
  • 3:13 - 3:18
    a menos que quieras que se consideren de una manera especial y que sean llamadas una y otra vez.
  • 3:18 - 3:24
    Y recuerda también que no puedes tener muchas funciones llamadas "draw".
  • 3:24 - 3:28
    Sólo la última sería considerada.
  • 3:28 - 3:31
    Si tenemos "rect" aquí dentro
  • 3:31 - 3:35
    Entonces ahora podemos ver que nuestro carro ya no se está dibujando,
  • 3:35 - 3:40
    y sólo se está dibujando "rect" en su lugar, porque sólo se considera la última definición.
  • 3:40 - 3:43
    Así que vamos a deshacernos de ésta.
  • 3:43 - 3:48
    Ahora, la función "draw" no es la única función predefinida
  • 3:48 - 3:50
    que tiene este comportamiento especial.
  • 3:50 - 3:53
    Hay muchas otras funciones también,
  • 3:53 - 3:57
    para responder a las interacciones del ratón y al uso de teclas.
  • 3:57 - 4:02
    Digamos que queremos tener un programa que dibuja una elipse coloreada
  • 4:02 - 4:05
    por donde el usuario pasa el ratón.
  • 4:05 - 4:09
    Podríamos hacer eso con una función como ésta...
  • 4:09 - 4:20
    digamos "mouseX, mouseY, mouseY" y luego "ellipse(mouseX, mouseY, 10, 10)"
  • 4:20 - 4:23
    Muy bien, oh, hermoso.
  • 4:23 - 4:27
    Ahora, esta función se está llamando una y otra vez,
  • 4:27 - 4:31
    aún cuando el usuario no está moviendo el ratón, como en este momento.
  • 4:31 - 4:35
    Y este programa, funciona, hace lo que queremos que haga,
  • 4:35 - 4:38
    está pintando esas lindas elipses por toda la pantalla.
  • 4:38 - 4:42
    Pero resulta que hay una mejor manera de hacer lo mismo
  • 4:42 - 4:44
    y que es más eficiente.
  • 4:44 - 4:52
    Entonces podemos cambiar la función "draw" a "mouseMoved" y vamos a ver.
  • 4:52 - 4:55
    Sigue funcionando.
  • 4:55 - 4:58
    Verás, nuestro entorno revisa los programas
  • 4:58 - 5:01
    para ver si se ha definido una función "mouseMoved",
  • 5:01 - 5:05
    y si se ha hecho, llama a la función cada vez que el usuario mueve el ratón.
  • 5:05 - 5:10
    Pero no se llamará si el usuario no mueve el ratón.
  • 5:10 - 5:13
    Así que antes, estábamos llamando al código de la función "draw"
  • 5:13 - 5:16
    cuando no lo necesitábamos, una y otra vez.
  • 5:16 - 5:20
    Y ahora, sólo llamamos al código en "mouseMoved"
  • 5:20 - 5:23
    cuando "mouseX" o "mouseY" han cambiado.
  • 5:23 - 5:27
    Así que nuestro programa es más eficiente y eso es algo bueno.
  • 5:27 - 5:31
    Generalmente, si sólo quieres cambiar el resultado de tu programa
  • 5:31 - 5:35
    cuando el usuario mueve el ratón, entonces es mejor que tengas tu código
  • 5:35 - 5:37
    dentro de la función "mouseMoved".
  • 5:37 - 5:41
    Y existen muchas funciones predefinidas como ésta,
  • 5:41 - 5:45
    puedes ver más ejemplos en la documentación.
  • 5:45 - 5:49
    Como "mousePressed", "mouseReleased", "keyPressed", y otras.
  • 5:49 - 5:54
    Así que recuerda, si quieres usar una función especial predefinida,
  • 5:54 - 5:59
    como "mouseMoved" o "draw", escríbelas correctamente, y úsalas correctamente.
  • 5:59 - 6:03
    Si no es así, entonces asegurate de que los nombres de tus funciones
  • 6:03 - 6:07
    sean nuevos y únicos.
Title:
Funciones especiales de ProcessingJS
Description:

more » « less
Video Language:
English
Duration:
06:08
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Special ProcessingJS functions
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Special ProcessingJS functions
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Special ProcessingJS functions
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Special ProcessingJS functions

Spanish, Mexican subtitles

Revisions