অ্যান্ড্রয়েড হোম স্ক্রীন, বেশিরভাগ অ্যান্ড্রয়েড-চালিত ডিভাইসে উপলব্ধ, ব্যবহারকারীকে সামগ্রীতে দ্রুত অ্যাক্সেসের জন্য অ্যাপ উইজেট (বা উইজেটগুলি ) এম্বেড করতে দেয়৷ আপনি যদি একটি হোম স্ক্রীন প্রতিস্থাপন বা অনুরূপ অ্যাপ তৈরি করছেন, তাহলে আপনি AppWidgetHost
প্রয়োগ করে ব্যবহারকারীকে উইজেট এম্বেড করতে দিতে পারেন। এটি এমন কিছু নয় যা বেশিরভাগ অ্যাপকে করতে হবে, কিন্তু আপনি যদি নিজের হোস্ট তৈরি করেন, তাহলে একটি হোস্ট যে চুক্তিবদ্ধ বাধ্যবাধকতাগুলি স্পষ্টভাবে সম্মত হয় তা বোঝা গুরুত্বপূর্ণ।
এই পৃষ্ঠাটি একটি কাস্টম AppWidgetHost
বাস্তবায়নের সাথে জড়িত দায়িত্বগুলির উপর ফোকাস করে৷ কিভাবে একটি AppWidgetHost
বাস্তবায়ন করতে হয় তার একটি নির্দিষ্ট উদাহরণের জন্য, Android হোম স্ক্রীন LauncherAppWidgetHost
এর সোর্স কোডটি দেখুন।
এখানে একটি কাস্টম AppWidgetHost
বাস্তবায়নের সাথে জড়িত মূল ক্লাস এবং ধারণাগুলির একটি ওভারভিউ রয়েছে:
অ্যাপ উইজেট হোস্ট :
AppWidgetHost
অ্যাপ উইজেট পরিষেবার সাথে মিথস্ক্রিয়া প্রদান করে যে অ্যাপগুলি তাদের UI-তে উইজেটগুলি এম্বেড করে। একটিAppWidgetHost
একটি ID থাকতে হবে যা হোস্টের নিজস্ব প্যাকেজের মধ্যে অনন্য। এই আইডি হোস্টের সমস্ত ব্যবহার জুড়ে থাকে। আইডি সাধারণত একটি হার্ডকোড করা মান যা আপনি আপনার অ্যাপে বরাদ্দ করেন।অ্যাপ উইজেট আইডি : প্রতিটি উইজেট ইনস্ট্যান্স বাঁধাই করার সময় একটি অনন্য আইডি বরাদ্দ করা হয়।
bindAppWidgetIdIfAllowed()
এবং আরও বিস্তারিত জানার জন্য, বাইন্ডিং উইজেট বিভাগটি দেখুন যা অনুসরণ করে। হোস্টallocateAppWidgetId()
ব্যবহার করে অনন্য আইডি পায়। হোস্ট থেকে মুছে না যাওয়া পর্যন্ত এই আইডি উইজেটের জীবনকাল জুড়ে থাকে। যে কোনো হোস্ট-নির্দিষ্ট অবস্থা—যেমন উইজেটের আকার এবং অবস্থান—হোস্টিং প্যাকেজ দ্বারা স্থির থাকতে হবে এবং অ্যাপ উইজেট আইডির সাথে যুক্ত থাকতে হবে।অ্যাপ উইজেট হোস্ট ভিউ :
AppWidgetHostView
কে একটি ফ্রেম হিসেবে ভাবুন যেখানে উইজেটটি যখনই প্রদর্শনের প্রয়োজন হয় তখন সেটি মোড়ানো হয়। একটি উইজেট একটিAppWidgetHostView
এর সাথে যুক্ত থাকে প্রতিবার হোস্ট দ্বারা উইজেটটি স্ফীত হয়।- ডিফল্টরূপে, সিস্টেমটি একটি
AppWidgetHostView
তৈরি করে, কিন্তু হোস্ট এটিকে প্রসারিত করেAppWidgetHostView
এর নিজস্ব উপশ্রেণী তৈরি করতে পারে। - অ্যান্ড্রয়েড 12 (এপিআই লেভেল 31) থেকে শুরু করে,
AppWidgetHostView
গতিশীলভাবে ওভারলোড হওয়া রঙগুলি পরিচালনা করার জন্যsetColorResources()
এবংresetColorResources()
পদ্ধতিগুলি প্রবর্তন করে। হোস্ট এই পদ্ধতিতে রং প্রদানের জন্য দায়ী।
- ডিফল্টরূপে, সিস্টেমটি একটি
অপশন বান্ডেল :
AppWidgetHost
অপশন বান্ডেল ব্যবহার করেAppWidgetProvider
কীভাবে উইজেট দেখানো হয়-উদাহরণস্বরূপ, সাইজ রেঞ্জের তালিকা —এবং উইজেটটি লকস্ক্রিন বা হোম স্ক্রিনে আছে কিনা সে সম্পর্কে তথ্য জানাতে। এই তথ্যটিAppWidgetProvider
কীভাবে এবং কোথায় প্রদর্শিত হবে তার উপর ভিত্তি করে উইজেটের বিষয়বস্তু এবং উপস্থিতি তৈরি করতে দেয়। আপনি একটি উইজেটের বান্ডেল পরিবর্তন করতেupdateAppWidgetOptions()
এবংupdateAppWidgetSize()
ব্যবহার করতে পারেন। এই উভয় পদ্ধতিইonAppWidgetOptionsChanged()
কলব্যাককেAppWidgetProvider
এ ট্রিগার করে।
বাইন্ডিং উইজেট
যখন একজন ব্যবহারকারী একটি হোস্টে একটি উইজেট যোগ করে, তখন বাইন্ডিং নামে একটি প্রক্রিয়া ঘটে। বাইন্ডিং বলতে একটি নির্দিষ্ট অ্যাপ উইজেট আইডিকে একটি নির্দিষ্ট হোস্ট এবং একটি নির্দিষ্ট AppWidgetProvider
এর সাথে সংযুক্ত করাকে বোঝায়।
বাইন্ডিং এপিআইগুলি হোস্টের পক্ষে বাইন্ডিংয়ের জন্য একটি কাস্টম UI প্রদান করাও সম্ভব করে তোলে। এই প্রক্রিয়াটি ব্যবহার করতে, আপনার অ্যাপটিকে অবশ্যই হোস্টের ম্যানিফেস্টে BIND_APPWIDGET
অনুমতি ঘোষণা করতে হবে:
<uses-permission android:name="android.permission.BIND_APPWIDGET" />
কিন্তু এই মাত্র প্রথম ধাপ. রানটাইমে, ব্যবহারকারীকে স্পষ্টভাবে আপনার অ্যাপটিকে হোস্টে একটি উইজেট যোগ করার অনুমতি দিতে হবে। আপনার অ্যাপের উইজেট যোগ করার অনুমতি আছে কিনা তা পরীক্ষা করতে, bindAppWidgetIdIfAllowed()
পদ্ধতি ব্যবহার করুন। bindAppWidgetIdIfAllowed()
false
রিটার্ন করলে, আপনার অ্যাপটিকে অবশ্যই একটি ডায়ালগ প্রদর্শন করতে হবে যা ব্যবহারকারীকে অনুমতি দেওয়ার জন্য অনুরোধ করে: বর্তমান উইজেট সংযোজনের জন্য "অনুমতি দিন" বা ভবিষ্যতের সমস্ত উইজেট সংযোজন কভার করার জন্য "অনুমতি দিন"।
এই স্নিপেটটি কীভাবে ডায়ালগ প্রদর্শন করতে হয় তার একটি উদাহরণ দেয়:
কোটলিন
val intent = Intent(AppWidgetManager.ACTION_APPWIDGET_BIND).apply { putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetId) putExtra(AppWidgetManager.EXTRA_APPWIDGET_PROVIDER, info.componentName) // This is the options bundle described in the preceding section. putExtra(AppWidgetManager.EXTRA_APPWIDGET_OPTIONS, options) } startActivityForResult(intent, REQUEST_BIND_APPWIDGET)
জাভা
Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_BIND); intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetId); intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_PROVIDER, info.componentName); // This is the options bundle described in the preceding section. intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_OPTIONS, options); startActivityForResult(intent, REQUEST_BIND_APPWIDGET);
হোস্টকে অবশ্যই পরীক্ষা করতে হবে যে একজন ব্যবহারকারী যে উইজেট যোগ করে সেটির কনফিগারেশনের প্রয়োজন আছে কিনা। আরও তথ্যের জন্য, অ্যাপ উইজেট কনফিগার করতে ব্যবহারকারীদের সক্ষম করুন দেখুন।
হোস্ট দায়িত্ব
আপনি AppWidgetProviderInfo
মেটাডেটা ব্যবহার করে উইজেটগুলির জন্য বেশ কয়েকটি কনফিগারেশন সেটিংস নির্দিষ্ট করতে পারেন। আপনি উইজেট প্রদানকারীর সাথে যুক্ত AppWidgetProviderInfo
অবজেক্ট থেকে নিম্নলিখিত বিভাগে আরও বিস্তারিতভাবে কভার করা এই কনফিগারেশন বিকল্পগুলি পুনরুদ্ধার করতে পারেন।
অ্যান্ড্রয়েডের যে সংস্করণই আপনি লক্ষ্য করছেন তা নির্বিশেষে, সমস্ত হোস্টের নিম্নলিখিত দায়িত্ব রয়েছে:
একটি উইজেট যোগ করার সময়, পূর্বে বর্ণিত উইজেট আইডি বরাদ্দ করুন। যখন একটি উইজেট হোস্ট থেকে সরানো হয়, তখন উইজেট আইডি ডিলোকেট করতে
deleteAppWidgetId()
এ কল করুন।একটি উইজেট যোগ করার সময়, কনফিগারেশন কার্যকলাপ চালু করা প্রয়োজন কিনা তা পরীক্ষা করুন। সাধারণত, হোস্টকে উইজেটের কনফিগারেশন অ্যাক্টিভিটি চালু করতে হবে যদি এটি বিদ্যমান থাকে এবং
configuration_optional
এবংreconfigurable
উভয় পতাকা উল্লেখ করে ঐচ্ছিক হিসেবে চিহ্নিত না হয়। বিস্তারিত জানার জন্য কনফিগারেশন কার্যকলাপ থেকে উইজেট আপডেট দেখুন। অনেক উইজেট প্রদর্শন করার আগে এটি একটি প্রয়োজনীয় পদক্ষেপ।উইজেট
AppWidgetProviderInfo
মেটাডেটাতে একটি ডিফল্ট প্রস্থ এবং উচ্চতা নির্দিষ্ট করে। এই মানগুলি কক্ষগুলিতে সংজ্ঞায়িত করা হয় — Android 12 থেকে শুরু করে, যদিtargetCellWidth
এবংtargetCellHeight
নির্দিষ্ট করা থাকে—অথবা শুধুমাত্রminWidth
এবংminHeight
নির্দিষ্ট করা থাকলে dps। উইজেট সাইজিং বৈশিষ্ট্য দেখুন।নিশ্চিত করুন যে উইজেটটি অন্তত এতগুলি ডিপিএস দিয়ে সাজানো হয়েছে। উদাহরণস্বরূপ, অনেক হোস্ট একটি গ্রিডে আইকন এবং উইজেটগুলি সারিবদ্ধ করে। এই পরিস্থিতিতে, ডিফল্টরূপে হোস্ট ন্যূনতম সংখ্যক কক্ষ ব্যবহার করে একটি উইজেট যোগ করে যা
minWidth
এবংminHeight
সীমাবদ্ধতা পূরণ করে।
পূর্ববর্তী বিভাগে তালিকাভুক্ত প্রয়োজনীয়তাগুলি ছাড়াও, নির্দিষ্ট প্ল্যাটফর্ম সংস্করণগুলি এমন বৈশিষ্ট্যগুলি প্রবর্তন করে যা হোস্টের উপর নতুন দায়িত্ব রাখে।
লক্ষ্যযুক্ত Android সংস্করণের উপর ভিত্তি করে আপনার পদ্ধতি নির্ধারণ করুন
অ্যান্ড্রয়েড 12
অ্যান্ড্রয়েড 12 (এপিআই লেভেল 31) একটি অতিরিক্ত List<SizeF>
বান্ডেল করে যাতে dps-তে সম্ভাব্য আকারের তালিকা থাকে যা একটি উইজেট উদাহরণ বিকল্প বান্ডেলে নিতে পারে। প্রদত্ত মাপের সংখ্যা হোস্ট বাস্তবায়নের উপর নির্ভর করে। হোস্ট সাধারণত ফোনের জন্য দুটি মাপ প্রদান করে—পোর্ট্রেট এবং ল্যান্ডস্কেপ—এবং ফোল্ডেবলের জন্য চারটি মাপ।
একটি AppWidgetProvider
RemoteViews
কে প্রদান করতে পারে এমন বিভিন্ন RemoteViews
এর সংখ্যার MAX_INIT_VIEW_COUNT
(16) সীমা রয়েছে। যেহেতু AppWidgetProvider
অবজেক্ট একটি RemoteViews
অবজেক্টকে List<SizeF>
, MAX_INIT_VIEW_COUNT
বেশি আকার প্রদান করবেন না।
অ্যান্ড্রয়েড 12 ডিপিএস-এ maxResizeWidth
এবং maxResizeHeight
বৈশিষ্ট্যগুলিও প্রবর্তন করে। আমরা সুপারিশ করি যে একটি উইজেট যা এই বৈশিষ্ট্যগুলির মধ্যে অন্তত একটি ব্যবহার করে সেটি বৈশিষ্ট্যগুলির দ্বারা নির্দিষ্ট করা আকারের বেশি না হয়৷
অতিরিক্ত সম্পদ
-
Glance
রেফারেন্স ডকুমেন্টেশন দেখুন.