মোবাইল বিজ্ঞপ্তি একত্রিত করুন

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

এই সমস্যাটি আরও চ্যালেঞ্জিং হয়ে ওঠে যখন আপনি SDK যেমন ন্যাভিগেশন SDK ব্যবহার করেন, যেগুলি অ্যাপ থেকে স্বাধীনভাবে ফোরগ্রাউন্ড পরিষেবাগুলি চালায় যেগুলির নিজস্ব স্বাধীন অবিরাম বিজ্ঞপ্তি রয়েছে, তাদের একত্রিত করা কঠিন করে তোলে৷ এই সমস্যাগুলির সমাধান করার জন্য, নেভিগেশন SDK v1.11 একটি সাধারণ API চালু করেছে যাতে SDK-এর মধ্যে সহ অ্যাপ জুড়ে অবিরাম বিজ্ঞপ্তিগুলি পরিচালনা করতে সহায়তা করে৷

অবিরাম বিজ্ঞপ্তি একত্রীকরণ

উপাদান

ফোরগ্রাউন্ড সার্ভিস ম্যানেজার অ্যান্ড্রয়েড ফোরগ্রাউন্ড সার্ভিস ক্লাস এবং ক্রমাগত বিজ্ঞপ্তি ক্লাসের চারপাশে একটি মোড়ক প্রদান করে। এই মোড়কের প্রধান কাজ হল নোটিফিকেশন আইডির পুনঃব্যবহার জোরদার করা যাতে ম্যানেজার ব্যবহার করে সমস্ত ফোরগ্রাউন্ড পরিষেবা জুড়ে বিজ্ঞপ্তি শেয়ার করা হয়।


ন্যাভিগেশন SDK-তে ForegroundServiceManager সিঙ্গলটন শুরু করার এবং পাওয়ার জন্য স্ট্যাটিক পদ্ধতি রয়েছে। এই সিঙ্গেলটনটি নেভিগেশন SDK-এর জীবদ্দশায় শুধুমাত্র একবার শুরু করা যেতে পারে। ফলস্বরূপ, আপনি যদি ইনিশিয়ালাইজেশন কলগুলির মধ্যে একটি ব্যবহার করেন ( initForegroundServiceManagerMessageAndIntent() বা initForegroundServiceManagerProvider() ), তাহলে সেই পথটি পুনরায় প্রবেশ করার ক্ষেত্রে আপনাকে একটি চেষ্টা-ক্যাচ ব্লক দিয়ে ঘিরে রাখতে হবে। ন্যাভিগেশন SDK একটি রানটাইম ব্যতিক্রম ছুড়ে দেয় যদি আপনি যেকোন একটি পদ্ধতিকে একাধিকবার কল করেন যদি না আপনি প্রথমে ForegroundServiceManager এর সমস্ত রেফারেন্স পরিষ্কার করেন এবং প্রতিটি পরবর্তী কলের আগে clearForegroundServiceManager() কল করেন।

initForegroundServiceManagerMessageAndIntent() এর চারটি প্যারামিটার হল application , notificationId , defaultMessage এবং resumeIntent । যদি চূড়ান্ত তিনটি পরামিতি শূন্য হয়, তাহলে বিজ্ঞপ্তিটি হল আদর্শ নেভিগেশন SDK বিজ্ঞপ্তি। এই বিজ্ঞপ্তির পিছনে অ্যাপে অন্যান্য ফোরগ্রাউন্ড পরিষেবাগুলি লুকানো এখনও সম্ভব। notificationId প্যারামিটারটি বিজ্ঞপ্তি আইডি নির্দিষ্ট করে যা বিজ্ঞপ্তির জন্য ব্যবহার করা উচিত। যদি এটি শূন্য হয়, তাহলে একটি নির্বিচারে মান ব্যবহার করা হয়। আপনি অন্য SDK-এর মতো অন্যান্য বিজ্ঞপ্তিগুলির সাথে দ্বন্দ্বগুলির সাথে কাজ করার জন্য এটি স্পষ্টভাবে সেট করতে পারেন৷ defaultMessage হল একটি স্ট্রিং যা প্রদর্শিত হয় যখন সিস্টেমটি নেভিগেট না করে। resumeIntent হল একটি উদ্দেশ্য যা বিজ্ঞপ্তিতে ক্লিক করার সময় বহিস্কার করা হয়। যদি resumeIntent নাল থাকে, তাহলে বিজ্ঞপ্তিতে ক্লিক করা উপেক্ষা করা হয়।

