কার মেসেঞ্জার

কার মেসেঞ্জার গাড়ির ডিভাইসের জন্য বিশেষভাবে তৈরি মেসেজিং সুবিধা প্রদান করে। অন্যান্য কার অ্যাপের মতোই, ব্যবহারকারীরা লঞ্চার থেকে কার মেসেঞ্জার চালু করেন।

কার মেসেঞ্জারে নতুন কী আছে?

নতুন কার মেসেঞ্জার অ্যাপের মাধ্যমে চালকরা:

  • একটি বিশেষ মেসেজিং অভিজ্ঞতা লাভ করুন।
  • লঞ্চার থেকে কার মেসেঞ্জার চালু করুন।
  • গাড়ি চালানোর আগে ও চলাকালীন প্রাপ্ত বার্তাগুলো ব্রাউজ করুন।
  • বার্তা শুনুন এবং উত্তর দিন।
  • মেসেজ নোটিফিকেশন মিউট করুন।
  • নতুন আলাপ শুরু করুন।

পরিভাষা

এই পৃষ্ঠায় নিম্নলিখিত পরিভাষাগুলো ব্যবহৃত হয়েছে:

পড়ার জন্য ট্যাপ করুন (TTR)
যখন কোনো ব্যবহারকারী মেসেজ নোটিফিকেশনের সাথে ইন্টারঅ্যাক্ট করেন, তখন ট্যাপ-টু-রিড ফিচারটি ভয়েস অ্যাসিস্ট্যান্টকে সেই ব্যবহারকারীর পক্ষ থেকে টেক্সট মেসেজ পড়তে এবং তার উত্তর দিতে সক্ষম করে।

সরাসরি উত্তর
ট্যাপ-টু-রিড-এর মতোই, তবে এক্ষেত্রে ভয়েস অ্যাসিস্ট্যান্ট মেসেজটি পড়ে শোনায় না এবং সাথে সাথেই উত্তর দেওয়ার জন্য অনুরোধ করে।

সরাসরি প্রেরণ
নির্দিষ্ট পরিচিতি সহ বা পরিচিতি ছাড়াই নতুন বার্তা প্রবাহ তৈরি করার জন্য ভয়েস অ্যাসিস্ট্যান্টের সাথে সংযুক্ত হয়।

আনবান্ডেলড অ্যাপের সুবিধা

কার মেসেঞ্জারের মতো আনবান্ডলড অ্যাপগুলো এই সুবিধাগুলো প্রদান করে:

  • শুধুমাত্র পাবলিক মেথড ব্যবহার করে (হিডেন এপিআই-এর উপর কোনো প্ল্যাটফর্ম নির্ভরতা নেই)
  • অ্যান্ড্রয়েড প্ল্যাটফর্মের বাইরে অ্যাপ তৈরি করুন
  • আরও ঘন ঘন রিলিজ চালু করুন (নতুন ফিচার এবং সমাধান করা সমস্যার জন্য)
  • গুগল প্লে-এর মাধ্যমে অ্যাপ আপডেট করুন

আনবান্ডেলড অ্যাপ সম্পর্কে আরও জানুন।

প্রযুক্তিগত বিবরণ

এই বিভাগে কার মেসেঞ্জার আর্কিটেকচার বর্ণনা করা হয়েছে। আরও জানতে, “CarVoiceInteractionSession-এর সাথে ইন্টিগ্রেট করুন” দেখুন।

টেলিফোনি-ভিত্তিক স্থাপত্য

ব্লুটুথের মাধ্যমে পেয়ার করা হলে, ফোনের টেলিফোনি ডেটাবেস থেকে গাড়ির টেলিফোনি ডেটাবেসে ডেটা সিঙ্ক্রোনাইজ হয়। ব্লুটুথ সংযোগ বিচ্ছিন্ন হলে, সিঙ্ক্রোনাইজ করা ডেটা গাড়ির টেলিফোনি ডেটাবেস থেকে মুছে যায়।

এই বৈশিষ্ট্যটি অ্যান্ড্রয়েড ১২-এ চালু করা হয়েছিল। এর প্রধান সুবিধাগুলো হলো:

  • ডাটাবেস থেকে ব্যবহারকারীদের বিপুল সংখ্যক বার্তা পুনরুদ্ধার করা যায়।
  • পূর্ববর্তী ড্রাইভের বার্তাগুলো সমর্থিত।
  • অ্যান্ড্রয়েড ফোনে এসএমএস সংরক্ষণ ও পুনরুদ্ধারের জন্য একই ধরনের আর্কিটেকচার এবং এপিআই ব্যবহার করে।
  • অ্যান্ড্রয়েড প্ল্যাটফর্ম থেকে সম্পূর্ণরূপে বিচ্ছিন্ন হয়ে যায়।

