নেভিগেশন কম্পোনেন্ট আপনাকে অ্যাকশনে সম্পত্তি যোগ করতে এবং অ্যানিমেশন দেখতে দেয়। আপনার নিজস্ব অ্যানিমেশন তৈরি করতে, অ্যানিমেশন সংস্থানগুলি দেখুন।
আপনাকে শুরু করতে নেভিগেশনে বেশ কিছু ডিফল্ট অ্যানিমেশনও অন্তর্ভুক্ত রয়েছে। একটি অ্যাকশনে অ্যানিমেশন যোগ করতে, নিম্নলিখিতগুলি করুন:
- নেভিগেশন এডিটরে, অ্যানিমেশন যেখানে হওয়া উচিত সেখানে অ্যাকশনে ক্লিক করুন।
- অ্যাট্রিবিউট প্যানেলের অ্যানিমেশন বিভাগে, আপনি যে অ্যানিমেশন যোগ করতে চান তার পাশের ড্রপডাউন তীরটিতে ক্লিক করুন। আপনি নিম্নলিখিত ধরনের মধ্যে চয়ন করতে পারেন:
- একটি গন্তব্য প্রবেশ
- একটি গন্তব্য থেকে প্রস্থান করা হচ্ছে
- একটি পপ অ্যাকশনের মাধ্যমে একটি গন্তব্যে প্রবেশ করা, একটি ক্রিয়া যা নেভিগেট করার সময় পিছনের স্ট্যাকের বাইরে অতিরিক্ত গন্তব্যগুলি পপ করে৷
- একটি পপ অ্যাকশনের মাধ্যমে একটি গন্তব্য থেকে প্রস্থান করা
- প্রদর্শিত প্রজেক্ট অ্যানিমেশনের তালিকা থেকে একটি অ্যানিমেশন চয়ন করুন।

