data:image/s3,"s3://crabby-images/31702/317022e5a26bc1df52af7f9bb92172f7b74d4884" alt=""
Primeramente creamos una aplicacion JavaFX
data:image/s3,"s3://crabby-images/fb21d/fb21d029ca782be2f7c171cc0ddbf82a7b7f58fc" alt=""
data:image/s3,"s3://crabby-images/9f2f5/9f2f51328f71c4064b8297de12d9ca834225c504" alt=""
Una vez que se nos abre copiamos el siguiente código fuente
package javafxapplication3;
import javafx.animation.KeyFrame;
import javafx.animation.Interpolator;
import javafx.animation.Timeline;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.stage.Stage;
import javafx.scene.control.Label;
import javafx.scene.control.TextBox;
import javafx.scene.layout.HBox;
var xRotar: Number = 0;
var anim = Timeline {
keyFrames: [
KeyFrame {
time: bind 2000ms
values: [
xRotar => 360 tween Interpolator.LINEAR,
]
}
]
};
Stage {
title: "Animación de Controles"
visible: true
scene: Scene {
width: 400
height: 500
content: [hBoxNombre,hBoxEmail, wsButton
]
}
def lblNombre = Label {
text: "Nombre:"
}
def txtNombre = TextBox {
columns: 12
selectOnFocus: true
}
def hBoxNombre = HBox {
layoutY: 10
content: [lblNombre, txtNombre]
rotate: bind xRotar
}
def lblEmail = Label {
text: "Email:"
}
def txtEmail = TextBox {
columns: 12
selectOnFocus: true
}
def hBoxEmail = HBox {
layoutY: 40
spacing: 10
rotate: bind xRotar
content: [lblEmail, txtEmail]
}
def wsButton = Button {
text: "Animar"
layoutY: 80
action: function (): Void {
anim.playFromStart();
}
}
}
Notas:
anim: Es usado para definir en el tiempo la respectiva animacion, para nuestro caso se ejecutará la animación por 2000 ms con una cuenta(interpolación) de 360
def: nos permite definir controles y asignarles variables fuera del Stage y luego estas variables son colocadas dentro del content del Stage
Finalmente ejecutamos el proyecto.
Damos click sobre el botón animar
data:image/s3,"s3://crabby-images/92021/92021068bdf230bccedf8e503817f3926a6ea655" alt=""
En ese momento veremos el respectivo movimiento de los controles
data:image/s3,"s3://crabby-images/e0b9d/e0b9df4795f349078c87ce8ecf635a288700550e" alt=""
No hay comentarios:
Publicar un comentario