প্রক্রিয়াটি হলো:

টেলিফোনি-ভিত্তিক ডেটা প্রবাহ চিত্র ১. টেলিফোনি-ভিত্তিক তথ্য প্রবাহ।

প্রবাহটি পাঠ্য আকারে চিত্রিত করা হলো:

 1. Phone connects to car.
    |
    --> 2. SMS data transferred from phone's database to car database.
          |
          --> 3. Car Messenger retrieves data from telephony database to display on UI.
                  |
                  --> 4. User interactions prompt the voice assistant.
                  |
          <-- 5. Car Messenger receives reply action from the voice assistant.
          |
    <-- 6. SMS is marked as read in car database.
    |
 7. Reply transmitted to recipients, phone database updated with reply and read status.

আমরা ডেটা দিয়ে যা করি তা হলো:

কার মেসেঞ্জার ডেটা ব্যবহার চিত্র ২. কার মেসেঞ্জারে ডেটা ব্যবস্থাপনা।

প্রবাহটি পাঠ্য আকারে চিত্রিত করা হলো:

 1. Phone connects to car.
    |
    --> 2. SMS data transferred from phone's database to car database.
          |
          --> 3. Phone disconnects from car.
                  |
                  --> 4. SMS data deleted from car telephony database.
  • সংযোগ স্থাপন হলে, ব্লুটুথ ম্যাপ ব্যবহার করে ফোন থেকে গাড়িতে ডেটা স্থানান্তরিত হয়।
  • সংযোগ বিচ্ছিন্ন হলে, গাড়ির ডেটাবেস থেকে সেই ফোনের ডেটা মুছে ফেলা হয়।

গাড়ি মেসেঞ্জার পান

গুগল গিট থেকে কার মেসেঞ্জারের সর্বশেষ কমিটটি নিন।

ভয়েস ইন্টারঅ্যাকশন এপিআই

কার মেসেঞ্জার অ্যাসিস্ট্যান্টের সাথে ইন্টিগ্রেট করার জন্য CarVoiceInteractionSession API ব্যবহার করে। এই উপাদানগুলো নিম্নলিখিত বিভাগগুলিতে বর্ণনা করা হয়েছে।

পেন্ডিংইনটেন্ট মডেল

এই API-গুলো সমাধান করা অ্যাসিস্ট্যান্ট কোয়েরিগুলো কার মেসেঞ্জারে ফেরত পাঠাতে PendingIntent ব্যবহার করে।

ঘটনাপ্রবাহটি হলো:

  1. কার মেসেঞ্জার activity.showAssist(Bundle args) কল করার মাধ্যমে অ্যাসিস্ট্যান্ট চালু করে । args-এর মধ্যে API অ্যাকশন এবং এর প্রয়োজনীয় প্যারামিটারগুলো থাকে, এবং প্রয়োজনে একটি পেন্ডিং ইন্টেন্টও অন্তর্ভুক্ত থাকে।

  2. প্রয়োজন হলে অ্যাসিস্ট্যান্ট ব্যবহারকারীর ইনপুট সংগ্রহ করে এবং সেটিকে অপেক্ষমান ইন্টেন্টের সাথে প্যাকেজ করে।

  3. অ্যাসিস্ট্যান্ট ইনটেন্টটি কার মেসেঞ্জারের কাছে ফেরত পাঠায়।

  4. কার মেসেঞ্জার এপিআই অ্যাকশনটি সমাধান করে

পঠিত হিসেবে চিহ্নিত করুন এপিআই অ্যাকশন

যখন অ্যাসিস্ট্যান্ট কোনো মেসেজ পড়ে, তখন মেসেজটিকে পঠিত হিসেবে চিহ্নিত করার জন্য VOICE_ACTION_READ_NOTIFICATION অথবা VOICE_ACTION_READ_CONVERSATION অ্যাকশনসহ PendingIntent কার মেসেঞ্জারে পাঠানো হয়।

সরাসরি উত্তর এপিআই অ্যাকশন

যখন অ্যাসিস্ট্যান্ট কোনো মেসেজের উত্তর দেয়, তখন কথোপকথনে উত্তর দেওয়ার জন্য VOICE_ACTION_REPLY_NOTIFICATION এবং VOICE_ACTION_REPLY_CONVERSATION অ্যাকশনসহ PendingIntent কার মেসেঞ্জারে পাঠানো হয়।

