कोणीय 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 फ़ोल्डर।