Overslaan naar hoofdinhoud

View Transitions

Openen in ChatGPT
Java API
25.11 Experimental

View-transities bieden geanimeerde overgangen wanneer de DOM verandert, waardoor visuele schokken worden verminderd en de ruimtelijke context tijdens navigatie of content-updates behouden blijft. webforJ integreert met de View Transition API van de browser om de complexiteit van het coördineren van animaties tussen oude en nieuwe toestanden aan te pakken.

Toon Code

Experimentele API

Deze API is gemarkeerd als experimenteel sinds 25.11 en kan in toekomstige versies veranderen. De API-handtekening, het gedrag en de prestatiekenmerken zijn onderhevig aan wijzigingen.

Basisgebruik

Om een view-transitie te creëren, gebruik Page.getCurrent().startViewTransition(), dat een builder retourneert voor het configureren van de transitie:

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

Het transitieproces legt een momentopname van de huidige toestand vast, past je DOM-wijzigingen toe in de onUpdate callback en animeert vervolgens van de oude momentopname naar de nieuwe inhoud. Je moet done.run() aanroepen om aan te geven wanneer je wijzigingen zijn voltooid.

De onUpdate callback is vereist

Het aanroepen van start() zonder een update callback in te stellen, werpt een IllegalStateException.

Toepassen van overgangen

webforJ biedt vooraf gedefinieerde overgangs typen die je kunt toepassen op componenten die de DOM binnenkomen of verlaten:

ConstantEffect
ViewTransition.NONEGeen animatie
ViewTransition.FADECrossfade tussen oude en nieuwe inhoud
ViewTransition.SLIDE_LEFTInhoud stroomt naar links (zoals vooruit navigatie)
ViewTransition.SLIDE_RIGHTInhoud stroomt naar rechts (zoals terug navigatie)
ViewTransition.SLIDE_UPInhoud stroomt omhoog
ViewTransition.SLIDE_DOWNInhoud stroomt omlaag
ViewTransition.ZOOMOude inhoud krimpt, nieuwe inhoud groeit aan
ViewTransition.ZOOM_OUTOude inhoud groeit weg, nieuwe inhoud krimpt in

Gebruik enter() om een component die wordt toegevoegd te animeren en exit() om een component die wordt verwijderd te animeren:

// Animeer een component die de DOM binnenkomt
Page.getCurrent().startViewTransition()
.enter(chatPanel, ViewTransition.ZOOM)
.onUpdate(done -> {
container.add(chatPanel);
done.run();
})
.start();

// Animeer een component die de DOM verlaat
Page.getCurrent().startViewTransition()
.exit(chatPanel, ViewTransition.FADE)
.onUpdate(done -> {
container.remove(chatPanel);
done.run();
})
.start();

Gedeelde componentovergangen

Gedeelde componentovergangen creëren een morfings-effect waarbij een component lijkt te transformeren van zijn positie in de oude weergave naar zijn positie in de nieuwe weergave. Dit wordt bereikt door componenten dezelfde overgangsnaam te geven met behulp van de setViewTransitionName() methode, beschikbaar op elke component die de HasStyle interface implementeert.

// In de kaartweergave
image.setViewTransitionName("blog-image");

// In de detailweergave - dezelfde naam creëert de morf
image.setViewTransitionName("blog-image");

Bij het overgaan tussen deze weergaven, animeert de browser de component tussen de posities, waardoor een verbonden visuele ervaring ontstaat.

Gebruik unieke namen

Wanneer je werkt met lijsten of herhaalde componenten, neem dan een unieke identificatie op in de overgangsnaam. Elke component heeft zijn eigen unieke naam nodig om correct te morfen naar de bijbehorende component in de nieuwe weergave. Het gebruik van dezelfde naam voor meerdere zichtbare componenten veroorzaakt ongedefinieerd gedrag.

Toon Code

Lijstherordering

Een veelvoorkomend gebruik van gedeelde componentovergangen is het animeren van lijstitems wanneer hun volgorde verandert. Door een unieke view-transition-name aan elk item toe te wijzen, animeert de browser componenten automatisch naar hun nieuwe posities:

// Elke kaart krijgt een unieke overgangsnaam op basis van zijn ID
card.setViewTransitionName("card-" + item.id());

// Bij het schudden, update gewoon de DOM - de browser verwerkt de animatie
Page.getCurrent().startViewTransition()
.onUpdate(done -> {
renderList();
done.run();
})
.start();
Toon Code

Aangepaste CSS-animaties

Voor volledige controle over animaties kun je aangepaste CSS-keyframes definiëren. webforJ voegt het achtervoegsel -enter of -exit toe aan je overgangsnamen, die je gebruikt om de pseudo-elementen van de view-overgang te targeten:

/* Definieer keyframes voor inkomende componenten */
@keyframes flip-enter {
from {
opacity: 0;
transform: perspective(1000px) rotateX(-90deg);
}
to {
opacity: 1;
transform: perspective(1000px) rotateX(0deg);
}
}

/* Toepassen op het pseudo-element van de view-overgang */
::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;
}

Verwijs naar je aangepaste animatie door de naam (zonder het achtervoegsel) door te geven aan enter() of exit():

// Gebruik "flip-in" - webforJ voegt automatisch het "-enter" achtervoegsel toe
Page.getCurrent().startViewTransition()
.enter(notification, "flip-in")
.onUpdate(done -> {
stage.add(notification);
done.run();
})
.start();

// Gebruik "blur-out" voor exit - webforJ voegt het "-exit" achtervoegsel toe
Page.getCurrent().startViewTransition()
.exit(notification, "blur-out")
.onUpdate(done -> {
stage.remove(notification);
done.run();
})
.start();
Toon Code

CSS-aanpassing

Elke vooraf gedefinieerde overgangstype exposeert CSS-aangepaste eigenschappen voor fine-tuning:

VariabeleStandaardBeschrijving
--vt-fade-duration200msDuur van de animatie
--vt-fade-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
VariabeleStandaardBeschrijving
--vt-slide-left-duration200msDuur van de animatie
--vt-slide-left-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-slide-left-distance30%Schuifafstand
VariabeleStandaardBeschrijving
--vt-slide-right-duration200msDuur van de animatie
--vt-slide-right-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-slide-right-distance30%Schuifafstand
VariabeleStandaardBeschrijving
--vt-slide-up-duration200msDuur van de animatie
--vt-slide-up-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-slide-up-distance30%Schuifafstand
VariabeleStandaardBeschrijving
--vt-slide-down-duration200msDuur van de animatie
--vt-slide-down-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-slide-down-distance30%Schuifafstand
VariabeleStandaardBeschrijving
--vt-zoom-duration200msDuur van de animatie
--vt-zoom-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-zoom-scale0.8Schaalfactor (oude zoomt uit naar dit, nieuwe zoomt in vanaf dit)
VariabeleStandaardBeschrijving
--vt-zoom-out-duration200msDuur van de animatie
--vt-zoom-out-easingcubic-bezier(0.4, 0, 0.2, 1)Easing-functie
--vt-zoom-out-scale1.2Schaalfactor (oude zoomt in naar dit, nieuwe zoomt uit vanaf dit)

Om aan te passen, overschrijf deze variabelen in je CSS:

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

Voor geavanceerde aanpassing, richt je rechtstreeks op de pseudo-elementen van de view-overgang:

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

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