সরাসরি এসএমএস পাঠান এপিআই অ্যাকশন

কার মেসেঞ্জার থেকে অ্যাসিস্ট্যান্টের কাছে VOICE_ACTION_SEND_SMS অ্যাকশন সম্বলিত একটি বান্ডেল পাঠানো হয়।

নমুনা কোড:

/**
 *   KEY_PHONE_NUMBER - Recipients phone number. If this and the recipients name are not
 *   provided by the application, assistant must do contact disambiguation but is not required
 *   to add the name to the PendingIntent.
 *
 *   KEY_RECIPIENT_NAME - Recipients name. If this and the recipient phone number are not
 *   provided by the application, assistant must do contact disambiguation but is not required
 *   to add the name to the PendingIntent.
 *
 *   KEY_RECIPIENT_UID - Recipients UID in the ContactProvider database. Optionally provided
 *   by the application. Not required to be sent back by the assistant.
 *
 *   KEY_DEVICE_NAME - Friendly name of the device in which to send the message from. If not
 *   provided by the application, assistant must do device disambiguation but is not required
 *   to add it to PendingIntent. In V1 this is required to be sent by the application.
 *
 *   KEY_DEVICE_ADDRESS - Bluetooth device address of the device in which to send the message
 *   from. If not provided by the application, assistant must do device disambiguation and add
 *   this to the PendingIntent. In V1 this is required to be sent by the application.
 *
 *   KEY_SEND_PENDING_INTENT - @NotNull Will always be provided by the application. The
 *   application must preload the pending intent with any KEYs it provides the assistant that
 *   is also needed to send the message. (I.e if the application passes in the
 *   KEY_PHONE_NUMBER in the Bundle, the assistant can assume the application has already put
 *   this in the PendingIntent and may not re-add it to the PendingIntent).
 *
 */
public static final String KEY_PHONE_NUMBER = KEY_PHONE_NUMBER;
public static final String KEY_RECIPIENT_NAME = KEY_RECIPIENT_NAME;
public static final String KEY_RECIPIENT_UID = KEY_RECIPIENT_UID;
public static final String KEY_DEVICE_NAME = KEY_DEVICE_NAME;
public static final String KEY_DEVICE_ADDRESS = KEY_DEVICE_NAME;
public static final String KEY_SEND_PENDING_INTENT =KEY_SEND_PENDING_INTENT;

এই ছবিতে প্রাপক নির্বাচন করার পর বার্তা লেখার প্রক্রিয়া দেখানো হয়েছে:

ডায়ালার অ্যাপের পরিচিতি পৃষ্ঠা চিত্র ৩. ডায়ালার অ্যাপের কন্টাক্টস পেজ।

এই ছবিতে দেখানো হয়েছে, নতুন বার্তা ব্যবহার করে কোনো প্রাপক নির্বাচন না করে কীভাবে বার্তা রচনা করতে হয়।

কোন প্রাপক নির্বাচন করা হয়নি চিত্র ৪. মেসেঞ্জার অ্যাপে নতুন বার্তা পাঠানোর বাটন।

সরাসরি এসএমএস পাঠানোর অ্যাকশন একীভূত করুন

এখানে VOICE_ACTION_SEND_SMS সমন্বিত একটি ডায়লারের উদাহরণ দেওয়া হলো, যেখানে ঐচ্ছিক প্যারামিটার প্রদানের ব্যবস্থা রয়েছে:

    /**
     * Build the {@link Bundle} to pass to assistant to send a sms.
     */
    public Bundle buildDirectSendBundle(String number, String name, String uid,
                                        BluetoothDevice device) {
        Bundle bundle = new Bundle();
        bundle.putString(CarVoiceInteractionSession.KEY_ACTION, VOICE_ACTION_SEND_SMS);
        // start optional parameters
        bundle.putString(CarVoiceInteractionSession.KEY_PHONE_NUMBER, number);
        bundle.putString(CarVoiceInteractionSession.KEY_RECIPIENT_NAME, name);
        bundle.putString(CarVoiceInteractionSession.KEY_RECIPIENT_UID, uid);
        // end optional parameters
        bundle.putString(CarVoiceInteractionSession.KEY_DEVICE_ADDRESS, device.getAddress());
        bundle.putString(CarVoiceInteractionSession.KEY_DEVICE_NAME,
                DialerUtils.getDeviceName(mContext, device));
        Intent intent = new Intent(mContext, MessagingService.class)
                .setAction(ACTION_DIRECT_SEND)
                .setClass(mContext, MessagingService.class);

        int requestCode = ACTION_DIRECT_SEND.hashCode();
        PendingIntent pendingIntent = PendingIntent.getForegroundService(
                mContext, requestCode, intent,
                PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE);

        bundle.putParcelable(KEY_SEND_PENDING_INTENT, pendingIntent);
        return bundle;
    }

