একটি অ্যানিমেশন সংস্থান দুটি ধরণের অ্যানিমেশনগুলির মধ্যে একটিকে সংজ্ঞায়িত করতে পারে:
- সম্পত্তি অ্যানিমেশন
- একটি
Animatorদিয়ে একটি নির্দিষ্ট সময়ের মধ্যে একটি বস্তুর সম্পত্তি মান পরিবর্তন করে একটি অ্যানিমেশন তৈরি করে। - অ্যানিমেশন দেখুন
দুটি ধরণের অ্যানিমেশন রয়েছে যা আপনি ভিউ অ্যানিমেশন ফ্রেমওয়ার্ক দিয়ে করতে পারেন:
- টুইন অ্যানিমেশন : একটি
Animationসাথে একটি একক চিত্রে একাধিক রূপান্তর সম্পাদন করে একটি অ্যানিমেশন তৈরি করে। - ফ্রেম অ্যানিমেশন :
AnimationDrawableসাথে ক্রমানুসারে চিত্রগুলির একটি ক্রম দেখিয়ে একটি অ্যানিমেশন তৈরি করে।
- টুইন অ্যানিমেশন : একটি
সম্পত্তি অ্যানিমেশন
XML-এ সংজ্ঞায়িত একটি অ্যানিমেশন যা লক্ষ্য বস্তুর বৈশিষ্ট্য পরিবর্তন করে, যেমন ব্যাকগ্রাউন্ড কালার বা আলফা মান, নির্দিষ্ট সময়ের মধ্যে।
- ফাইল অবস্থান:
-
res/animator/ filename .xml
ফাইলের নাম রিসোর্স আইডি হিসাবে ব্যবহৃত হয়। - সংকলিত সম্পদ ডেটা টাইপ:
- একটি
ValueAnimator,ObjectAnimator, বাAnimatorSetএ রিসোর্স পয়েন্টার - সম্পদ রেফারেন্স:
- জাভা-ভিত্তিক বা কোটলিন কোডে:
R.animator. filename
XML-এ:@[ package :]animator/ filename - সিনট্যাক্স:
<set android:ordering=["together" | "sequentially"]> <objectAnimator android:propertyName="string" android:duration="int" android:valueFrom="float | int | color" android:valueTo="float | int | color" android:startOffset="int" android:repeatCount="int" android:repeatMode=["restart" | "reverse"] android:valueType=["intType" | "floatType"]/> <animator android:duration="int" android:valueFrom="float | int | color" android:valueTo="float | int | color" android:startOffset="int" android:repeatCount="int" android:repeatMode=["restart" | "reverse"] android:valueType=["intType" | "floatType"]/> <set> ... </set> </set>
ফাইলটিতে একটি একক মূল উপাদান থাকতে হবে: হয়
<set>,<objectAnimator>, অথবা<valueAnimator>। আপনি অন্যান্য<set>উপাদান সহ<set>উপাদানের ভিতরে অ্যানিমেশন উপাদানগুলিকে একত্রিত করতে পারেন।- উপাদান:
- উদাহরণ:
XML ফাইল
res/animator/property_animator.xmlএ সংরক্ষিত হয়েছে :<set android:ordering="sequentially"> <set> <objectAnimator android:propertyName="x" android:duration="500" android:valueTo="400" android:valueType="intType"/> <objectAnimator android:propertyName="y" android:duration="500" android:valueTo="300" android:valueType="intType"/> </set> <objectAnimator android:propertyName="alpha" android:duration="500" android:valueTo="1f"/> </set>
এই অ্যানিমেশনটি চালানোর জন্য, আপনার কোডের XML সংস্থানগুলিকে একটি
AnimatorSetঅবজেক্টে স্ফীত করুন এবং তারপর অ্যানিমেশন সেট শুরু করার আগে সমস্ত অ্যানিমেশনের জন্য লক্ষ্য বস্তু সেট করুন।setTarget()কল করাAnimatorSetসমস্ত বাচ্চাদের জন্য সুবিধা হিসাবে একটি একক লক্ষ্য বস্তু সেট করে। নিম্নলিখিত কোড দেখায় কিভাবে এটি করতে হয়:কোটলিন
val set: AnimatorSet = AnimatorInflater.loadAnimator(myContext, R.animator.property_animator) .apply { setTarget(myObject) start() }
জাভা
AnimatorSet set = (AnimatorSet) AnimatorInflater.loadAnimator(myContext, R.animator.property_animator); set.setTarget(myObject); set.start();
- এছাড়াও দেখুন:
- সম্পত্তি অ্যানিমেশন ওভারভিউ
- প্রপার্টি অ্যানিমেশন সিস্টেম কীভাবে ব্যবহার করবেন তার উদাহরণের জন্য API ডেমো
অ্যানিমেশন দেখুন
ভিউ অ্যানিমেশন ফ্রেমওয়ার্ক টুইন এবং ফ্রেম-বাই-ফ্রেম অ্যানিমেশন উভয়কেই সমর্থন করে, যা উভয়ই XML-এ ঘোষণা করা হয়। নিম্নলিখিত বিভাগগুলি কীভাবে উভয় পদ্ধতি ব্যবহার করতে হয় তা বর্ণনা করে।
টুইন অ্যানিমেশন
XML-এ সংজ্ঞায়িত একটি অ্যানিমেশন যা একটি গ্রাফিকে রূপান্তর সম্পাদন করে যেমন ঘূর্ণায়মান, বিবর্ণ, সরানো এবং প্রসারিত করা।
- ফাইল অবস্থান:
-
res/anim/ filename .xml
ফাইলের নাম রিসোর্স আইডি হিসাবে ব্যবহৃত হয়। - সংকলিত সম্পদ ডেটা টাইপ:
- একটি
Animationরিসোর্স পয়েন্টার - সম্পদ রেফারেন্স:
- জাভাতে:
R.anim. filename
XML-এ:@[ package :]anim/ filename - সিনট্যাক্স:
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@[package:]anim/interpolator_resource" android:shareInterpolator=["true" | "false"] > <alpha android:fromAlpha="float" android:toAlpha="float" /> <scale android:fromXScale="float" android:toXScale="float" android:fromYScale="float" android:toYScale="float" android:pivotX="float" android:pivotY="float" /> <translate android:fromXDelta="float" android:toXDelta="float" android:fromYDelta="float" android:toYDelta="float" /> <rotate android:fromDegrees="float" android:toDegrees="float" android:pivotX="float" android:pivotY="float" /> <set> ... </set> </set>
ফাইলটিতে একটি একক মূল উপাদান থাকতে হবে: হয় একটি
<alpha>,<scale>,<translate>,<rotate>, অথবা<set>উপাদান যা অন্যান্য অ্যানিমেশন উপাদানগুলির একটি গ্রুপ (বা গোষ্ঠী) ধারণ করে (নেস্টেড<set>সহ উপাদান)।- উপাদান:
- উদাহরণ:
XML ফাইল
res/anim/hyperspace_jump.xmlএ সংরক্ষিত হয়েছে:<set xmlns:android="http://schemas.android.com/apk/res/android" android:shareInterpolator="false"> <scale android:interpolator="@android:anim/accelerate_decelerate_interpolator" android:fromXScale="1.0" android:toXScale="1.4" android:fromYScale="1.0" android:toYScale="0.6" android:pivotX="50%" android:pivotY="50%" android:fillAfter="false" android:duration="700" /> <set android:interpolator="@android:anim/accelerate_interpolator" android:startOffset="700"> <scale android:fromXScale="1.4" android:toXScale="0.0" android:fromYScale="0.6" android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%" android:duration="400" /> <rotate android:fromDegrees="0" android:toDegrees="-45" android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%" android:duration="400" /> </set> </set>
নিম্নলিখিত অ্যাপ্লিকেশন কোডটি একটি
ImageViewএ অ্যানিমেশন প্রয়োগ করে এবং অ্যানিমেশন শুরু করে:কোটলিন
val image: ImageView = findViewById(R.id.image) val hyperspaceJump: Animation = AnimationUtils.
loadAnimation(this, R.anim.hyperspace_jump) image.startAnimation(hyperspaceJump)জাভা
ImageView image = (ImageView) findViewById(R.id.image); Animation hyperspaceJump = AnimationUtils.
loadAnimation(this, R.anim.hyperspace_jump); image.startAnimation(hyperspaceJump);- এছাড়াও দেখুন:
ইন্টারপোলেটর
একটি ইন্টারপোলেটর হল XML-এ সংজ্ঞায়িত একটি অ্যানিমেশন সংশোধক যা একটি অ্যানিমেশনের পরিবর্তনের হারকে প্রভাবিত করে। এটি আপনার বিদ্যমান অ্যানিমেশন প্রভাবগুলিকে ত্বরান্বিত, হ্রাস, পুনরাবৃত্তি, বাউন্স ইত্যাদি হতে দেয়।
android:interpolator interpolator অ্যাট্রিবিউট সহ একটি অ্যানিমেশন উপাদানে একটি ইন্টারপোলেটর প্রয়োগ করা হয়, যার মানটি একটি ইন্টারপোলেটর সম্পদের একটি রেফারেন্স।
অ্যান্ড্রয়েডে উপলব্ধ সমস্ত ইন্টারপোলেটরগুলি Interpolator ক্লাসের সাবক্লাস। প্রতিটি ইন্টারপোলেটর ক্লাসের জন্য, অ্যান্ড্রয়েডে একটি পাবলিক রিসোর্স রয়েছে যা আপনি android:interpolator অ্যাট্রিবিউট ব্যবহার করে একটি অ্যানিমেশনে ইন্টারপোলেটর প্রয়োগ করতে উল্লেখ করতে পারেন। নিম্নলিখিত সারণী প্রতিটি ইন্টারপোলেটরের জন্য ব্যবহার করার জন্য সম্পদ নির্দিষ্ট করে:
| ইন্টারপোলেটর ক্লাস | রিসোর্স আইডি |
|---|---|
AccelerateDecelerateInterpolator | @android:anim/accelerate_decelerate_interpolator |
AccelerateInterpolator | @android:anim/accelerate_interpolator |
AnticipateInterpolator | @android:anim/anticipate_interpolator |
AnticipateOvershootInterpolator | @android:anim/anticipate_overshoot_interpolator |
BounceInterpolator | @android:anim/bounce_interpolator |
CycleInterpolator | @android:anim/cycle_interpolator |
DecelerateInterpolator | @android:anim/decelerate_interpolator |
LinearInterpolator | @android:anim/linear_interpolator |
OvershootInterpolator | @android:anim/overshoot_interpolator |
android:interpolator অ্যাট্রিবিউট দিয়ে আপনি কীভাবে এর মধ্যে একটি প্রয়োগ করতে পারেন তা এখানে:
<set android:interpolator="@android:anim/accelerate_interpolator"> ... </set>
কাস্টম ইন্টারপোলেটর
আপনি যদি প্ল্যাটফর্ম দ্বারা প্রদত্ত ইন্টারপোলেটরগুলির সাথে সন্তুষ্ট না হন তবে আপনি পরিবর্তিত বৈশিষ্ট্যগুলির সাথে একটি কাস্টম ইন্টারপোলেটর সংস্থান তৈরি করতে পারেন৷ উদাহরণস্বরূপ, আপনি AnticipateInterpolator এর জন্য ত্বরণের হার সামঞ্জস্য করতে পারেন বা CycleInterpolator এর জন্য চক্রের সংখ্যা সামঞ্জস্য করতে পারেন। এটি করার জন্য, আপনি একটি XML ফাইলে আপনার নিজস্ব ইন্টারপোলেটর সংস্থান তৈরি করুন।
- ফাইল অবস্থান:
-
res/anim/ filename .xml
ফাইলের নাম রিসোর্স আইডি হিসাবে ব্যবহৃত হয়। - সংকলিত সম্পদ ডেটা টাইপ:
- সংশ্লিষ্ট ইন্টারপোলেটর অবজেক্টে রিসোর্স পয়েন্টার
- সম্পদ রেফারেন্স:
- XML-এ:
@[ package :]anim/ filename - সিনট্যাক্স:
<?xml version="1.0" encoding="utf-8"?> <InterpolatorName xmlns:android="http://schemas.android.com/apk/res/android" android:attribute_name="value" />
আপনি যদি কোনো অ্যাট্রিবিউট প্রয়োগ না করেন, তাহলে আপনার ইন্টারপোলেটর ঠিক একইভাবে কাজ করে যেমনটি প্ল্যাটফর্ম দ্বারা প্রদত্ত, পূর্ববর্তী সারণীতে তালিকাভুক্ত।
- উপাদান:
- লক্ষ্য করুন যে প্রতিটি
Interpolatorবাস্তবায়ন, যখন XML-এ সংজ্ঞায়িত করা হয়, তখন একটি নাম থাকে যা একটি ছোট হাতের অক্ষর দিয়ে শুরু হয়। - উদাহরণ:
XML ফাইল
res/anim/my_overshoot_interpolator.xmlএ সংরক্ষিত হয়েছে:<?xml version="1.0" encoding="utf-8"?> <overshootInterpolator xmlns:android="http://schemas.android.com/apk/res/android" android:tension="7.0" />
এই অ্যানিমেশন XML ইন্টারপোলেটর প্রয়োগ করে:
<scale xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@anim/my_overshoot_interpolator" android:fromXScale="1.0" android:toXScale="3.0" android:fromYScale="1.0" android:toYScale="3.0" android:pivotX="50%" android:pivotY="50%" android:duration="700" />
ফ্রেম অ্যানিমেশন
XML-এ সংজ্ঞায়িত একটি অ্যানিমেশন যা ছবির মতো ক্রমানুসারে চিত্রগুলির একটি ক্রম দেখায়।
- ফাইল অবস্থান:
-
res/drawable/ filename .xml
ফাইলের নাম রিসোর্স আইডি হিসাবে ব্যবহৃত হয়। - সংকলিত সম্পদ ডেটা টাইপ:
- একটি
AnimationDrawableরিসোর্স পয়েন্টার - সম্পদ রেফারেন্স:
- জাভাতে:
R.drawable. filename
XML-এ:@[ package :]drawable. filename - সিনট্যাক্স:
<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot=["true" | "false"] > <item android:drawable="@[package:]drawable/drawable_resource_name" android:duration="integer" /> </animation-list>
- উপাদান:
- উদাহরণ:
XML ফাইল
res/drawable/rocket_thrust.xmlএ সংরক্ষিত হয়েছে:<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false"> <item android:drawable="@drawable/rocket_thrust1" android:duration="200" /> <item android:drawable="@drawable/rocket_thrust2" android:duration="200" /> <item android:drawable="@drawable/rocket_thrust3" android:duration="200" /> </animation-list>
নিম্নলিখিত অ্যাপ্লিকেশন কোডটি একটি
Viewএর পটভূমি হিসাবে অ্যানিমেশন সেট করে, তারপর অ্যানিমেশনটি চালান:কোটলিন
val rocketImage: ImageView = findViewById(R.id.rocket_image) rocketImage.
setBackgroundResource(R.drawable.rocket_thrust) val rocketAnimation = rocketImage.backgroundif (rocketAnimation isAnimatable) { rocketAnimation.start()}জাভা
ImageView rocketImage = (ImageView) findViewById(R.id.rocket_image); rocketImage.
setBackgroundResource(R.drawable.rocket_thrust); rocketAnimation = rocketImage.getBackground(); if (rocketAnimation instanceofAnimatable) { ((Animatable)rocketAnimation).start(); }- এছাড়াও দেখুন: