Winkel 6 - Animationen

Animationen sorgen für viel Interaktion zwischen den HTML-Elementen. Animation war auch mit Angular2 verfügbar. Der Unterschied zu Angular 6 besteht darin, dass die Animation nicht mehr Teil der ist@angular/core Bibliothek, ist aber ein separates Paket, in das importiert werden muss app.module.ts.

Zunächst müssen wir die Bibliothek wie folgt importieren:

import { BrowserAnimationsModule } from '@angular/platform-browser/animations';

Das BrowserAnimationsModule muss dem Import-Array in hinzugefügt werden app.module.ts wie unten gezeigt -

app.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { AppComponent } from './app.component';
@NgModule({
   declarations: [
      AppComponent
   ],
   imports: [
      BrowserModule,
      BrowserAnimationsModule
   ],
   providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

Im app.component.htmlhaben wir die HTML-Elemente hinzugefügt, die animiert werden sollen.

<div>
   <button (click) = "animate()">Click Me</button>
   <div [@myanimation] = "state" class = "rotate">
      <img src = "assets/images/img.png" width = "100" height = "100">
   </div>
</div>

Für die Hauptdiv haben wir eine Schaltfläche und eine Div mit einem Bild hinzugefügt. Es gibt ein Klickereignis, für das die Animationsfunktion aufgerufen wird. Und für die Div, die@myanimation Direktive wird hinzugefügt und erhält den Wert als Zustand.

Lassen Sie uns jetzt die sehen app.component.ts wo die Animation definiert ist.

import { Component } from '@angular/core';
import { trigger, state, style, transition, animate } from '@angular/animations';
@Component({
   selector: 'app-root',
   templateUrl: './app.component.html',
   styleUrls: ['./app.component.css'],
   styles:[`
      div{
         margin: 0 auto;
         text-align: center;
         width:200px;
      }
      .rotate{
         width:100px;
         height:100px;
         border:solid 1px red;
      }
   `],
   animations: [
      trigger('myanimation',[
         state('smaller',style({
            transform : 'translateY(100px)'
         })),
         state('larger',style({
            transform : 'translateY(0px)'
         })),
         transition('smaller <=> larger',animate('300ms ease-in'))
      ])
   ]
})
export class AppComponent {
   state: string = "smaller";
   animate() {
      this.state= this.state == 'larger' ? 'smaller' : 'larger';
   }
}

Wir müssen die Animationsfunktion importieren, die in der .ts-Datei verwendet werden soll, wie oben gezeigt.

import { trigger, state, style, transition, animate } from '@angular/animations';

Hier haben wir Trigger, Status, Stil, Übergang und Animation aus @ angle / animations importiert.

Jetzt fügen wir die Animationseigenschaft dem Dekorator @Component () hinzu -

animations: [
   trigger('myanimation',[
      state('smaller',style({
         transform : 'translateY(100px)'
      })),
      state('larger',style({
         transform : 'translateY(0px)'
      })),
      transition('smaller <=> larger',animate('300ms ease-in'))
   ])
]

Trigger definiert den Start der Animation. Der erste Parameter ist der Name der Animation, die dem HTML-Tag zugewiesen werden soll, auf das die Animation angewendet werden muss. Der zweite Parameter sind die Funktionen, die wir importiert haben - Status, Übergang usw.

Das stateDie Funktion umfasst die Animationsschritte, zwischen denen das Element wechselt. Im Moment haben wir zwei Zustände definiert, kleiner und größer. Für kleinere Staaten haben wir den Stil gegebentransform:translateY(100px) und transform:translateY(100px).

Die Übergangsfunktion fügt dem HTML-Element eine Animation hinzu. Das erste Argument nimmt die Zustände an, dh Start und Ende; Das zweite Argument akzeptiert die Animationsfunktion. Mit der Animationsfunktion können Sie die Länge, Verzögerung und Beschleunigung eines Übergangs definieren.

Sehen wir uns nun die HTML-Datei an, um zu sehen, wie die Übergangsfunktion funktioniert

<div>
   <button (click) = "animate()">Click Me</button>
   <div [@myanimation] = "state" class="rotate">
      <img src = "assets/images/img.png" width = "100" height = "100">
   </div>
</div>

In der wird eine Stileigenschaft hinzugefügt @componentDirektive, die die div zentral ausrichtet. Betrachten wir das folgende Beispiel, um dasselbe zu verstehen:

styles:[`
   div{
      margin: 0 auto;
      text-align: center;
      width:200px;
   }
   .rotate{
      width:100px;
      height:100px;
      border:solid 1px red;
   }
`],

Hier wird ein Sonderzeichen [``] verwendet, um dem HTML-Element ggf. Stile hinzuzufügen. Für das div haben wir den in der Datei app.component.ts definierten Animationsnamen angegeben.

Auf Knopfdruck wird die Animationsfunktion aufgerufen, die in der Datei app.component.ts wie folgt definiert ist:

export class AppComponent {
   state: string = "smaller";
   animate() {
      this.state= this.state == ?larger?? 'smaller' : 'larger';
   }
}

Die Statusvariable ist definiert und erhält den Standardwert als kleiner. Die Animationsfunktion ändert den Status beim Klicken. Wenn der Status größer ist, wird er in einen kleineren konvertiert. und wenn es kleiner ist, wird es in größer umgewandelt.

So erfolgt die Ausgabe im Browser (http://localhost:4200/) wird aussehen wie -

Beim Klicken auf die Click Me Schaltfläche wird die Position des Bildes geändert, wie im folgenden Screenshot gezeigt -

Die Transformationsfunktion wird in der yRichtung, die von 0 auf 100 Pixel geändert wird, wenn auf die Schaltfläche "Klicken" geklickt wird. Das Bild wird in der gespeichertassets/images Mappe.