একবার আপনি অ্যানিমেশন যোগ করলে, XML টেক্সট ভিউতে টগল করতে টেক্সট ট্যাবে ক্লিক করুন। অ্যানিমেশনের জন্য XML এখন সংশ্লিষ্ট <action>
উপাদানে উপস্থিত হয়। নিম্নলিখিত উদাহরণে, confirmationAction
অ্যাকশনের উৎস গন্তব্য specifyAmountFragment
:
<fragment
android:id="@+id/specifyAmountFragment"
android:name="com.example.buybuddy.buybuddy.SpecifyAmountFragment"
android:label="fragment_specify_amount"
tools:layout="@layout/fragment_specify_amount">
<action
android:id="@+id/confirmationAction"
app:destination="@id/confirmationFragment"
app:enterAnim="@anim/slide_in_right"
app:exitAnim="@anim/slide_out_left"
app:popEnterAnim="@anim/slide_in_left"
app:popExitAnim="@anim/slide_out_right" />
</fragment>
গন্তব্যের মধ্যে ভাগ করা উপাদান স্থানান্তর যোগ করুন
যখন একটি দৃশ্য দুটি গন্তব্যের মধ্যে ভাগ করা হয়, তখন আপনি একটি ভাগ করা উপাদান ট্রানজিশন ব্যবহার করতে পারেন যাতে একটি গন্তব্য থেকে অন্য গন্তব্যে নেভিগেট করার সময় দৃশ্যটি কীভাবে রূপান্তরিত হয় তা নির্ধারণ করতে। শেয়ার্ড এলিমেন্ট ট্রানজিশন ট্রানজিশন ফ্রেমওয়ার্কের অংশ।
ভাগ করা উপাদানগুলি আপনার নেভিগেশন XML ফাইলের মাধ্যমে নয় বরং প্রোগ্রাম্যাটিকভাবে সরবরাহ করা হয়। ক্রিয়াকলাপ এবং খণ্ড গন্তব্যের প্রতিটিতে Navigator.Extras
একটি সাবক্লাস রয়েছে৷ এক্সট্রাস ইন্টারফেস যা ভাগ করা উপাদান সহ নেভিগেশনের জন্য অতিরিক্ত বিকল্পগুলি গ্রহণ করে৷ navigate()
কল করার সময় আপনি এই Extras
পাস করতে পারেন।
ভাগ করা উপাদান একটি টুকরো গন্তব্যে স্থানান্তর করে৷
FragmentNavigator.Extras
ক্লাস আপনাকে একটি গন্তব্য থেকে অন্য গন্তব্যে ভাগ করা উপাদানগুলিকে তাদের রূপান্তর নাম দ্বারা ম্যাপ করতে দেয়, যেমন FragmentTransaction.addSharedElement()
ব্যবহার করে। তারপরে আপনি navigate()
এর জন্য অতিরিক্তগুলি পাস করতে পারেন, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
val extras = FragmentNavigatorExtras(view1 to "hero_image")
view.findNavController().navigate(
R.id.confirmationAction,
null, // Bundle of args
null, // NavOptions
extras)
FragmentNavigator.Extras extras = new FragmentNavigator.Extras.Builder()
.addSharedElement(view1, "hero_image")
.build();
Navigation.findNavController(view).navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras);
ভাগ করা উপাদান একটি কার্যকলাপ গন্তব্য স্থানান্তর
শেয়ার্ড এলিমেন্ট ট্রানজিশন নিয়ন্ত্রণ করতে কার্যকলাপগুলি ActivityOptionsCompat
এর উপর নির্ভর করে যেমন একটি শেয়ার্ড এলিমেন্ট ডকুমেন্টেশনের সাথে একটি কার্যকলাপ শুরু করুন এবং নীচের উদাহরণে দেখানো হয়েছে:
// Rename the Pair class from the Android framework to avoid a name clash
import android.util.Pair as UtilPair
...
val options = ActivityOptionsCompat.makeSceneTransitionAnimation(activity,
UtilPair.create(view1, "hero_image"))
val extras = ActivityNavigatorExtras(options)
view.findNavController().navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras)
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(this,
Pair.create(view1, "hero_image"));
ActivityNavigatorExtras extras = new ActivityNavigatorExtras.Builder()
.setActivityOptions(options)
.build();
Navigation.findNavController(view).navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras);
কার্যকলাপ পরিবর্তনে পপ অ্যানিমেশন প্রয়োগ করুন
যখন আপনি কোনো Activity
বা থেকে নেভিগেট করেন, তখন পপ অ্যানিমেশনগুলি স্বয়ংক্রিয়ভাবে প্রয়োগ হয় না৷ পরিবর্তে, আপনাকে অবশ্যই ActivityNavigator.applyPopAnimationsToPendingTransition()
টার্গেট Activity
গন্তব্য থেকে কল করতে হবে যেখানে অ্যানিমেশন হওয়া উচিত:
override fun finish() {
super.finish()
ActivityNavigator.applyPopAnimationsToPendingTransition(this)
}
@Override
public void finish() {
super.finish();
ActivityNavigator.applyPopAnimationsToPendingTransition(this);
}
নেভিগেশন কম্পোনেন্ট আপনাকে অ্যাকশনে সম্পত্তি যোগ করতে এবং অ্যানিমেশন দেখতে দেয়। আপনার নিজস্ব অ্যানিমেশন তৈরি করতে, অ্যানিমেশন সংস্থানগুলি দেখুন।
আপনাকে শুরু করতে নেভিগেশনে বেশ কিছু ডিফল্ট অ্যানিমেশনও অন্তর্ভুক্ত রয়েছে। একটি অ্যাকশনে অ্যানিমেশন যোগ করতে, নিম্নলিখিতগুলি করুন:
- নেভিগেশন এডিটরে, অ্যানিমেশন যেখানে হওয়া উচিত সেখানে অ্যাকশনে ক্লিক করুন।
- অ্যাট্রিবিউট প্যানেলের অ্যানিমেশন বিভাগে, আপনি যে অ্যানিমেশন যোগ করতে চান তার পাশের ড্রপডাউন তীরটিতে ক্লিক করুন। আপনি নিম্নলিখিত ধরনের মধ্যে চয়ন করতে পারেন:
- একটি গন্তব্য প্রবেশ
- একটি গন্তব্য থেকে প্রস্থান করা হচ্ছে
- একটি পপ অ্যাকশনের মাধ্যমে একটি গন্তব্যে প্রবেশ করা, একটি ক্রিয়া যা নেভিগেট করার সময় পিছনের স্ট্যাকের বাইরে অতিরিক্ত গন্তব্যগুলি পপ করে৷
- একটি পপ অ্যাকশনের মাধ্যমে একটি গন্তব্য থেকে প্রস্থান করা
- প্রদর্শিত প্রজেক্ট অ্যানিমেশনের তালিকা থেকে একটি অ্যানিমেশন চয়ন করুন।