initForegroundServiceManagerProvider() এর তিনটি প্যারামিটার হল application , notificationId এবং notificationProvider । যদি চূড়ান্ত দুটি প্যারামিটার শূন্য হয়, তাহলে বিজ্ঞপ্তিটি হল আদর্শ নেভিগেশন SDK বিজ্ঞপ্তি। notificationId প্যারামিটারটি বিজ্ঞপ্তি আইডি নির্দিষ্ট করে যা বিজ্ঞপ্তির জন্য ব্যবহার করা উচিত। যদি এটি শূন্য হয়, তাহলে একটি নির্বিচারে মান ব্যবহার করা হয়। আপনি অন্য SDK-এর মতো অন্যান্য বিজ্ঞপ্তিগুলির সাথে দ্বন্দ্বগুলির সাথে কাজ করার জন্য এটি স্পষ্টভাবে সেট করতে পারেন৷ যদি notificationProvider সেট করা থাকে, তাহলে প্রদানকারী সর্বদা রেন্ডার করা বিজ্ঞপ্তি তৈরি করার জন্য দায়ী।

নেভিগেশন SDK getForegroundServiceManager() পদ্ধতি ফোরগ্রাউন্ড সার্ভিস ম্যানেজার সিঙ্গেলটন প্রদান করে। আপনি যদি এখনও একটি তৈরি না করে থাকেন, তাহলে এটি notificationId , defaultMessage এবং resumeIntent এর জন্য নাল প্যারামিটার সহ initForegroundServiceManagerMessageAndIntent() কল করার সমতুল্য।

ForegroundServiceManager তিনটি সহজ পদ্ধতি আছে। প্রথম দুটি একটি পরিষেবাকে অগ্রভাগের মধ্যে এবং বাইরে নিয়ে যাওয়ার জন্য এবং সাধারণত তৈরি করা পরিষেবার মধ্যে থেকে ডাকা হয়৷ এই পদ্ধতিগুলি ব্যবহার করা নিশ্চিত করে যে পরিষেবাগুলি ভাগ করা অবিরাম বিজ্ঞপ্তির সাথে যুক্ত। চূড়ান্ত পদ্ধতি, updateNotification() , ম্যানেজারকে ফ্ল্যাগ করে যে বিজ্ঞপ্তিটি পরিবর্তিত হয়েছে এবং পুনরায় রেন্ডার করা উচিত।

আপনার যদি শেয়ার করা অবিরাম বিজ্ঞপ্তির সম্পূর্ণ নিয়ন্ত্রণের প্রয়োজন হয়, তাহলে API একটি বিজ্ঞপ্তি প্রদানকারীকে সংজ্ঞায়িত করার জন্য একটি NotificationContentProvider ইন্টারফেস প্রদান করে, যা বর্তমান সামগ্রীর সাথে একটি বিজ্ঞপ্তি পাওয়ার জন্য একটি একক পদ্ধতি ধারণ করে। এটি একটি বেস ক্লাসও প্রদান করে, যা আপনি ঐচ্ছিকভাবে প্রদানকারীকে সংজ্ঞায়িত করতে সাহায্য করতে ব্যবহার করতে পারেন। বেস ক্লাসের প্রধান উদ্দেশ্যগুলির মধ্যে একটি হল এটি ForegroundServiceManager অ্যাক্সেস করার প্রয়োজন ছাড়াই updateNotification() কল করার একটি উপায় প্রদান করে। আপনি যদি নতুন বিজ্ঞপ্তি বার্তা পেতে বিজ্ঞপ্তি প্রদানকারীর একটি উদাহরণ ব্যবহার করেন, আপনি বিজ্ঞপ্তিতে বার্তা রেন্ডার করতে সরাসরি এই অভ্যন্তরীণ পদ্ধতিতে কল করতে পারেন।

