Angular7 - Animacje
Animacje dodają wiele interakcji między elementami HTML. Animacja była dostępna w Angular 2, od Angular 4 animacja nie jest już częścią biblioteki @ angular / core, ale jest oddzielnym pakietem, który należy zaimportować do app.module.ts.
Na początek musimy zaimportować bibliotekę z poniższą linią kodu -
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
Plik BrowserAnimationsModule należy dodać do tablicy importu w app.module.ts jak pokazano poniżej -
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppRoutingModule , RoutingComponent} from './app-routing.module';
import { AppComponent } from './app.component';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
import { MyserviceService } from './myservice.service';
import { HttpClientModule } from '@angular/common/http';
import { ScrollDispatchModule } from '@angular/cdk/scrolling';
import { DragDropModule } from '@angular/cdk/drag-drop';
import { ReactiveFormsModule } from '@angular/forms';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
@NgModule({
declarations: [
SqrtPipe,
AppComponent,
NewCmpComponent,
ChangeTextDirective,
RoutingComponent
],
imports: [
BrowserModule,
AppRoutingModule,
HttpClientModule,
ScrollDispatchModule,
DragDropModule,
ReactiveFormsModule,
BrowserAnimationsModule
],
providers: [MyserviceService],
bootstrap: [AppComponent]
})
export class AppModule { }
W app.component.htmldodaliśmy elementy html, które mają być animowane.
<div>
<button (click) = "animate()">Click Me</button>
<div [@myanimation] = "state" class = "rotate">
<img src = "assets/images/img.png" width = "100" height = "100">
</div>
</div>
Do głównego elementu DIV dodaliśmy przycisk i element DIV z obrazem. Istnieje zdarzenie kliknięcia, dla którego jest wywoływana funkcja animacji. W przypadku elementu div dyrektywa @myanimation jest dodawana i otrzymuje wartość jako stan.
Zobaczmy teraz app.component.ts gdzie animacja jest zdefiniowana.
import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators} from '@angular/forms';
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';
}
}
Musimy zaimportować funkcję animacji, która ma być używana w pliku .ts, jak pokazano powyżej.
import { trigger, state, style, transition, animate } from '@angular/animations';
Tutaj zaimportowaliśmy wyzwalacz, stan, styl, przejście i animację z @ angular / animations.
Teraz dodamy właściwość animations do dekoratora @Component () -
animations: [
trigger('myanimation',[
state('smaller',style({
transform : 'translateY(100px)' })),
state('larger',style({
transform : 'translateY(0px)' })),
transition('smaller <=> larger',animate('300ms ease-in'))
])
]
Wyzwalacz określa początek animacji. Pierwszym parametrem jest nazwa animacji, która ma być nadana znacznikowi html, do którego animacja ma zostać zastosowana. Drugi parametr to zaimportowane przez nas funkcje - stan, przejście itd.
Funkcja stanu obejmuje kroki animacji, pomiędzy którymi przejdzie element. W tej chwili zdefiniowaliśmy dwa stany, mniejszy i większy. W przypadku mniejszego państwa nadaliśmy styltransform:translateY(100px) i transform:translateY(100px).
Funkcja przejścia dodaje animację do elementu html. Pierwszy argument przyjmuje stany początkowy i końcowy, drugi argument przyjmuje funkcję animate. Funkcja animacji umożliwia zdefiniowanie długości, opóźnienia i łatwości przejścia.
Zobaczmy teraz plik .html, aby zobaczyć, jak działa funkcja przejścia -
<div>
<button (click) = "animate()">Click Me</button>
<div [@myanimation] = "state" class = "rotate">
<img src = "assets/images/img.png" width = "100" height = "100">
</div>
</div>
W dyrektywie @component dodano właściwość style, która centralnie wyrównuje element div. Rozważmy następujący przykład, aby zrozumieć to samo -
styles:[`
div{
margin: 0 auto;
text-align: center;
width:200px;
}
.rotate{
width:100px;
height:100px;
border:solid 1px red;
}
`],
W tym przypadku znak specjalny [``] jest używany do dodawania stylów do elementu html, jeśli istnieje. W przypadku elementu div nadaliśmy nazwę animacji zdefiniowaną wapp.component.ts plik.
Po kliknięciu przycisku wywołuje funkcję animacji, która jest zdefiniowana w app.component.ts plik w następujący sposób -
export class AppComponent {
state: string = "smaller";
animate() {
this.state = this.state == ‘larger’? 'smaller' : 'larger';
}
}
Zmienna stanu jest zdefiniowana i otrzymuje domyślną wartość jako mniejszą. Funkcja animacji zmienia stan po kliknięciu. Jeśli stan jest większy, przekształci się w mniejszy; a jeśli jest mniejszy, przekształci się w większy.
Tak wygląda wyjście w przeglądarce (http://localhost:4200/) będzie wyglądać jak -
Po kliknięciu Click Me przycisk, pozycja obrazu zostanie zmieniona, jak pokazano na poniższym zrzucie ekranu -
Funkcja transformacji jest stosowana w kierunku y, który zmienia się z 0 na 100 pikseli po kliknięciu przycisku Kliknij mnie. Obraz jest przechowywany w plikuassets/images teczka.