TTR এবং ডাইরেক্ট রিপ্লাই-এর উন্নতিসাধন

আপডেট করা API-টি এখন একটি বহুমুখী Conversation ক্লাস ব্যবহার করে, যা নোটিফিকেশনের গণ্ডি ছাড়িয়ে বিভিন্ন অপারেশনের সুযোগ দেয় এবং অ্যাপের নিজস্ব প্রেক্ষাপটে এর কার্যক্ষমতা প্রসারিত করে। এর ফলে পূর্বে StatusBarNotification ক্লাস ব্যবহারের প্রয়োজনীয়তা দূর হয়েছে।

ডিবাগ কার মেসেঞ্জার

কার মেসেঞ্জার ডিবাগিং সম্পর্কে আরও জানতে নিম্নলিখিত বিভাগগুলি দেখুন।

ব্লুটুথ সংযোগ ডিবাগ করুন

  1. dumpsys কমান্ডটি চালান:

    adb shell dumpsys bluetooth_manager
    • dumpsys কমান্ডের আউটপুটে MapClientService অনুসন্ধান করুন।
     Profile: MapClientService
          mCurrentDevice: 99:99 (Pixel XL) name=Mce state=Connected
    
  2. সঠিক ডিভাইসটি তালিকাভুক্ত আছে কিনা তা নিশ্চিত করুন। উদাহরণস্বরূপ:

    ডিভাইসের তালিকা চিত্র ৫. ডিভাইসের তালিকা।

  3. যদি কোনো ডিভাইস খুঁজে না পাওয়া যায়, তাহলে নিম্নলিখিতগুলির মধ্যে একটি করুন:

    • ব্লুটুথের সাথে পুনরায় সংযোগ করুন।

    অথবা

    • ব্লুটুথ সেটিংসে, টেক্সট মেসেজ চালু আছে কিনা তা নিশ্চিত করুন।

    অথবা

    • ফোনে নিশ্চিত করুন যে মেসেজ অ্যাক্সেসের অনুমতি দেওয়া হয়েছে।

ব্লুটুথ ডেটাবেস ডিবাগ করুন

কার মেসেঞ্জার টেলিফোনি ডেটাবেসের উপর ভিত্তি করে তৈরি। ব্লুটুথ সেই ডেটাবেসটি পূরণ করছে কিনা তা জানতে, আপনি টেবিলের কমান্ডগুলো ব্যবহার করতে পারেন।

কাজ আদেশ
কথোপকথন adb shell content query --uri content://mms-sms/conversations?simple=true
শুধুমাত্র এসএমএস বার্তা adb shell content query --uri content://sms
এমএমএস/এসএমএস বার্তা adb shell content query --uri content://mms-sms/conversations
শুধুমাত্র এমএমএস বার্তা adb shell content query --uri content://mms
শুধুমাত্র এমএমএস ইনবক্সে adb shell content query --uri content://mms/conversations/inbox
শুধুমাত্র এসএমএস বার্তা পাঠানো হয়েছে adb shell content query --uri content://sms/sent
শুধুমাত্র এসএমএস ইনবক্স adb shell content query --uri content://sms/conversations/inbox
এমএমএস বার্তার প্রথম অংশ
( 1 জায়গায় এমএমএস-এর আইডি বসান)
adb shell content query --uri content://mms/part/1

কার মেসেঞ্জার এবং ভয়েস অ্যাসিস্ট্যান্ট কোয়েরি ডিবাগ করুন

বিল্ড ইমেজ eng বা userdebug হলে লগগুলো ডিফল্টভাবে প্রিন্ট হয়। অন্যথায়, কার মেসেঞ্জারের জন্য লগিং চালু করতে:

  1. প্রাসঙ্গিক ট্যাগগুলোর জন্য adb shell setprop log.tag.<TAG> DEBUG . কমান্ডটি চালান।

  2. প্রিলোডেড অ্যাসিস্ট্যান্ট- এর জন্য লগিং সক্রিয় করুন।

  3. যেসব বাগ বারবার দেখা যায়, সেগুলোর ক্ষেত্রে অ্যান্ড্রয়েড স্টুডিও- তে ব্রেকপয়েন্ট ব্যবহার করার কথা বিবেচনা করতে পারেন।