ব্যবহারের পরিস্থিতি

এই বিভাগটি শেয়ার করা অবিরাম বিজ্ঞপ্তিগুলি ব্যবহার করার জন্য ব্যবহারের পরিস্থিতিগুলির বিবরণ দেয়৷

অন্যান্য অ্যাপ ফোরগ্রাউন্ড পরিষেবাগুলির অবিরাম বিজ্ঞপ্তিগুলি লুকান৷
সবচেয়ে সহজ দৃশ্য হল বর্তমান আচরণ সংরক্ষণ করা, এবং শুধুমাত্র ন্যাভিগেশন SDK তথ্য রেন্ডার করার জন্য অবিরাম বিজ্ঞপ্তি ব্যবহার করুন। ফোরগ্রাউন্ড সার্ভিস ম্যানেজার startForeground() এবং stopForeground() পদ্ধতি ব্যবহার করে অন্যান্য পরিষেবাগুলি এই বিজ্ঞপ্তির পিছনে লুকিয়ে থাকতে পারে।
অন্যান্য অ্যাপ ফোরগ্রাউন্ড পরিষেবাগুলির অবিরাম বিজ্ঞপ্তিগুলি লুকান, কিন্তু নেভিগেট না করার সময় দেখানো ডিফল্ট পাঠ্য সেট করুন
দ্বিতীয় সহজতম দৃশ্যকল্প হল বর্তমান আচরণ সংরক্ষণ করা, এবং সিস্টেমটি নেভিগেট না করা ছাড়া, ন্যাভিগেশন SDK তথ্য রেন্ডার করার জন্য শুধুমাত্র স্থায়ী বিজ্ঞপ্তি ব্যবহার করুন। যখন সিস্টেমটি নেভিগেট করছে না, initForegroundServiceManagerMessageAndIntent() তে প্রদত্ত স্ট্রিংটি ডিফল্ট নেভিগেশন SDK স্ট্রিংয়ের পরিবর্তে প্রদর্শিত হয় যা "গুগল মানচিত্র" উল্লেখ করে। আপনি এই কলটি ব্যবহার করতে পারেন রিজিউমের অভিপ্রায় সেট করতে যা বিজ্ঞপ্তিতে ক্লিক করা হলে ফায়ার হয়৷
ক্রমাগত বিজ্ঞপ্তির রেন্ডারিংয়ের সম্পূর্ণ নিয়ন্ত্রণ নিন
চূড়ান্ত দৃশ্যের জন্য একটি বিজ্ঞপ্তি প্রদানকারীকে সংজ্ঞায়িত করা এবং তৈরি করা এবং initForegroundServiceManagerProvider() ব্যবহার করে ForegroundServiceManager কাছে পাঠানো প্রয়োজন। এই বিকল্পটি আপনাকে বিজ্ঞপ্তিতে কী রেন্ডার করা হয়েছে তার সম্পূর্ণ নিয়ন্ত্রণ দেয়, তবে এটি বিজ্ঞপ্তি থেকে নেভিগেশন SDK বিজ্ঞপ্তি তথ্যকে সংযোগ বিচ্ছিন্ন করে, যার ফলে বিজ্ঞপ্তিতে দেখানো সহায়ক টার্ন-বাই-টার্ন প্রম্পটগুলি সরিয়ে দেয়। Google এই তথ্য পুনরুদ্ধার এবং বিজ্ঞপ্তিতে ঢোকানোর জন্য একটি সহজ উপায় প্রদান করে না।

উদাহরণ বিজ্ঞপ্তি প্রদানকারী

নিম্নলিখিত কোড উদাহরণটি দেখায় কিভাবে একটি সাধারণ বিজ্ঞপ্তি সামগ্রী প্রদানকারী ব্যবহার করে বিজ্ঞপ্তিগুলি তৈরি এবং ফেরত দেওয়া যায়৷

