কিছু পরিস্থিতিতে, ছবি অ্যানিমেটেড করা প্রয়োজন. আপনি যদি বেশ কয়েকটি চিত্রের সমন্বয়ে একটি কাস্টম লোডিং অ্যানিমেশন প্রদর্শন করতে চান বা যদি আপনি ব্যবহারকারীর ক্রিয়াকলাপের পরে একটি আইকনকে রূপ দিতে চান তবে এটি কার্যকর। ড্রেবল অ্যানিমেট করার জন্য অ্যান্ড্রয়েড দুটি বিকল্প প্রদান করে।
প্রথম বিকল্পটি হল একটি AnimationDrawable
ব্যবহার করা। এটি আপনাকে বেশ কয়েকটি স্ট্যাটিক অঙ্কনযোগ্য ফাইল নির্দিষ্ট করতে দেয় যা একটি অ্যানিমেশন তৈরি করতে একবারে একটি প্রদর্শন করে। দ্বিতীয় বিকল্পটি হল একটি AnimatedVectorDrawable
ব্যবহার করা, যা আপনাকে একটি ভেক্টর ড্রয়েবলের বৈশিষ্ট্যগুলিকে অ্যানিমেট করতে দেয়।
AnimationDrawable ব্যবহার করুন
একটি অ্যানিমেশন তৈরি করার একটি উপায় হল অঙ্কনযোগ্য সংস্থানগুলির একটি ক্রম লোড করা, যেমন একটি ফিল্মের রোল৷ AnimationDrawable
ক্লাস এই ধরনের অঙ্কনযোগ্য অ্যানিমেশনের ভিত্তি।
আপনি AnimationDrawable
ক্লাস API ব্যবহার করে আপনার কোডে একটি অ্যানিমেশনের ফ্রেমগুলি সংজ্ঞায়িত করতে পারেন, তবে অ্যানিমেশন তৈরি করে এমন ফ্রেমগুলির তালিকা করে এমন একটি একক XML ফাইলের মাধ্যমে তাদের সংজ্ঞায়িত করা সহজ। এই ধরনের অ্যানিমেশনের জন্য XML ফাইলটি আপনার Android প্রকল্পের res/drawable/
ডিরেক্টরির অন্তর্গত। এই ক্ষেত্রে, নির্দেশাবলী অ্যানিমেশনের প্রতিটি ফ্রেমের জন্য ক্রম এবং সময়কাল দেয়।
XML ফাইলে রুট নোড হিসাবে একটি <animation-list>
উপাদান থাকে এবং একটি সিরিজ চাইল্ড <item>
নোড থাকে যা প্রতিটি ফ্রেমকে সংজ্ঞায়িত করে—একটি অঙ্কনযোগ্য সম্পদ এবং এর সময়কাল। Drawable
অ্যানিমেশনের জন্য এখানে একটি উদাহরণ XML ফাইল রয়েছে:
<animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="true"> <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>
এই অ্যানিমেশনটি তিনটি ফ্রেমের জন্য চলে। তালিকার android:oneshot
অ্যাট্রিবিউটটিকে true
সেট করা এটিকে একবার চক্র করে এবং তারপর থামিয়ে শেষ ফ্রেমে ধরে রাখে। আপনি যদি android:oneshot
তে false
সেট করেন, তাহলে অ্যানিমেশন লুপ হয়ে যাবে।
আপনি যদি এই XMLটিকে প্রজেক্টের res/drawable/
ডিরেক্টরিতে rocket_thrust.xml
হিসাবে সংরক্ষণ করেন, তাহলে আপনি এটিকে একটি View
ব্যাকগ্রাউন্ড ইমেজ হিসাবে যুক্ত করতে পারেন এবং তারপর এটিকে প্লে করতে start()
কল করতে পারেন। এখানে একটি ক্রিয়াকলাপের একটি উদাহরণ যেখানে অ্যানিমেশনটি একটি ImageView
এ যোগ করা হয় এবং তারপর যখন স্ক্রীনটি স্পর্শ করা হয় তখন অ্যানিমেট করা হয়:
কোটলিন
private lateinit var rocketAnimation: AnimationDrawable override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.main) val rocketImage = findViewById<ImageView>(R.id.rocket_image).apply { setBackgroundResource(R.drawable.rocket_thrust) rocketAnimation = background as AnimationDrawable } rocketImage.setOnClickListener({ rocketAnimation.start() }) }
জাভা
AnimationDrawable rocketAnimation; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ImageView rocketImage = (ImageView) findViewById(R.id.rocket_image); rocketImage.setBackgroundResource(R.drawable.rocket_thrust); rocketAnimation = (AnimationDrawable) rocketImage.getBackground(); rocketImage.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { rocketAnimation.start(); } }); }
এটা মনে রাখা গুরুত্বপূর্ণ যে AnimationDrawable
এ কল করা start()
পদ্ধতিটি আপনার Activity
এর onCreate()
পদ্ধতির সময় কল করা যাবে না, কারণ AnimationDrawable
এখনও সম্পূর্ণভাবে উইন্ডোতে সংযুক্ত নয়। অ্যানিমেশনটি অবিলম্বে চালানোর জন্য, ইন্টারঅ্যাকশনের প্রয়োজন ছাড়াই, আপনি এটিকে আপনার Activity
পদ্ধতি থেকে কল করতে পারেন, যেটিকে বলা হয় যখন Android স্ক্রীনে দৃশ্যটিকে দৃশ্যমান করে।onStart()
XML সিনট্যাক্স এবং উপলব্ধ ট্যাগ এবং বৈশিষ্ট্য সম্পর্কে আরও তথ্যের জন্য, অ্যানিমেশন সংস্থান দেখুন।
AnimatedVectorDrawable ব্যবহার করুন
একটি ভেক্টর ড্রয়েবল হল এক ধরনের অঙ্কনযোগ্য যা পিক্সেলেটেড বা ঝাপসা ছাড়াই মাপযোগ্য। AnimatedVectorDrawable
ক্লাস —এবং AnimatedVectorDrawableCompat
পশ্চাদগামী সামঞ্জস্যের জন্য — আপনাকে একটি ভেক্টরের বৈশিষ্ট্যগুলিকে অ্যানিমেট করতে দেয়, যেমন এটিকে ঘোরানো বা পাথ ডেটা পরিবর্তন করে এটিকে একটি ভিন্ন চিত্রে পরিণত করা।
আপনি সাধারণত তিনটি XML ফাইলে অ্যানিমেটেড ভেক্টর অঙ্কনযোগ্য সংজ্ঞায়িত করেন:
-
res/drawable/
এ<vector>
উপাদানের সাথে একটি ভেক্টর অঙ্কনযোগ্য। - একটি অ্যানিমেটেড ভেক্টর
res/drawable/
-এ<animated-vector>
উপাদানের সাথে অঙ্কনযোগ্য। -
res/animator/
-এ<objectAnimator>
উপাদান সহ এক বা একাধিক অবজেক্ট অ্যানিমেটর।
অ্যানিমেটেড ভেক্টর ড্রয়েবলগুলি <group>
এবং <path>
উপাদানগুলির বৈশিষ্ট্যগুলিকে অ্যানিমেট করতে পারে। <group>
উপাদানটি পাথ বা সাবগ্রুপের একটি সেট সংজ্ঞায়িত করে এবং <path>
উপাদানটি আঁকার পাথগুলিকে সংজ্ঞায়িত করে।
আপনি যখন অ্যানিমেট করতে চান এমন একটি ভেক্টর অঙ্কনযোগ্য সংজ্ঞায়িত করেন, তখন গোষ্ঠী এবং পাথগুলিতে একটি অনন্য নাম বরাদ্দ করতে android:name
বৈশিষ্ট্যটি ব্যবহার করুন, যাতে আপনি আপনার অ্যানিমেটর সংজ্ঞা থেকে সেগুলি উল্লেখ করতে পারেন। যেমন:
<vector xmlns:android="http://schemas.android.com/apk/res/android" android:height="64dp" android:width="64dp" android:viewportHeight="600" android:viewportWidth="600"> <group android:name="rotationGroup" android:pivotX="300.0" android:pivotY="300.0" android:rotation="45.0" > <path android:name="v" android:fillColor="#000000" android:pathData="M300,70 l 0,-70 70,70 0,0 -70,70z" /> </group> </vector>
অ্যানিমেটেড ভেক্টর অঙ্কনযোগ্য সংজ্ঞাটি ভেক্টরের গোষ্ঠী এবং পথগুলিকে তাদের নামের দ্বারা অঙ্কনযোগ্য বোঝায়:
<animated-vector xmlns:android="http://schemas.android.com/apk/res/android" android:drawable="@drawable/vectordrawable" > <target android:name="rotationGroup" android:animation="@animator/rotation" /> <target android:name="v" android:animation="@animator/path_morph" /> </animated-vector>
অ্যানিমেশন সংজ্ঞা ObjectAnimator
বা AnimatorSet
অবজেক্টের প্রতিনিধিত্ব করে। এই উদাহরণে প্রথম অ্যানিমেটর টার্গেট গ্রুপকে 360 ডিগ্রি ঘোরায়:
<objectAnimator android:duration="6000" android:propertyName="rotation" android:valueFrom="0" android:valueTo="360" />
এই উদাহরণের দ্বিতীয় অ্যানিমেটরটি ভেক্টর ড্রয়েবলের পথকে এক আকার থেকে অন্য আকারে রূপান্তরিত করে। পাথগুলি অবশ্যই মরফিংয়ের জন্য সামঞ্জস্যপূর্ণ হতে হবে: তাদের অবশ্যই একই সংখ্যক কমান্ড এবং প্রতিটি কমান্ডের জন্য একই সংখ্যক পরামিতি থাকতে হবে।
<set xmlns:android="http://schemas.android.com/apk/res/android"> <objectAnimator android:duration="3000" android:propertyName="pathData" android:valueFrom="M300,70 l 0,-70 70,70 0,0 -70,70z" android:valueTo="M300,70 l 0,-70 70,0 0,140 -70,0 z" android:valueType="pathType" /> </set>
এখানে ফলস্বরূপ AnimatedVectorDrawable
রয়েছে:
AnimatedVectorDrawable
।অ্যানিমেটেড ভেক্টর অঙ্কনযোগ্য (AVD) পূর্বরূপ
অ্যান্ড্রয়েড স্টুডিওতে অ্যানিমেটেড ভেক্টর অঙ্কনযোগ্য টুল আপনাকে অ্যানিমেটেড অঙ্কনযোগ্য সংস্থানগুলির পূর্বরূপ দেখতে দেয়। এই টুলটি আপনাকে Android স্টুডিওতে <animation-list>
, <animated-vector>
, এবং <animated-selector>
রিসোর্সের পূর্বরূপ দেখতে সাহায্য করে এবং আপনার কাস্টম অ্যানিমেশনগুলিকে আরও সহজ করে তোলে।
আরও তথ্যের জন্য, AnimatedVectorDrawable
এর API রেফারেন্স দেখুন।