कोणीय 6 - एनिमेशन
एनिमेशन html एलिमेंट्स के बीच बहुत अधिक इंटरैक्शन जोड़ता है। एंगुलर 2 के साथ एनीमेशन भी उपलब्ध था। कोणीय 6 के साथ अंतर यह है कि एनीमेशन का हिस्सा नहीं है@angular/core पुस्तकालय, लेकिन एक अलग पैकेज है जिसे आयात करने की आवश्यकता है app.module.ts।
आरंभ करने के लिए, हमें पुस्तकालय को निम्नानुसार आयात करना होगा -
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
BrowserAnimationsModule में आयात सरणी में जोड़ा जाना चाहिए app.module.ts जैसा कि नीचे दिखाया गया है -
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 { }
में app.component.html, हमने html एलिमेंट्स जोड़े हैं, जो एनिमेटेड होने हैं।
<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 को एक छवि के साथ जोड़ा है। एक क्लिक ईवेंट है जिसके लिए चेतन फ़ंक्शन कहा जाता है। और डिव के लिए,@myanimation निर्देश को जोड़ा जाता है और राज्य के रूप में मूल्य दिया जाता है।
अब हम देखते हैं app.component.ts जहां एनीमेशन को परिभाषित किया गया है।
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 फ़ाइल में उपयोग किया जाना है।
import { trigger, state, style, transition, animate } from '@angular/animations';
यहां हमने @ कोणीय / एनिमेशन से ट्रिगर, राज्य, शैली, संक्रमण और चेतन आयात किया है।
अब, हम एनिमेशन प्रापर्टी को @Component () डेकोरेटर में जोड़ेंगे -
animations: [
trigger('myanimation',[
state('smaller',style({
transform : 'translateY(100px)'
})),
state('larger',style({
transform : 'translateY(0px)'
})),
transition('smaller <=> larger',animate('300ms ease-in'))
])
]
ट्रिगर एनीमेशन की शुरुआत को परिभाषित करता है। इसके लिए पहला परमपद html टैग को दिए जाने वाले एनीमेशन का नाम है जिसमें एनीमेशन को लागू करने की आवश्यकता है। दूसरा परमार्थ वे कार्य हैं जिन्हें हमने आयात किया है - राज्य, संक्रमण, आदि।
stateफ़ंक्शन में एनीमेशन चरण शामिल हैं, जो तत्व के बीच संक्रमण करेगा। अभी हमने दो राज्यों को परिभाषित किया है, छोटे और बड़े। छोटे राज्य के लिए, हमने शैली दी हैtransform:translateY(100px) तथा transform:translateY(100px)।
संक्रमण फ़ंक्शन html तत्व में एनीमेशन जोड़ता है। पहला तर्क राज्यों को लेता है, अर्थात, शुरू और अंत; दूसरा तर्क चेतन कार्य को स्वीकार करता है। चेतन कार्य आपको संक्रमण की लंबाई, देरी और सहजता को परिभाषित करने की अनुमति देता है।
अब देखते हैं कि .html फ़ाइल यह देखने के लिए कि संक्रमण फ़ंक्शन कैसे काम करता है
<div>
<button (click) = "animate()">Click Me</button>
<div [@myanimation] = "state" class="rotate">
<img src = "assets/images/img.png" width = "100" height = "100">
</div>
</div>
इसमें एक शैली गुण जोड़ा गया है @componentनिर्देश, जो केंद्र को div संरेखित करता है। आइए इसे समझने के लिए निम्नलिखित उदाहरण पर विचार करें -
styles:[`
div{
margin: 0 auto;
text-align: center;
width:200px;
}
.rotate{
width:100px;
height:100px;
border:solid 1px red;
}
`],
यहां, html तत्व में शैलियों को जोड़ने के लिए एक विशेष चरित्र [``] का उपयोग किया जाता है, यदि कोई हो। Div के लिए, हमने app.component.ts फ़ाइल में परिभाषित एनीमेशन नाम दिया है।
एक बटन पर क्लिक करने पर यह चेतन फ़ंक्शन को कॉल करता है, जिसे app.component.ts फ़ाइल में निम्नानुसार परिभाषित किया गया है -
export class AppComponent {
state: string = "smaller";
animate() {
this.state= this.state == ?larger?? 'smaller' : 'larger';
}
}
राज्य चर को परिभाषित किया गया है और छोटे के रूप में डिफ़ॉल्ट मान दिया गया है। चेतन फ़ंक्शन क्लिक पर राज्य को बदलता है। यदि राज्य बड़ा है, तो यह छोटे में परिवर्तित हो जाएगा; और अगर छोटा होता है, तो यह बड़े में बदल जाएगा।
यह कैसे ब्राउज़र में आउटपुट है (http://localhost:4200/) जैसा दिखेगा -
पर क्लिक करने पर Click Me बटन, छवि की स्थिति को निम्न स्क्रीनशॉट में दिखाया गया है -
में परिवर्तन समारोह लागू किया जाता है yदिशा, जिसे क्लिक मी बटन पर क्लिक करने पर 0 से 100px में बदल दिया जाता है। छवि में संग्रहीत हैassets/images फ़ोल्डर।