public class NotificationContentProviderImpl
   extends NotificationContentProviderBase
   implements NotificationContentProvider {
 private String channelId;
 private Context context;
 private String message;

 /** Constructor */
 public NotificationContentProviderImpl(Application application) {
   super(application);
   message = "-- uninitialized --";
   channelId = null;
   this.context = application;
 }

 /**
  * Sets message to display in the notification. Calls updateNotification
  * to display the message immediately.
  *
  * @param msg The message to display in the notification.
  */
 public void setMessage(String msg) {
   message = msg;
   updateNotification();
 }

 /**
  * Returns the notification as it should be rendered.
  */
 @Override
 public Notification getNotification() {
   Notification notification;

   if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {
     Spanned styledText = Html.fromHtml(message, FROM_HTML_MODE_LEGACY);
     String channelId = getChannelId(context);
     notification =
         new Notification.Builder(context, channelId)
             .setContentTitle("Notifications Demo")
             .setStyle(new Notification.BigTextStyle()
                 .bigText(styledText))
             .setSmallIcon(R.drawable.ic_navigation_white_24dp)
             .setTicker("ticker text")
             .build();
   } else {
     notification = new Notification.Builder(context)
         .setContentTitle("Notification Demo")
         .setContentText("testing non-O text")
         .build();
   }

   return notification;
 }

 // Helper to set up a channel ID.
 private String getChannelId(Context context) {
   if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {
     if (channelId == null) {
       NotificationManager notificationManager =
           (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
       NotificationChannel channel = new NotificationChannel(
           "default", "navigation", NotificationManager.IMPORTANCE_DEFAULT);
       channel.setDescription("For navigation persistent notification.");
       notificationManager.createNotificationChannel(channel);
       channelId = channel.getId();
     }
     return channelId;
   } else {
     return "";
   }
 }
}

আপনি NotificationContentProviderImpl তৈরি করার পরে, আপনি নিম্নলিখিত কোড ব্যবহার করে নেভিগেশন SDK এর সাথে সংযুক্ত করুন:

ForegroundServiceManager f = NavigationApi.getForegroundServiceManager(getApplication());
mNotification = new NotificationContentProviderImpl(getApplication());
NavigationApi.clearForegroundServiceManager();
NavigationApi.initForegroundServiceManagerProvider(getApplication(), null, mNotification);

সতর্কতা এবং ভবিষ্যৎ পরিকল্পনা

  • initForegroundServiceManagerMessageAndIntent() বা initForegroundServiceManagerProvider() কে তাড়াতাড়ি কল করতে ভুলবেন না যাতে প্রত্যাশিত ব্যবহারের দৃশ্যকল্পটি ভালভাবে সংজ্ঞায়িত হয়। একটি নতুন ন্যাভিগেটর তৈরি করার আগে আপনাকে অবশ্যই এই পদ্ধতিতে কল করতে হবে।
  • কোড পাথওয়ে একাধিকবার প্রবেশ করানো হলে initForegroundServiceManagerMessageAndIntent() বা initForegroundServiceManagerProvider() কল থেকে ব্যতিক্রমগুলি ধরা নিশ্চিত করুন৷ ন্যাভিগেশন SDK v2.0-এ, এই পদ্ধতিটিকে একাধিকবার কল করা রানটাইম ব্যতিক্রমের পরিবর্তে একটি চেক করা ব্যতিক্রম ফেলে দেয়।
  • হেডার স্টাইলিংয়ের সাথে মেলে এমন বিজ্ঞপ্তির জীবনকাল ধরে ধারাবাহিক স্টাইলিং পেতে Google-এর এখনও কিছু কাজ থাকতে পারে।
  • আপনি যখন একটি বিজ্ঞপ্তি প্রদানকারীকে সংজ্ঞায়িত করেন, তখন আপনি অগ্রাধিকার দিয়ে হেড-আপ আচরণ নিয়ন্ত্রণ করতে পারেন।
  • Google পালাক্রমে তথ্য পুনরুদ্ধার করার জন্য একটি সহজ উপায় প্রদান করে না যা একটি বিজ্ঞপ্তি প্রদানকারী বিজ্ঞপ্তিতে সন্নিবেশ করতে পারে।