একবার আপনি অ্যানিমেশন যোগ করলে, XML টেক্সট ভিউতে টগল করতে টেক্সট ট্যাবে ক্লিক করুন। অ্যানিমেশনের জন্য XML এখন সংশ্লিষ্ট <action>
উপাদানে উপস্থিত হয়। নিম্নলিখিত উদাহরণে, confirmationAction
অ্যাকশনের উৎস গন্তব্য specifyAmountFragment
:
<fragment
android:id="@+id/specifyAmountFragment"
android:name="com.example.buybuddy.buybuddy.SpecifyAmountFragment"
android:label="fragment_specify_amount"
tools:layout="@layout/fragment_specify_amount">
<action
android:id="@+id/confirmationAction"
app:destination="@id/confirmationFragment"
app:enterAnim="@anim/slide_in_right"
app:exitAnim="@anim/slide_out_left"
app:popEnterAnim="@anim/slide_in_left"
app:popExitAnim="@anim/slide_out_right" />
</fragment>
গন্তব্যের মধ্যে ভাগ করা উপাদান স্থানান্তর যোগ করুন
যখন একটি দৃশ্য দুটি গন্তব্যের মধ্যে ভাগ করা হয়, তখন আপনি একটি ভাগ করা উপাদান ট্রানজিশন ব্যবহার করতে পারেন যাতে একটি গন্তব্য থেকে অন্য গন্তব্যে নেভিগেট করার সময় দৃশ্যটি কীভাবে রূপান্তরিত হয় তা নির্ধারণ করতে। শেয়ার্ড এলিমেন্ট ট্রানজিশন ট্রানজিশন ফ্রেমওয়ার্কের অংশ।
ভাগ করা উপাদানগুলি আপনার নেভিগেশন XML ফাইলের মাধ্যমে নয় বরং প্রোগ্রাম্যাটিকভাবে সরবরাহ করা হয়। ক্রিয়াকলাপ এবং খণ্ড গন্তব্যের প্রতিটিতে Navigator.Extras
একটি সাবক্লাস রয়েছে৷ এক্সট্রাস ইন্টারফেস যা ভাগ করা উপাদান সহ নেভিগেশনের জন্য অতিরিক্ত বিকল্পগুলি গ্রহণ করে৷ navigate()
কল করার সময় আপনি এই Extras
পাস করতে পারেন।
ভাগ করা উপাদান একটি টুকরো গন্তব্যে স্থানান্তর করে৷
FragmentNavigator.Extras
ক্লাস আপনাকে একটি গন্তব্য থেকে অন্য গন্তব্যে ভাগ করা উপাদানগুলিকে তাদের রূপান্তর নাম দ্বারা ম্যাপ করতে দেয়, যেমন FragmentTransaction.addSharedElement()
ব্যবহার করে। তারপরে আপনি navigate()
এর জন্য অতিরিক্তগুলি পাস করতে পারেন, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
val extras = FragmentNavigatorExtras(view1 to "hero_image")
view.findNavController().navigate(
R.id.confirmationAction,
null, // Bundle of args
null, // NavOptions
extras)
FragmentNavigator.Extras extras = new FragmentNavigator.Extras.Builder()
.addSharedElement(view1, "hero_image")
.build();
Navigation.findNavController(view).navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras);
ভাগ করা উপাদান একটি কার্যকলাপ গন্তব্য স্থানান্তর
শেয়ার্ড এলিমেন্ট ট্রানজিশন নিয়ন্ত্রণ করতে কার্যকলাপগুলি ActivityOptionsCompat
এর উপর নির্ভর করে যেমন একটি শেয়ার্ড এলিমেন্ট ডকুমেন্টেশনের সাথে একটি কার্যকলাপ শুরু করুন এবং নীচের উদাহরণে দেখানো হয়েছে:
// Rename the Pair class from the Android framework to avoid a name clash
import android.util.Pair as UtilPair
...
val options = ActivityOptionsCompat.makeSceneTransitionAnimation(activity,
UtilPair.create(view1, "hero_image"))
val extras = ActivityNavigatorExtras(options)
view.findNavController().navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras)
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(this,
Pair.create(view1, "hero_image"));
ActivityNavigatorExtras extras = new ActivityNavigatorExtras.Builder()
.setActivityOptions(options)
.build();
Navigation.findNavController(view).navigate(
R.id.details,
null, // Bundle of args
null, // NavOptions
extras);
কার্যকলাপ পরিবর্তনে পপ অ্যানিমেশন প্রয়োগ করুন
যখন আপনি কোনো Activity
বা থেকে নেভিগেট করেন, তখন পপ অ্যানিমেশনগুলি স্বয়ংক্রিয়ভাবে প্রয়োগ হয় না৷ পরিবর্তে, আপনাকে অবশ্যই ActivityNavigator.applyPopAnimationsToPendingTransition()
টার্গেট Activity
গন্তব্য থেকে কল করতে হবে যেখানে অ্যানিমেশন হওয়া উচিত:
override fun finish() {
super.finish()
ActivityNavigator.applyPopAnimationsToPendingTransition(this)
}
@Override
public void finish() {
super.finish();
ActivityNavigator.applyPopAnimationsToPendingTransition(this);
}