آموزش انیمیشن ها در انگولار 6
آموزش انیمیشن ها در انگولار 6
در این درس از مجموعه آموزش برنامه نویسی سایت سورس باران، به آموزش انیمیشن ها در انگولار 6 خواهیم پرداخت.
انیمیشن ها تعامل زیادی بین عناصر html اضافه می کنند. انیمیشن با Angular2 نیز در دسترس بود. تفاوت با انگولار 6 این است که انیمیشن دیگر بخشی از کتابخانه @angular/core نیست، بلکه یک بسته جداگانه است که باید در app.module.ts وارد شود.
برای شروع، باید کتابخانه را به صورت زیر وارد کنیم –
1 |
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; |
همانطور که در زیر نشان داده شده است، BrowserAnimationsModule باید به آرایه import در app.module.ts اضافه شود.
app.module.ts
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
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 { } |
در app.component.html عناصر html را اضافه کرده ایم که قرار است متحرک شوند.
1 2 3 4 5 6 |
<div> <button (click) = "animate()">Click Me</button> <div [@myanimation] = "state" class = "rotate"> <img src = "assets/images/img.png" width = "100" height = "100"> </div> </div> |
برای div اصلی یک دکمه و یک div با تصویر اضافه کرده ایم. یک رویداد کلیک وجود دارد که برای آن تابع animate فراخوانی می شود. و برای div، دستور @myanimation اضافه شده و مقدار به عنوان حالت داده می شود.
اجازه دهید اکنون app.component.ts را ببینیم که در آن انیمیشن تعریف شده است.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
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'; } } |
ما باید تابع انیمیشنی را که قرار است در فایل ts استفاده شود، مطابق شکل بالا وارد کنیم.
1 |
import { trigger, state, style, transition, animate } from '@angular/animations'; |
در اینجا ما تریگر، حالت، استایل، انتقال و متحرک سازی را از @angular/animations وارد کرده ایم.
اکنون، ویژگی animations را به دکوراتور @Component () اضافه می کنیم
1 2 3 4 5 6 7 8 9 10 11 |
animations: [ trigger('myanimation',[ state('smaller',style({ transform : 'translateY(100px)' })), state('larger',style({ transform : 'translateY(0px)' })), transition('smaller <=> larger',animate('300ms ease-in')) ]) ] |
Trigger شروع انیمیشن را مشخص می کند. اولین پارامتر آن نام انیمیشنی است که باید به تگ html داده شود که انیمیشن باید روی آن اعمال شود. پارامتر دوم توابعی هستند که ما وارد کرده ایم – حالت، انتقال و غیره.
تابع حالت شامل مراحل انیمیشن است که عنصر بین آنها انتقال می یابد. در حال حاضر دو حالت کوچکتر و بزرگتر را تعریف کرده ایم. برای حالت کوچکتر، استایل transform:translateY(100px) و transform:translateY(100px) را داده ایم.
تابع Transition انیمیشن را به عنصر html اضافه می کند. آرگومان اول حالت ها را می گیرد، یعنی شروع و پایان. آرگومان دوم تابع animate را می پذیرد. تابع متحرک به شما امکان می دهد طول، تاخیر و سهولت یک انتقال را تعریف کنید.
اجازه دهید اکنون فایل html را ببینیم تا ببینیم تابع انتقال چگونه کار می کند
1 2 3 4 5 6 |
<div> <button (click) = "animate()">Click Me</button> <div [@myanimation] = "state" class="rotate"> <img src = "assets/images/img.png" width = "100" height = "100"> </div> </div> |
یک ویژگی style در دستورالعمل @component اضافه شده است که در مرکز div را تراز می کند. اجازه دهید مثال زیر را برای درک همین موضوع در نظر بگیریم
1 2 3 4 5 6 7 8 9 10 11 12 |
styles:[` div{ margin: 0 auto; text-align: center; width:200px; } .rotate{ width:100px; height:100px; border:solid 1px red; } `], |
در اینجا، یک کاراکتر ویژه [] برای افزودن استایل به عنصر html، در صورت وجود، استفاده میشود. برای div، نام انیمیشن تعریف شده در فایل app.component.ts را داده ایم.
با کلیک یک دکمه، تابع animate را فراخوانی می کند که در فایل app.component.ts به صورت زیر تعریف شده است –
1 |
1 2 3 4 5 6 |
export class AppComponent { state: string = "smaller"; animate() { this.state= this.state == �larger�? 'smaller' : 'larger'; } } |
متغیر state تعریف می شود و مقدار پیش فرض کوچکتر به آن داده می شود. تابع animate وضعیت را با کلیک تغییر می دهد. اگر حالت بزرگتر باشد، به کوچکتر تبدیل می شود. و اگر کوچکتر باشد به بزرگتر تبدیل می شود.
خروجی در مرورگر (http://localhost:4200/) به این صورت خواهد بود –
با کلیک بر روی دکمه من کلیک کنید، موقعیت تصویر همانطور که در تصویر زیر نشان داده شده است تغییر می کند
تابع تبدیل در جهت y اعمال می شود که با کلیک روی دکمه Click Me از 0 به 100 پیکسل تغییر می کند. تصویر در پوشه assets/images ذخیره می شود.
لیست جلسات قبل آموزش انگولار 6
- آموزش انگولار 6
- آموزش مقدمه انگولار 6
- آموزش راه اندازی محیط انگولار 6
- آموزش راه اندازی پروژه در انگولار 6
- آموزش کامپوننت ها در انگولار 6
- آموزش ماژول در انگولار 6
- آموزش اتصال داده در انگولار 6
- آموزش اتصال رویداد در انگولار 6
- آموزش تمپلیت ها در انگولار 6
- آموزش دستورالعمل ها در انگولار 6
- آموزش پایپ ها در انگولار 6
- آموزش مسیریابی در انگولار 6
- آموزش سرویس ها در انگولار 6
- آموزش سرویس Http در انگولار 6
- آموزش Http Client در انگولار 6
- آموزش فرم ها در انگولار 6
دیدگاه شما