Passer au contenu principal

View Transitions

Ouvrir dans ChatGPT
Java API
25.11 Experimental

Les transitions de vue fournissent des transitions animées lorsque le DOM change, réduisant le choc visuel et maintenant le contexte spatial lors de la navigation ou des mises à jour de contenu. webforJ s'intègre à l'API de transition de vue du navigateur pour gérer la complexité de la coordination des animations entre les anciens et les nouveaux états.

Afficher le code

API expérimentale

Cette API est marquée comme expérimentale depuis le 25.11 et peut changer dans les futures versions. La signature de l'API, son comportement et ses caractéristiques de performance sont susceptibles de modification.

Utilisation de base

Pour créer une transition de vue, utilisez Page.getCurrent().startViewTransition(), qui retourne un constructeur pour configurer la transition :

Page.getCurrent().startViewTransition()
.onUpdate(done -> {
container.remove(oldView);
container.add(newView);
done.run();
})
.start();

Le processus de transition capture un instantané de l'état actuel, applique vos changements de DOM dans le rappel onUpdate, puis anime de l'ancien instantané au nouveau contenu. Vous devez appeler done.run() pour signaler que vos changements sont complets.

Le rappel onUpdate est requis

Appeler start() sans configurer un rappel de mise à jour déclenche une IllegalStateException.

Application des transitions

webforJ fournit des types de transition prédéfinis que vous pouvez appliquer aux composants entrant ou sortant du DOM :

ConstanteEffet
ViewTransition.NONEPas d'animation
ViewTransition.FADEFondu entre l'ancien et le nouveau contenu
ViewTransition.SLIDE_LEFTLe contenu glisse vers la gauche (comme pour la navigation en avant)
ViewTransition.SLIDE_RIGHTLe contenu glisse vers la droite (comme pour la navigation en arrière)
ViewTransition.SLIDE_UPLe contenu glisse vers le haut
ViewTransition.SLIDE_DOWNLe contenu glisse vers le bas
ViewTransition.ZOOML'ancien contenu se rétrécit, le nouveau contenu grandit
ViewTransition.ZOOM_OUTL'ancien contenu grandit, le nouveau contenu se rétrécit

Utilisez enter() pour animer l'ajout d'un composant et exit() pour animer le retrait d'un composant :

// Animer un composant entrant dans le DOM
Page.getCurrent().startViewTransition()
.enter(chatPanel, ViewTransition.ZOOM)
.onUpdate(done -> {
container.add(chatPanel);
done.run();
})
.start();

// Animer un composant sortant du DOM
Page.getCurrent().startViewTransition()
.exit(chatPanel, ViewTransition.FADE)
.onUpdate(done -> {
container.remove(chatPanel);
done.run();
})
.start();

Transitions de composants partagés

Les transitions de composants partagés créent un effet de morphing où un composant semble se transformer de sa position dans l'ancienne vue à sa position dans la nouvelle vue. Cela est réalisé en donnant aux composants le même nom de transition en utilisant la méthode setViewTransitionName(), disponible sur tout composant qui implémente l'interface HasStyle.

// Dans la vue de carte
image.setViewTransitionName("blog-image");

// Dans la vue de détail - le même nom crée le morph
image.setViewTransitionName("blog-image");

Lors de la transition entre ces vues, le navigateur anime le composant entre les positions, créant une expérience visuelle connectée.

Utiliser des noms uniques

Lorsque vous travaillez avec des listes ou des composants répétés, incluez un identifiant unique dans le nom de la transition. Chaque composant nécessite son propre nom distinct pour se morph correctement avec son composant correspondant dans la nouvelle vue. Utiliser le même nom pour plusieurs composants visibles provoque un comportement indéfini.

Afficher le code

Réorganisation de liste

Un cas d'utilisation courant pour les transitions de composants partagés est l'animation des éléments de liste lorsque leur ordre change. En assignant un view-transition-name unique à chaque élément, le navigateur anime automatiquement les composants vers leurs nouvelles positions :

// Chaque carte obtient un nom de transition unique basé sur son ID
card.setViewTransitionName("card-" + item.id());

// Lors du mélange, il suffit de mettre à jour le DOM - le navigateur gère l'animation
Page.getCurrent().startViewTransition()
.onUpdate(done -> {
renderList();
done.run();
})
.start();
Afficher le code

Animations CSS personnalisées

Pour un contrôle total sur les animations, vous pouvez définir des keyframes CSS personnalisées. webforJ ajoute des suffixes -enter ou -exit à vos noms de transition, que vous utilisez pour cibler les pseudo-éléments de transition de vue :

/* Définir les keyframes pour les composants entrants */
@keyframes flip-enter {
from {
opacity: 0;
transform: perspective(1000px) rotateX(-90deg);
}
to {
opacity: 1;
transform: perspective(1000px) rotateX(0deg);
}
}

/* Appliquer au pseudo-élément de transition de vue */
::view-transition-new(flip-in-enter) {
animation: flip-enter 450ms cubic-bezier(0.34, 1.56, 0.64, 1);
transform-origin: top center;
}

::view-transition-old(flip-in-enter) {
display: none;
}

Référencez votre animation personnalisée en passant son nom (sans le suffixe) à enter() ou exit() :

// Utilisez "flip-in" - webforJ ajoute automatiquement le suffixe "-enter"
Page.getCurrent().startViewTransition()
.enter(notification, "flip-in")
.onUpdate(done -> {
stage.add(notification);
done.run();
})
.start();

// Utilisez "blur-out" pour sortir - webforJ ajoute automatiquement le suffixe "-exit"
Page.getCurrent().startViewTransition()
.exit(notification, "blur-out")
.onUpdate(done -> {
stage.remove(notification);
done.run();
})
.start();
Afficher le code

Personnalisation CSS

Chaque type de transition prédéfini expose des propriétés CSS personnalisées pour un réglage fin :

VariablePar défautDescription
--vt-fade-duration200msDurée de l'animation
--vt-fade-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
VariablePar défautDescription
--vt-slide-left-duration200msDurée de l'animation
--vt-slide-left-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-slide-left-distance30%Distance de glissement
VariablePar défautDescription
--vt-slide-right-duration200msDurée de l'animation
--vt-slide-right-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-slide-right-distance30%Distance de glissement
VariablePar défautDescription
--vt-slide-up-duration200msDurée de l'animation
--vt-slide-up-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-slide-up-distance30%Distance de glissement
VariablePar défautDescription
--vt-slide-down-duration200msDurée de l'animation
--vt-slide-down-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-slide-down-distance30%Distance de glissement
VariablePar défautDescription
--vt-zoom-duration200msDurée de l'animation
--vt-zoom-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-zoom-scale0.8Facteur d'échelle (ancien zooms à ceci, nouveau zooms à partir de ceci)
VariablePar défautDescription
--vt-zoom-out-duration200msDurée de l'animation
--vt-zoom-out-easingcubic-bezier(0.4, 0, 0.2, 1)Fonction d'easing
--vt-zoom-out-scale1.2Facteur d'échelle (ancien zooms à ceci, nouveau zooms à partir de ceci)

Pour personnaliser, remplacez ces variables dans votre CSS :

:root {
--vt-fade-duration: 300ms;
--vt-slide-left-distance: 50%;
}

Pour une personnalisation avancée, ciblez directement les pseudo-éléments de transition de vue :

::view-transition-old(vt-slide-left-exit) {
animation-duration: 400ms;
}

::view-transition-new(vt-slide-left-enter) {
animation-timing-function: ease-out;
}