অ্যাপ উইজেট হল ক্ষুদ্রাকৃতির অ্যাপ ভিউ যা আপনি অন্যান্য অ্যাপে এম্বেড করতে পারেন—যেমন হোম স্ক্রীন—এবং পর্যায়ক্রমিক আপডেট পেতে পারেন। এই ভিউগুলিকে ইউজার ইন্টারফেসে উইজেট হিসাবে উল্লেখ করা হয় এবং আপনি একটি অ্যাপ উইজেট প্রদানকারী (বা উইজেট প্রদানকারী ) দিয়ে একটি প্রকাশ করতে পারেন। একটি অ্যাপ কম্পোনেন্ট যা অন্যান্য উইজেট ধারণ করে তাকে অ্যাপ উইজেট হোস্ট (বা উইজেট হোস্ট ) বলা হয়। চিত্র 1 একটি নমুনা সঙ্গীত উইজেট দেখায়:
এই দস্তাবেজটি বর্ণনা করে কিভাবে একটি উইজেট প্রদানকারী ব্যবহার করে একটি উইজেট প্রকাশ করতে হয়। অ্যাপ উইজেট হোস্ট করতে আপনার নিজস্ব AppWidgetHost
তৈরি করার বিষয়ে বিস্তারিত জানার জন্য, একটি উইজেট হোস্ট তৈরি করুন দেখুন।
আপনার উইজেট কীভাবে ডিজাইন করবেন সে সম্পর্কে তথ্যের জন্য, অ্যাপ উইজেট ওভারভিউ দেখুন।
উইজেট উপাদান
একটি উইজেট তৈরি করতে, আপনার নিম্নলিখিত মৌলিক উপাদানগুলির প্রয়োজন:
-
AppWidgetProviderInfo
অবজেক্ট - একটি উইজেটের মেটাডেটা বর্ণনা করে, যেমন উইজেটের লেআউট, আপডেট ফ্রিকোয়েন্সি এবং
AppWidgetProvider
ক্লাস।AppWidgetProviderInfo
XML-এ সংজ্ঞায়িত করা হয়েছে , যেমন এই নথিতে বর্ণনা করা হয়েছে। -
AppWidgetProvider
ক্লাস - মৌলিক পদ্ধতিগুলিকে সংজ্ঞায়িত করে যা আপনাকে প্রোগ্রাম্যাটিকভাবে উইজেটের সাথে ইন্টারফেস করতে দেয়। এটির মাধ্যমে, উইজেট আপডেট, সক্ষম, নিষ্ক্রিয় বা মুছে ফেলা হলে আপনি সম্প্রচার পাবেন। আপনি ম্যানিফেস্টে
AppWidgetProvider
ঘোষণা করেন এবং তারপর এই নথিতে বর্ণিত হিসাবে এটি বাস্তবায়ন করেন । - লেআউট দেখুন
- উইজেটের জন্য প্রাথমিক বিন্যাস সংজ্ঞায়িত করে। এই নথিতে বর্ণিত লেআউটটি XML-এ সংজ্ঞায়িত করা হয়েছে ।
চিত্র 2 দেখায় কিভাবে এই উপাদানগুলি সামগ্রিক অ্যাপ উইজেট প্রক্রিয়াকরণ প্রবাহের সাথে ফিট করে৷
আপনার উইজেটের ব্যবহারকারীর কনফিগারেশনের প্রয়োজন হলে, অ্যাপ উইজেট কনফিগারেশন কার্যকলাপ বাস্তবায়ন করুন। এই কার্যকলাপ ব্যবহারকারীদের উইজেট সেটিংস পরিবর্তন করতে দেয়—উদাহরণস্বরূপ, একটি ঘড়ি উইজেটের সময় অঞ্চল।
- Android 12 (API স্তর 31) থেকে শুরু করে, আপনি একটি ডিফল্ট কনফিগারেশন প্রদান করতে পারেন এবং ব্যবহারকারীদের পরে উইজেটটি পুনরায় কনফিগার করতে দিতে পারেন। আরও বিশদ বিবরণের জন্য উইজেটের ডিফল্ট কনফিগারেশন ব্যবহার করুন এবং ব্যবহারকারীদের স্থাপন করা উইজেটগুলি পুনরায় কনফিগার করতে সক্ষম করুন দেখুন।
- অ্যান্ড্রয়েড 11 (এপিআই লেভেল 30) বা তার নিচে, ব্যবহারকারী যখনই তাদের হোম স্ক্রিনে উইজেট যোগ করে তখনই এই অ্যাক্টিভিটি চালু হয়।
এছাড়াও আমরা নিম্নলিখিত উন্নতিগুলির সুপারিশ করি: নমনীয় উইজেট বিন্যাস , বিবিধ বর্ধন , উন্নত উইজেট , সংগ্রহ উইজেট , এবং একটি উইজেট হোস্ট তৈরি করা ৷
AppWidgetProviderInfo XML ঘোষণা করুন
AppWidgetProviderInfo
অবজেক্ট একটি উইজেটের প্রয়োজনীয় গুণাবলী সংজ্ঞায়িত করে। একটি একক <appwidget-provider>
উপাদান ব্যবহার করে একটি XML রিসোর্স ফাইলে AppWidgetProviderInfo
অবজেক্টটি সংজ্ঞায়িত করুন এবং প্রকল্পের res/xml/
ফোল্ডারে সংরক্ষণ করুন।
এটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
android:minWidth="40dp"
android:minHeight="40dp"
android:targetCellWidth="1"
android:targetCellHeight="1"
android:maxResizeWidth="250dp"
android:maxResizeHeight="120dp"
android:updatePeriodMillis="86400000"
android:description="@string/example_appwidget_description"
android:previewLayout="@layout/example_appwidget_preview"
android:initialLayout="@layout/example_loading_appwidget"
android:configure="com.example.android.ExampleAppWidgetConfigurationActivity"
android:resizeMode="horizontal|vertical"
android:widgetCategory="home_screen"
android:widgetFeatures="reconfigurable|configuration_optional">
</appwidget-provider>
উইজেট সাইজিং বৈশিষ্ট্য
ডিফল্ট হোম স্ক্রীন তার উইন্ডোতে উইজেটগুলিকে একটি নির্দিষ্ট উচ্চতা এবং প্রস্থের কোষগুলির গ্রিডের উপর ভিত্তি করে অবস্থান করে। বেশিরভাগ হোম স্ক্রীন শুধুমাত্র উইজেটগুলিকে গ্রিড কোষের পূর্ণসংখ্যার মাপ নিতে দেয়—উদাহরণস্বরূপ, দুটি কক্ষ অনুভূমিকভাবে তিনটি কোষ দ্বারা উল্লম্বভাবে।
উইজেট সাইজিং বৈশিষ্ট্যগুলি আপনাকে আপনার উইজেটের জন্য একটি ডিফল্ট আকার নির্দিষ্ট করতে দেয় এবং উইজেটের আকারে নিম্ন এবং উপরের সীমানা প্রদান করে। এই প্রসঙ্গে, একটি উইজেটের ডিফল্ট আকার হল সেই মাপ যা উইজেটটি প্রথমবার হোম স্ক্রিনে যোগ করার সময় নেয়।
নিচের সারণীটি <appwidget-provider>
উইজেট সাইজিং সম্পর্কিত বৈশিষ্ট্যগুলি বর্ণনা করে:
গুণাবলী এবং বর্ণনা | |
---|---|
targetCellWidth এবং targetCellHeight (Android 12), minWidth এবং minHeight |
targetCellWidth এবং targetCellHeight , এবং minWidth এবং minHeight — যাতে ব্যবহারকারীর ডিভাইস targetCellWidth এবং targetCellHeight সমর্থন না করলে আপনার অ্যাপটি minWidth এবং minHeight ব্যবহারে ফিরে যেতে পারে। সমর্থিত হলে, targetCellWidth এবং targetCellHeight বৈশিষ্ট্যগুলি minWidth এবং minHeight বৈশিষ্ট্যগুলির উপর অগ্রাধিকার পায়৷ |
minResizeWidth এবং minResizeHeight | উইজেটের সর্বনিম্ন আকার নির্দিষ্ট করুন। এই মানগুলি নির্দিষ্ট করে যে আকারের অধীনে উইজেটটি অপাঠ্য বা অন্যথায় অব্যবহারযোগ্য। এই বৈশিষ্ট্যগুলি ব্যবহার করে ব্যবহারকারীকে উইজেটের আকার পরিবর্তন করতে দেয় যা ডিফল্ট উইজেট আকারের চেয়ে ছোট। minResizeWidth অ্যাট্রিবিউটটি উপেক্ষা করা হয় যদি এটি minWidth থেকে বেশি হয় বা অনুভূমিক আকার পরিবর্তন সক্ষম না থাকে। resizeMode দেখুন। একইভাবে, minResizeHeight অ্যাট্রিবিউট উপেক্ষা করা হয় যদি এটি minHeight এর চেয়ে বড় হয় বা উল্লম্ব আকার পরিবর্তন সক্ষম না করা হয়। |
maxResizeWidth এবং maxResizeHeight | উইজেটের প্রস্তাবিত সর্বোচ্চ আকার নির্দিষ্ট করুন। যদি মানগুলি গ্রিড ঘরের মাত্রার একাধিক না হয়, তবে সেগুলি নিকটতম কক্ষের আকার পর্যন্ত বৃত্তাকার করা হয়৷ maxResizeWidth অ্যাট্রিবিউট উপেক্ষা করা হয় যদি এটি minWidth এর চেয়ে ছোট হয় বা অনুভূমিক আকার পরিবর্তন সক্ষম না থাকে। resizeMode দেখুন। একইভাবে, maxResizeHeight অ্যাট্রিবিউট উপেক্ষা করা হয় যদি এটি minHeight এর চেয়ে বড় হয় বা উল্লম্ব আকার পরিবর্তন সক্ষম না করা হয়। অ্যান্ড্রয়েড 12 এ চালু করা হয়েছে। |
resizeMode | একটি উইজেটের আকার পরিবর্তন করা যেতে পারে এমন নিয়মগুলি নির্দিষ্ট করে৷ আপনি হোম স্ক্রীন উইজেটগুলিকে অনুভূমিকভাবে, উল্লম্বভাবে বা উভয় অক্ষে আকার পরিবর্তনযোগ্য করতে এই বৈশিষ্ট্যটি ব্যবহার করতে পারেন। ব্যবহারকারীরা একটি উইজেট স্পর্শ করে এবং ধরে রাখে তার আকার পরিবর্তনের হ্যান্ডলগুলি দেখানোর জন্য, তারপর লেআউট গ্রিডে এর আকার পরিবর্তন করতে অনুভূমিক বা উল্লম্ব হ্যান্ডলগুলিকে টেনে আনুন৷ resizeMode অ্যাট্রিবিউটের মানগুলির মধ্যে horizontal , vertical এবং none অন্তর্ভুক্ত নয়। একটি উইজেটকে অনুভূমিকভাবে এবং উল্লম্বভাবে আকার পরিবর্তনযোগ্য হিসাবে ঘোষণা করতে, horizontal|vertical ব্যবহার করুন। |
উদাহরণ
পূর্ববর্তী টেবিলের বৈশিষ্ট্যগুলি কীভাবে উইজেট আকারকে প্রভাবিত করে তা ব্যাখ্যা করতে, নিম্নলিখিত বৈশিষ্ট্যগুলি অনুমান করুন:
- একটি গ্রিড সেল 30 ডিপি প্রশস্ত এবং 50 ডিপি লম্বা।
- নিম্নলিখিত বৈশিষ্ট্য স্পেসিফিকেশন প্রদান করা হয়:
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
android:minWidth="80dp"
android:minHeight="80dp"
android:targetCellWidth="2"
android:targetCellHeight="2"
android:minResizeWidth="40dp"
android:minResizeHeight="40dp"
android:maxResizeWidth="120dp"
android:maxResizeHeight="120dp"
android:resizeMode="horizontal|vertical" />
Android 12 দিয়ে শুরু:
উইজেটের ডিফল্ট আকার হিসাবে targetCellWidth
এবং targetCellHeight
বৈশিষ্ট্যগুলি ব্যবহার করুন৷
উইজেটের আকার ডিফল্টরূপে 2x2। উইজেটটির আকার 2x1 বা 4x3 পর্যন্ত পরিবর্তন করা যেতে পারে।
Android 11 এবং নিম্নতর:
উইজেটের ডিফল্ট আকার গণনা করতে minWidth
এবং minHeight
বৈশিষ্ট্যগুলি ব্যবহার করুন৷
ডিফল্ট প্রস্থ = Math.ceil(80 / 30)
= 3
ডিফল্ট উচ্চতা = Math.ceil(80 / 50)
= 2
উইজেটের আকার ডিফল্টরূপে 3x2। উইজেটটি 2x1 বা পূর্ণ স্ক্রীন পর্যন্ত আকার পরিবর্তন করা যেতে পারে।
অতিরিক্ত উইজেট বৈশিষ্ট্য
নিম্নলিখিত সারণীতে <appwidget-provider>
বৈশিষ্ট্যগুলি বর্ণনা করা হয়েছে যা উইজেট আকার ছাড়া অন্য গুণাবলীর সাথে সম্পর্কিত।
গুণাবলী এবং বর্ণনা | |
---|---|
updatePeriodMillis | উইজেট ফ্রেমওয়ার্ক কত ঘন ঘন onUpdate() কলব্যাক পদ্ধতিতে কল করে AppWidgetProvider থেকে একটি আপডেটের অনুরোধ করে তা নির্ধারণ করে। এই মানের সাথে সঠিক সময়ে প্রকৃত আপডেট হওয়ার নিশ্চয়তা দেওয়া হয় না, এবং ব্যাটারি সংরক্ষণের জন্য আমরা যতটা সম্ভব কম সময়ে আপডেট করার পরামর্শ দিই—ঘণ্টায় একবারের বেশি নয়। একটি উপযুক্ত আপডেট সময় বাছাই করার জন্য বিবেচনার সম্পূর্ণ তালিকার জন্য, উইজেট সামগ্রী আপডেট করার জন্য অপ্টিমাইজেশন দেখুন। |
initialLayout | লেআউট রিসোর্সের দিকে নির্দেশ করে যা উইজেট লেআউটকে সংজ্ঞায়িত করে। |
configure | ব্যবহারকারী যখন উইজেট যোগ করে তখন তাদের উইজেট বৈশিষ্ট্য কনফিগার করতে দিয়ে যে কার্যকলাপটি চালু হয় তা সংজ্ঞায়িত করে। উইজেট কনফিগার করতে ব্যবহারকারীদের সক্ষম করুন দেখুন। Android 12 থেকে শুরু করে, আপনার অ্যাপ প্রাথমিক কনফিগারেশন এড়িয়ে যেতে পারে। বিস্তারিত জানার জন্য উইজেটের ডিফল্ট কনফিগারেশন ব্যবহার করুন দেখুন। |
description | আপনার উইজেটের জন্য প্রদর্শন করার জন্য উইজেট বাছাইকারীর বিবরণ নির্দিষ্ট করে। অ্যান্ড্রয়েড 12 এ চালু করা হয়েছে। |
previewLayout (Android 12) এবং previewImage (Android 11 এবং নিম্ন) |
previewImage এবং previewLayout উভয় বৈশিষ্ট্যই নির্দিষ্ট করার পরামর্শ দিই যাতে ব্যবহারকারীর ডিভাইস previewLayout সমর্থন না করলে আপনার অ্যাপ previewImage ব্যবহার করতে পারে। আরও বিশদ বিবরণের জন্য, স্কেলযোগ্য উইজেট পূর্বরূপগুলির সাথে পশ্চাদগামী সামঞ্জস্য দেখুন। |
autoAdvanceViewId | উইজেট সাবভিউয়ের ভিউ আইডি নির্দিষ্ট করে যা উইজেটের হোস্ট দ্বারা স্বয়ংক্রিয়ভাবে উন্নত হয়। |
widgetCategory | আপনার উইজেট হোম স্ক্রিনে ( home_screen ), লক স্ক্রীন ( keyguard ) বা উভয়েই প্রদর্শিত হতে পারে কিনা তা ঘোষণা করে৷ Android 5.0 এবং উচ্চতর সংস্করণের জন্য, শুধুমাত্র home_screen বৈধ। |
widgetFeatures | উইজেট দ্বারা সমর্থিত বৈশিষ্ট্য ঘোষণা করে। উদাহরণস্বরূপ, যদি আপনি চান যে আপনার উইজেটটি তার ডিফল্ট কনফিগারেশন ব্যবহার করুক যখন একজন ব্যবহারকারী এটি যোগ করে, configuration_optional এবং reconfigurable উভয় পতাকা উল্লেখ করুন। এটি একটি ব্যবহারকারী উইজেট যোগ করার পরে কনফিগারেশন কার্যকলাপ চালু করা বাইপাস করে। ব্যবহারকারী তারপরেও উইজেটটি পুনরায় কনফিগার করতে পারেন। |
উইজেট সম্প্রচার পরিচালনা করতে AppWidgetProvider ক্লাস ব্যবহার করুন
AppWidgetProvider
ক্লাস উইজেট সম্প্রচার পরিচালনা করে এবং উইজেট লাইফসাইকেল ইভেন্টগুলির প্রতিক্রিয়া হিসাবে উইজেট আপডেট করে। নিম্নলিখিত বিভাগগুলি বর্ণনা করে যে কীভাবে ম্যানিফেস্টে AppWidgetProvider
ঘোষণা করা যায় এবং তারপরে এটি বাস্তবায়ন করা যায়।
ম্যানিফেস্টে একটি উইজেট ঘোষণা করুন
প্রথমে, আপনার অ্যাপের AndroidManifest.xml
ফাইলে AppWidgetProvider
ক্লাস ঘোষণা করুন, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
<receiver android:name="ExampleAppWidgetProvider"
android:exported="false">
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<meta-data android:name="android.appwidget.provider"
android:resource="@xml/example_appwidget_info" />
</receiver>
<receiver>
উপাদানটির জন্য android:name
অ্যাট্রিবিউট প্রয়োজন, যা উইজেট দ্বারা ব্যবহৃত AppWidgetProvider
নির্দিষ্ট করে। আপনার AppWidgetProvider
এ একটি পৃথক প্রক্রিয়া সম্প্রচার করার প্রয়োজন না হলে উপাদানটি রপ্তানি করা উচিত নয়, যা সাধারণত হয় না৷
<intent-filter>
উপাদানটিতে android:name
বৈশিষ্ট্য সহ একটি <action>
উপাদান থাকতে হবে। এই বৈশিষ্ট্যটি নির্দিষ্ট করে যে AppWidgetProvider
ACTION_APPWIDGET_UPDATE
সম্প্রচার গ্রহণ করে৷ এটিই একমাত্র সম্প্রচার যা আপনাকে অবশ্যই স্পষ্টভাবে ঘোষণা করতে হবে। AppWidgetManager
স্বয়ংক্রিয়ভাবে প্রয়োজনীয় হিসাবে AppWidgetProvider
এ অন্যান্য সমস্ত উইজেট সম্প্রচার পাঠায়।
<meta-data>
উপাদানটি AppWidgetProviderInfo
রিসোর্স নির্দিষ্ট করে এবং নিম্নলিখিত বৈশিষ্ট্যগুলির প্রয়োজন:
-
android:name
: মেটাডেটা নাম নির্দিষ্ট করে।AppWidgetProviderInfo
বর্ণনাকারী হিসাবে ডেটা সনাক্ত করতেandroid.appwidget.provider
ব্যবহার করুন৷ -
android:resource
:AppWidgetProviderInfo
সম্পদের অবস্থান নির্দিষ্ট করে।
AppWidgetProvider ক্লাস বাস্তবায়ন করুন
AppWidgetProvider
ক্লাস উইজেট সম্প্রচার পরিচালনা করার জন্য একটি সুবিধার শ্রেণী হিসাবে BroadcastReceiver
প্রসারিত করে। এটি শুধুমাত্র সেই ইভেন্ট সম্প্রচার গ্রহণ করে যা উইজেটের সাথে প্রাসঙ্গিক, যেমন যখন উইজেট আপডেট করা হয়, মুছে ফেলা হয়, সক্ষম করা হয় এবং অক্ষম করা হয়। যখন এই সম্প্রচার ইভেন্টগুলি ঘটে, নিম্নলিখিত AppWidgetProvider
পদ্ধতিগুলিকে বলা হয়:
-
onUpdate()
- এটিকে
AppWidgetProviderInfo
তেupdatePeriodMillis
অ্যাট্রিবিউট দ্বারা সংজ্ঞায়িত বিরতিতে উইজেট আপডেট করতে বলা হয়। আরও তথ্যের জন্য এই পৃষ্ঠায় অতিরিক্ত উইজেট বৈশিষ্ট্য বর্ণনা করে টেবিলটি দেখুন। - এই পদ্ধতিটিকেও বলা হয় যখন ব্যবহারকারী উইজেট যোগ করে, তাই এটি প্রয়োজনীয় সেটআপ সম্পাদন করে যেমন অবজেক্ট
View
জন্য ইভেন্ট হ্যান্ডলার নির্ধারণ করা বা উইজেটে প্রদর্শনের জন্য ডেটা লোড করার জন্য কাজ শুরু করা। যাইহোক, যদি আপনিconfiguration_optional
পতাকা ছাড়াই একটি কনফিগারেশন কার্যকলাপ ঘোষণা করেন, ব্যবহারকারী যখন উইজেট যোগ করেন তখন এই পদ্ধতিটি বলা হয় না , তবে পরবর্তী আপডেটের জন্য এটি বলা হয় । কনফিগারেশন সম্পূর্ণ হলে প্রথম আপডেটটি সম্পাদন করা কনফিগারেশন কার্যকলাপের দায়িত্ব। আরও তথ্যের জন্য অ্যাপ উইজেট কনফিগার করতে ব্যবহারকারীদের সক্ষম করুন দেখুন। - সবচেয়ে গুরুত্বপূর্ণ কলব্যাক হল
onUpdate()
। আরও তথ্যের জন্য এই পৃষ্ঠায়onUpdate()
ক্লাসের সাথে ইভেন্ট পরিচালনা করুন দেখুন। -
onAppWidgetOptionsChanged()
এটিকে বলা হয় যখন উইজেটটি প্রথম স্থাপন করা হয় এবং যে কোনো সময় উইজেটটির আকার পরিবর্তন করা হয়। উইজেটের আকারের সীমার উপর ভিত্তি করে বিষয়বস্তু দেখাতে বা লুকানোর জন্য এই কলব্যাকটি ব্যবহার করুন। আকারের ব্যাপ্তিগুলি পান—এবং, Android 12 থেকে শুরু করে, একটি উইজেট ইন্সট্যান্স যে সম্ভাব্য আকারগুলি গ্রহণ করতে পারে তার তালিকাটি পান
getAppWidgetOptions()
, যা নিম্নলিখিতগুলি অন্তর্ভুক্ত করে এমন একটিBundle
প্রদান করে:-
OPTION_APPWIDGET_MIN_WIDTH
: একটি উইজেট দৃষ্টান্তের dp ইউনিটে প্রস্থে নিম্ন সীমা রয়েছে। -
OPTION_APPWIDGET_MIN_HEIGHT
: একটি উইজেট দৃষ্টান্তের dp ইউনিটে উচ্চতার নিম্ন সীমা রয়েছে৷ -
OPTION_APPWIDGET_MAX_WIDTH
: একটি উইজেট দৃষ্টান্তের dp ইউনিটে প্রস্থের উপরের সীমা রয়েছে৷ -
OPTION_APPWIDGET_MAX_HEIGHT
: একটি উইজেট দৃষ্টান্তের dp ইউনিটে উচ্চতার উপরের সীমা রয়েছে৷ -
OPTION_APPWIDGET_SIZES
: dp ইউনিটে সম্ভাব্য মাপের তালিকা রয়েছে (List<SizeF>
), যা একটি উইজেট উদাহরণ নিতে পারে। অ্যান্ড্রয়েড 12 এ চালু করা হয়েছে।
-
-
onDeleted(Context, int[])
প্রতিবার উইজেট হোস্ট থেকে উইজেট মুছে ফেলা হলে একে বলা হয়।
-
onEnabled(Context)
এটি বলা হয় যখন উইজেটের একটি উদাহরণ প্রথমবার তৈরি করা হয়। উদাহরণস্বরূপ, যদি ব্যবহারকারী আপনার উইজেটের দুটি দৃষ্টান্ত যোগ করে, এটি শুধুমাত্র প্রথমবার বলা হয়। আপনি যদি একটি নতুন ডাটাবেস খুলতে চান বা অন্য একটি সেটআপ করতে চান যা শুধুমাত্র সমস্ত উইজেট দৃষ্টান্তের জন্য একবার ঘটতে হবে, তাহলে এটি করার জন্য এটি একটি ভাল জায়গা।
-
onDisabled(Context)
এটি বলা হয় যখন আপনার উইজেটের শেষ উদাহরণটি উইজেট হোস্ট থেকে মুছে ফেলা হয়। এখানেই আপনি
onEnabled(Context)
এ করা যেকোনো কাজ পরিষ্কার করেন, যেমন একটি অস্থায়ী ডাটাবেস মুছে ফেলা।-
onReceive(Context, Intent)
এটি প্রতিটি সম্প্রচারের জন্য এবং পূর্ববর্তী প্রতিটি কলব্যাক পদ্ধতির আগে বলা হয়। আপনার সাধারণত এই পদ্ধতিটি প্রয়োগ করার প্রয়োজন নেই, কারণ ডিফল্ট
AppWidgetProvider
বাস্তবায়ন সমস্ত উইজেট সম্প্রচারকে ফিল্টার করে এবং পূর্ববর্তী পদ্ধতিগুলিকে উপযুক্ত হিসাবে কল করে।
আপনাকে অবশ্যই AndroidManifest
এ <receiver>
উপাদান ব্যবহার করে একটি সম্প্রচার রিসিভার হিসেবে আপনার AppWidgetProvider
ক্লাস বাস্তবায়ন ঘোষণা করতে হবে। আরও তথ্যের জন্য এই পৃষ্ঠার ম্যানিফেস্টে একটি উইজেট ঘোষণা দেখুন।
onUpdate() ক্লাস দিয়ে ইভেন্টগুলি পরিচালনা করুন
সবচেয়ে গুরুত্বপূর্ণ AppWidgetProvider
কলব্যাক হল onUpdate()
, কারণ এটি বলা হয় যখন প্রতিটি উইজেট একটি হোস্টে যোগ করা হয়, যদি না আপনি configuration_optional
পতাকা ছাড়া কনফিগারেশন কার্যকলাপ ব্যবহার করেন। যদি আপনার উইজেট কোনো ব্যবহারকারীর ইন্টারঅ্যাকশন ইভেন্ট গ্রহণ করে, তাহলে এই কলব্যাকে ইভেন্ট হ্যান্ডলারদের নিবন্ধন করুন। যদি আপনার উইজেট অস্থায়ী ফাইল বা ডাটাবেস তৈরি না করে, বা অন্য কাজ সম্পাদন করে যার জন্য পরিষ্কার-পরিচ্ছন্নতার প্রয়োজন হয়, তাহলে onUpdate()
হতে পারে একমাত্র কলব্যাক পদ্ধতি যা আপনাকে সংজ্ঞায়িত করতে হবে।
উদাহরণস্বরূপ, আপনি যদি একটি বোতাম সহ একটি উইজেট চান যা ট্যাপ করার সময় একটি কার্যকলাপ চালু করে, আপনি AppWidgetProvider
এর নিম্নলিখিত বাস্তবায়ন ব্যবহার করতে পারেন:
কোটলিন
class ExampleAppWidgetProvider : AppWidgetProvider() { override fun onUpdate( context: Context, appWidgetManager: AppWidgetManager, appWidgetIds: IntArray ) { // Perform this loop procedure for each widget that belongs to this // provider. appWidgetIds.forEach { appWidgetId -> // Create an Intent to launch ExampleActivity. val pendingIntent: PendingIntent = PendingIntent.getActivity( /* context = */ context, /* requestCode = */ 0, /* intent = */ Intent(context, ExampleActivity::class.java), /* flags = */ PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE ) // Get the layout for the widget and attach an onClick listener to // the button. val views: RemoteViews = RemoteViews( context.packageName, R.layout.appwidget_provider_layout ).apply { setOnClickPendingIntent(R.id.button, pendingIntent) } // Tell the AppWidgetManager to perform an update on the current // widget. appWidgetManager.updateAppWidget(appWidgetId, views) } } }
জাভা
public class ExampleAppWidgetProvider extends AppWidgetProvider { public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { // Perform this loop procedure for each widget that belongs to this // provider. for (int i=0; i < appWidgetIds.length; i++) { int appWidgetId = appWidgetIds[i]; // Create an Intent to launch ExampleActivity Intent intent = new Intent(context, ExampleActivity.class); PendingIntent pendingIntent = PendingIntent.getActivity( /* context = */ context, /* requestCode = */ 0, /* intent = */ intent, /* flags = */ PendingIntent.FLAG_UPDATE_CURRENT | PendingIntent.FLAG_IMMUTABLE ); // Get the layout for the widget and attach an onClick listener to // the button. RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.example_appwidget_layout); views.setOnClickPendingIntent(R.id.button, pendingIntent); // Tell the AppWidgetManager to perform an update on the current app // widget. appWidgetManager.updateAppWidget(appWidgetId, views); } } }
এই AppWidgetProvider
শুধুমাত্র onUpdate()
পদ্ধতিটি সংজ্ঞায়িত করে, এটি একটি PendingIntent
তৈরি করতে ব্যবহার করে যা একটি Activity
চালু করে এবং setOnClickPendingIntent(int, PendingIntent)
ব্যবহার করে উইজেটের বোতামে সংযুক্ত করে। এটি একটি লুপ অন্তর্ভুক্ত করে যা appWidgetIds
এ প্রতিটি এন্ট্রির মাধ্যমে পুনরাবৃত্তি করে, যা আইডিগুলির একটি অ্যারে যা এই প্রদানকারীর দ্বারা তৈরি প্রতিটি উইজেট সনাক্ত করে৷ ব্যবহারকারী যদি উইজেটের একাধিক দৃষ্টান্ত তৈরি করে, তবে সেগুলি একই সাথে আপডেট হয়। যাইহোক, উইজেটের সমস্ত দৃষ্টান্তের জন্য শুধুমাত্র একটি updatePeriodMillis
সময়সূচী পরিচালিত হয়। উদাহরণস্বরূপ, যদি আপডেটের সময়সূচীটি প্রতি দুই ঘন্টায় সংজ্ঞায়িত করা হয়, এবং উইজেটের একটি দ্বিতীয় দৃষ্টান্ত প্রথমটির এক ঘন্টা পরে যোগ করা হয়, তাহলে তারা উভয়ই প্রথম দ্বারা সংজ্ঞায়িত সময়ের এবং দ্বিতীয় আপডেটের সময়কালে আপডেট করা হয়। উপেক্ষা করা হয়। তারা উভয়ই প্রতি ঘন্টায় নয়, প্রতি ঘন্টায় আপডেট করে।
আরো বিস্তারিত জানার জন্য ExampleAppWidgetProvider.java
নমুনা ক্লাস দেখুন।
উইজেট সম্প্রচারের অভিপ্রায় গ্রহণ করুন
AppWidgetProvider
হল একটি সুবিধার ক্লাস। আপনি যদি সরাসরি উইজেট সম্প্রচার পেতে চান, তাহলে আপনি আপনার নিজস্ব BroadcastReceiver
প্রয়োগ করতে পারেন বা onReceive(Context,Intent)
কলব্যাককে ওভাররাইড করতে পারেন। আপনার যে উদ্দেশ্যগুলির যত্ন নেওয়া দরকার তা হল:
-
ACTION_APPWIDGET_UPDATE
-
ACTION_APPWIDGET_DELETED
-
ACTION_APPWIDGET_ENABLED
-
ACTION_APPWIDGET_DISABLED
-
ACTION_APPWIDGET_OPTIONS_CHANGED
উইজেট লেআউট তৈরি করুন
আপনাকে অবশ্যই XML-এ আপনার উইজেটের জন্য একটি প্রাথমিক বিন্যাস নির্ধারণ করতে হবে এবং প্রকল্পের res/layout/
ডিরেক্টরিতে সংরক্ষণ করতে হবে। বিস্তারিত জানার জন্য ডিজাইন নির্দেশিকা পড়ুন।
আপনি যদি লেআউটের সাথে পরিচিত হন তাহলে উইজেট লেআউট তৈরি করা সহজ। যাইহোক, সচেতন থাকুন যে উইজেট লেআউটগুলি RemoteViews
এর উপর ভিত্তি করে তৈরি করা হয়, যা প্রতিটি ধরণের লেআউট বা ভিজেটকে সমর্থন করে না৷ আপনি RemoteViews
দ্বারা সমর্থিত ভিউগুলির কাস্টম ভিউ বা সাবক্লাস ব্যবহার করতে পারবেন না।
RemoteViews
এছাড়াও ViewStub
সমর্থন করে, যা একটি অদৃশ্য, শূন্য-আকারের View
আপনি রানটাইমে লেআউট সংস্থানগুলিকে অলসভাবে স্ফীত করতে ব্যবহার করতে পারেন।
রাষ্ট্রীয় আচরণের জন্য সমর্থন
Android 12 নিম্নলিখিত বিদ্যমান উপাদানগুলি ব্যবহার করে রাষ্ট্রীয় আচরণের জন্য সমর্থন যোগ করে:
উইজেটটি এখনও রাষ্ট্রহীন। আপনার অ্যাপ্লিকেশানকে অবশ্যই রাজ্য সংরক্ষণ করতে হবে এবং রাজ্য পরিবর্তন ইভেন্টগুলির জন্য নিবন্ধন করতে হবে৷
নিম্নলিখিত কোড উদাহরণ দেখায় কিভাবে এই উপাদান বাস্তবায়ন করতে.
কোটলিন
// Check the view. remoteView.setCompoundButtonChecked(R.id.my_checkbox, true) // Check a radio group. remoteView.setRadioGroupChecked(R.id.my_radio_group, R.id.radio_button_2) // Listen for check changes. The intent has an extra with the key // EXTRA_CHECKED that specifies the current checked state of the view. remoteView.setOnCheckedChangeResponse( R.id.my_checkbox, RemoteViews.RemoteResponse.fromPendingIntent(onCheckedChangePendingIntent) )
জাভা
// Check the view. remoteView.setCompoundButtonChecked(R.id.my_checkbox, true); // Check a radio group. remoteView.setRadioGroupChecked(R.id.my_radio_group, R.id.radio_button_2); // Listen for check changes. The intent has an extra with the key // EXTRA_CHECKED that specifies the current checked state of the view. remoteView.setOnCheckedChangeResponse( R.id.my_checkbox, RemoteViews.RemoteResponse.fromPendingIntent(onCheckedChangePendingIntent));
দুটি লেআউট প্রদান করুন: একটি টার্গেটিং ডিভাইস যেগুলি res/layout-v31
এ Android 12 বা তার বেশি চলমান, এবং অন্যটি ডিফল্ট res/layout
ফোল্ডারে পূর্ববর্তী Android 11 বা তার নিচের সংস্করণগুলিকে লক্ষ্য করে৷
বৃত্তাকার কোণগুলি প্রয়োগ করুন
অ্যান্ড্রয়েড 12 আপনার উইজেটের গোলাকার কোণগুলির রেডিআই সেট করতে নিম্নলিখিত সিস্টেম প্যারামিটারগুলি প্রবর্তন করে:
system_app_widget_background_radius
: উইজেট ব্যাকগ্রাউন্ডের কোণার ব্যাসার্ধ, যা কখনই 28 dp-এর চেয়ে বড় হয় না।system_app_widget_inner_radius
: উইজেটের ভিতরে যেকোন ভিউ এর কোণার ব্যাসার্ধ। এটি একটি 8 ডিপি প্যাডিং ব্যবহার করার সময় সুন্দরভাবে সারিবদ্ধ করার জন্য পটভূমি ব্যাসার্ধের থেকে ঠিক 8 ডিপি কম।
নিম্নলিখিত উদাহরণটি একটি উইজেট দেখায় যা উইজেটের কোণে system_app_widget_background_radius
এবং উইজেটের ভিউয়ের জন্য system_app_widget_inner_radius
ব্যবহার করে।
উইজেটের 1 কোণ।
উইজেটের ভিতরে একটি দৃশ্যের 2 কোণ।
বৃত্তাকার কোণগুলির জন্য গুরুত্বপূর্ণ বিবেচনা
- থার্ড-পার্টি লঞ্চার এবং ডিভাইস নির্মাতারা
system_app_widget_background_radius
প্যারামিটার 28 dp-এর থেকে ছোট হতে ওভাররাইড করতে পারে।system_app_widget_inner_radius
প্যারামিটার সবসময়system_app_widget_background_radius
এর মানের থেকে 8 dp কম। - যদি আপনার উইজেট
@android:id/background
ব্যবহার না করে বা একটি ব্যাকগ্রাউন্ড সংজ্ঞায়িত না করে যা তার বিষয়বস্তুকে সীমারেখার উপর ভিত্তি করে ক্লিপ করে —android:clipToOutline
true
সেট করে — লঞ্চার স্বয়ংক্রিয়ভাবে ব্যাকগ্রাউন্ড শনাক্ত করে এবং বৃত্তাকার কোণ সহ একটি আয়তক্ষেত্র ব্যবহার করে উইজেটটিকে ক্লিপ করে 16 ডিপি পর্যন্ত। আপনার উইজেটটি Android 12 এর সাথে সামঞ্জস্যপূর্ণ কিনা তা নিশ্চিত করুন।
অ্যান্ড্রয়েডের পূর্ববর্তী সংস্করণগুলির সাথে উইজেট সামঞ্জস্যের জন্য, আমরা কাস্টম বৈশিষ্ট্যগুলিকে সংজ্ঞায়িত করার এবং Android 12 এর জন্য সেগুলিকে ওভাররাইড করতে একটি কাস্টম থিম ব্যবহার করার পরামর্শ দিই, যেমনটি নিম্নলিখিত নমুনা XML ফাইলগুলিতে দেখানো হয়েছে:
/values/attrs.xml
<resources>
<attr name="backgroundRadius" format="dimension" />
</resources>
/values/styles.xml
<resources>
<style name="MyWidgetTheme">
<item name="backgroundRadius">@dimen/my_background_radius_dimen</item>
</style>
</resources>
/values-31/styles.xml
<resources>
<style name="MyWidgetTheme" parent="@android:style/Theme.DeviceDefault.DayNight">
<item name="backgroundRadius">@android:dimen/system_app_widget_background_radius</item>
</style>
</resources>
/drawable/my_widget_background.xml
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners android:radius="?attr/backgroundRadius" />
...
</shape>
/layout/my_widget_layout.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
...
android:background="@drawable/my_widget_background" />