অবস্থানের সময় অঞ্চল সনাক্তকরণ, Android 12 বা উচ্চতর সংস্করণে উপলব্ধ, একটি ঐচ্ছিক স্বয়ংক্রিয় সময় অঞ্চল সনাক্তকরণ বৈশিষ্ট্য যা ডিভাইসগুলিকে তাদের অবস্থান এবং সময় অঞ্চল মানচিত্র ডেটা ব্যবহার করে সময় অঞ্চল নির্ধারণ করতে দেয়৷
লোকেশন টাইম জোন ডিটেকশন হল টেলিফোনি টাইম জোন ডিটেকশনের বিকল্প মেকানিজম। যেহেতু এই বৈশিষ্ট্যটির জন্য টেলিফোনির প্রয়োজন নেই, তাই এই বৈশিষ্ট্যটি মোবাইল টেলিফোনি ডিভাইস ছাড়াও বিভিন্ন ফর্ম ফ্যাক্টরের ডিভাইসে সমর্থিত হতে পারে।
অবস্থান সময় অঞ্চল সনাক্তকরণ বৈশিষ্ট্য AOSP প্ল্যাটফর্মে নিম্নলিখিত উপাদানগুলি নিয়ে গঠিত:
- সিস্টেম সার্ভারে সময় অঞ্চল সনাক্তকরণ যুক্তি।
ব্যবহারকারীদের টেলিফোনি এবং লোকেশন টাইম জোন সনাক্তকরণ পদ্ধতির মধ্যে নির্বাচন করতে সক্ষম করার জন্য Android 12-এ চালু করা সেটিংস-এ একটি ব্যবহারকারী-অ্যাক্সেসযোগ্য বিকল্প।
উপাদানগুলির জন্য একটি প্লাগ-ইন সিস্টেম যা অবস্থান সনাক্তকরণ এবং সময় অঞ্চল ম্যাপিং সম্পাদন করে। একটি প্লাগ-ইনকে লোকেশন টাইম জোন প্রোভাইডার (LTZP) বলা হয় এবং একটি ডিভাইসে তাদের মধ্যে দুটি পর্যন্ত থাকতে পারে। প্ল্যাটফর্মটি সিস্টেম API প্রদান করে যা একটি LTZP বাস্তবায়নের জন্য ব্যবহার করা আবশ্যক।
একটি রেফারেন্স LTZP বাস্তবায়ন।
OpenStreetMap ডেটা থেকে একটি রেফারেন্স ডেটা সেট তৈরি করতে হোস্ট টুলিং যা রেফারেন্স বাস্তবায়নের সাথে ব্যবহার করা যেতে পারে।
ব্যবহারকারীর গোপনীয়তা
অবস্থানের সময় অঞ্চল সনাক্তকরণে নিম্নলিখিত ব্যবহারকারীর গোপনীয়তা বৈশিষ্ট্যগুলি অন্তর্ভুক্ত রয়েছে:
অবস্থান অ্যালগরিদম নির্বাচন করার জন্য একটি টগল থাকলে, ব্যবহারকারীরা যেকোনো সময় অবস্থান অ্যালগরিদম বন্ধ করতে পারেন।
অবস্থান থেকে প্রাপ্ত টাইম জোনের পরামর্শগুলি একটি ডিভাইসে ব্যবহারকারীদের মধ্যে ভাগ করা হয় না৷
ব্যবহারকারীরা তারিখ এবং সময় সেটিংস স্ক্রিনের মাধ্যমে স্পষ্টভাবে সময় অঞ্চল সনাক্তকরণের জন্য অবস্থান সনাক্তকরণ নিয়ন্ত্রণ করতে পারেন। ব্যবহারকারীদের একটি অনুমতি ডায়ালগের মাধ্যমে স্পষ্টভাবে অনুমতি দিতে হবে না।
ডিভাইসের অবস্থানের তথ্য Android প্ল্যাটফর্ম পরিষেবাগুলিতে পাঠানো হয় না। এর পরিবর্তে নিম্নলিখিতগুলি ঘটে:
- টাইম জোন ডিটেক্টর পরিষেবাগুলি শুধুমাত্র LTZP দ্বারা টাইম জোন আইডি পাঠানো হয়, ডিভাইসের অবস্থান নয়। লোকেশন টাইম জোন সনাক্তকরণ সমর্থন করার জন্য এটি ন্যূনতম API প্রয়োজন।
- পৃথক LTZP-এর অপারেশন সিস্টেম ইন্টিগ্রেটরদের সিদ্ধান্ত নেওয়ার জন্য ছেড়ে দেওয়া হয়। LTZP বাস্তবায়নগুলি সম্পূর্ণরূপে অ্যান্ড্রয়েড ডিভাইস, লিভারেজ সার্ভারে রাখা টাইম জোন ম্যাপ ডেটা ব্যবহার করতে পারে বা একটি হাইব্রিড পদ্ধতি ব্যবহার করতে পারে।
বৈশিষ্ট্য আচরণ
time_zone_detector
পরিষেবা নির্ধারণ করে যে ডিভাইসের বর্তমান টাইম জোন কখন পরিবর্তন করতে হবে সেটি সনাক্তকরণ অ্যালগরিদম থেকে প্রাপ্ত পরামর্শের ভিত্তিতে।
location_time_zone_manager
পরিষেবা time_zone_detector
এর অবস্থান অ্যালগরিদমের জন্য পরামর্শ তৈরি করার জন্য দায়ী। location_time_zone_manager
পরিষেবাটি সিস্টেম সার্ভার প্রক্রিয়ায় চলে।
location_time_zone_manager
পরিষেবাটিতে কোনও সময় অঞ্চল সনাক্তকরণ যুক্তি নেই। এটি লোকেশন টাইম জোন প্রোভাইডার (LTZPs) নামে পরিচিত এক বা দুটি প্লাগ-ইনের জীবনচক্র পরিচালনার জন্য দায়ী।
যখন অবস্থানের সময় অঞ্চল সনাক্তকরণের প্রয়োজন হয় না, তখন LTZPগুলি শুরু হয় না৷ এর মানে হল যে লোকেশন টাইম জোন ডিটেকশন সিস্টেম LTZP-কে ডিভাইসের লোকেশন ট্র্যাক করতে বলে না যদি না তাদের স্পষ্টভাবে প্রয়োজন হয়। এই আচরণের কিছু কারণের মধ্যে নিম্নলিখিতগুলি অন্তর্ভুক্ত রয়েছে:
- সাধারণ টেলিফোনি ক্রিয়াকলাপের অংশ হিসাবে নিষ্ক্রিয়ভাবে প্রাপ্ত টেলিফোনি সংকেতগুলির বিপরীতে, Android অবস্থান প্রদানকারীদের থেকে অবস্থান সক্রিয়ভাবে অনুরোধ করা যেতে পারে এবং অতিরিক্ত শক্তি ব্যবহার করতে পারে।
- অবস্থান সেটিংস ব্যবহারকারীর স্কোপড এবং অ্যান্ড্রয়েডকে অবশ্যই বর্তমান ব্যবহারকারীর সেটিংসকে সম্মান করতে হবে।
- ডিভাইসের অবস্থান পাওয়া গোপনীয়তা সংবেদনশীল।
এছাড়াও, location_time_zone_manager
পরিষেবাটি একটি অনিশ্চিত পরামর্শ দেয় (যদি একটি প্রয়োজন হয়) যখন বর্তমান ব্যবহারকারী পরিবর্তন করে ব্যবহারকারীদের মধ্যে অবস্থানের তথ্য ভাগ করা এড়াতে।
এই পছন্দগুলির ফলস্বরূপ, বর্তমান অ্যালগরিদমকে অবস্থানে স্যুইচ করার পরে বা বর্তমান ব্যবহারকারীকে স্যুইচ করার পরে, সময় অঞ্চল সনাক্ত করার আগে এটি সাধারণত কয়েক সেকেন্ড সময় নেয়। এটি ব্যবহার করা LTZP-এর বাস্তবায়নের উপরও নির্ভর করে।
AOSP অবস্থান সময় অঞ্চল সনাক্তকরণ বাস্তবায়ন দুটি LTZP, একটি প্রাথমিক এবং একটি মাধ্যমিক LTZP এখানে সংজ্ঞায়িত করার অনুমতি দেয়:
- প্রাথমিক LTZP
- ব্যবহারকারী যখন লোকেশন টাইম জোন সনাক্তকরণ বৈশিষ্ট্যটি চালানোর অনুমতি দেয় তখন সব সময়ে চলে।
- সেকেন্ডারি LTZP
- যদি প্রাথমিক LTZP রিপোর্ট করে যে টাইম জোন অনিশ্চিত , একটি স্থায়ী ব্যর্থতার রিপোর্ট করে, বা আরম্ভ করার সময় সময় শেষ হয়ে গেছে। প্রাথমিক LTZP একটি নির্দিষ্ট পরামর্শ জমা দিলে তা বন্ধ হয়ে যায়।
চিত্র 1-এ দেখানো হিসাবে, time_zone_detector
পরিষেবাগুলি টেলিফোনি বা অবস্থান অ্যালগরিদম থেকে টাইম জোনের পরামর্শ গ্রহণ করে৷ অবস্থান অ্যালগরিদম প্রাথমিক বা মাধ্যমিক LTZP থেকে পরামর্শ গ্রহণ করে।
চিত্র 1. অবস্থান সময় অঞ্চল সনাক্তকরণ তথ্য প্রবাহ।
ডিভাইস কনফিগারেশন প্রয়োজনীয়তা
অবস্থানের সময় অঞ্চল বৈশিষ্ট্য সমর্থন করার জন্য, ডিভাইসগুলিকে LTZPs দিয়ে কনফিগার করতে হবে যা ডিভাইসটি ব্যবহার করতে পারে৷ ডিভাইসগুলির জন্য কমপক্ষে একটি LTZP সক্ষম এবং কনফিগার করা প্রয়োজন যাতে লোকেশন টাইম জোন সনাক্তকরণ কার্যকরী এবং সেটিংসে ব্যবহারকারীদের কাছে দৃশ্যমান হয়৷
ডিভাইস কনফিগারেশন
এই বিভাগটি বর্ণনা করে যে কীভাবে ডিভাইস নির্মাতারা অবস্থানের সময় অঞ্চল সনাক্তকরণকে সমর্থন করার জন্য ডিভাইসগুলি কনফিগার করতে পারে।
বেস AOSP কনফিগারেশন frameworks/base/core/res/res/values/config.xml
এ রয়েছে:
কনফিগারেশন কী | AOSP মান | বর্ণনা |
---|---|---|
config_enableGeolocationTimeZoneDetection | true | অবস্থান সময় অঞ্চল সনাক্তকরণ বৈশিষ্ট্যের জন্য এটি প্রধান নিয়ন্ত্রণ। বৈশিষ্ট্যটি AOSP-এ ডিফল্টরূপে সমর্থিত। অন্তত একটি LTZP সক্রিয় বা কনফিগার করা আবশ্যক যাতে ব্যবহারকারীদের জন্য উপলব্ধ করা যায়। মানটিকে মিথ্যাতে সেট করা একটি ছোট মেমরি সংরক্ষণের জন্য বৈশিষ্ট্যটিকে সম্পূর্ণরূপে নিষ্ক্রিয় করে। |
config_enablePrimaryLocationTimeZoneProvider | false | এটি প্রাথমিক LTZP সক্ষম করে। |
config_primaryLocationTimeZoneProviderPackageName | অ্যাপের প্যাকেজ নামের সাথে এটি সেট করুন যেখানে প্রাথমিক প্রদানকারী পরিষেবা পাওয়া যাবে। | |
config_enableSecondaryLocationTimeZoneProvider | false | এটি সেকেন্ডারি LTZP সক্ষম করে। |
config_secondaryLocationTimeZoneProviderPackageName | অ্যাপের প্যাকেজ নামের সাথে এটি সেট করুন যেখানে সেকেন্ডারি প্রদানকারী পরিষেবা পাওয়া যাবে। |
ডিফল্টরূপে, AOSP কনফিগারেশনে config_enableGeolocationTimeZoneDetection
কীটি true
এ সেট করা আছে, যা অবস্থানের সময় অঞ্চল সনাক্তকরণ বৈশিষ্ট্যের জন্য সমর্থন সক্ষম করে। বৈশিষ্ট্যটি প্রাথমিকভাবে ব্যবহারকারীদের কাছে দৃশ্যমান নয় কারণ AOSP ডিফল্টরূপে LTZP কনফিগারেশন অন্তর্ভুক্ত করে না। যাইহোক, এই ডিফল্ট কনফিগারেশন ব্যবহার করে, ডিভাইস নির্মাতারা পরীক্ষার জন্য কমান্ড লাইন থেকে LTZPs সক্ষম এবং অনুকরণ করতে পারে। (আরো তথ্যের জন্য, ডিবাগিং এবং টেস্টিং দেখুন।)
LTZP স্ট্যাটাস API
Android 14-এ, LTZP API গুলি LTZP রিপোর্টিং স্ট্যাটাস তথ্য সমর্থন করে। এটি LTZP-কে সেই সমস্যাগুলির রিপোর্ট করতে সক্ষম করে যেগুলি প্ল্যাটফর্ম নিজের জন্য সনাক্ত করতে সক্ষম নাও হতে পারে, কারণ প্ল্যাটফর্ম টাইম জোন সনাক্তকরণ উপাদানগুলি অবস্থান অ্যালগরিদমে অবস্থান বা সময় অঞ্চল সনাক্তকরণের সাথে সরাসরি জড়িত নয়৷
টেলিফোনি ফলব্যাক মোড সমর্থিত হলে ডিভাইসের পরিবেশের দ্বারা LTZP-এর আচরণের অবনতি হয়েছে বলে রিপোর্ট করার ক্ষমতা কার্যকর। উদাহরণস্বরূপ, যদি কোনও তৃতীয় পক্ষের LTZP যা কাস্টম সেটিংস বা তার অবস্থান সনাক্তকরণের কাজ করার জন্য অনুমতিগুলির উপর নির্ভর করে তা একটি অবনমিত মোডে চলছে বা বর্তমান ডিভাইস সেটিংস দ্বারা অক্ষম করা হয়েছে, তাহলে এটি সেটিংস অ্যাপের মতো অভ্যন্তরীণ প্ল্যাটফর্ম উপাদানগুলিতে এই অবস্থার তথ্য প্রতিবেদন করতে পারে reportSuggestion
পদ্ধতির মাধ্যমে। তারপরে সেটিংস অ্যাপটি কাস্টমাইজযোগ্য স্ট্রিং বা কাস্টমাইজেশনের মাধ্যমে ব্যবহারকারীদের অবহিত করতে পারে যে অবস্থানের অ্যালগরিদমটি ভালভাবে বা একেবারে কাজ করার জন্য এমন সেটিংস রয়েছে যা অবশ্যই পরিবর্তন করতে হবে।
LTZP যে স্ট্যাটাসগুলি রিপোর্ট করতে পারে সে সম্পর্কে আরও তথ্যের জন্য, TimeZoneProviderStatus
দেখুন।
LTZP কনফিগারেশন এবং স্থাপনা
একটি LTZP কনফিগার করার সময়, frameworks/base/core/java/android/service/timezone/TimeZoneProviderService.java
এর জন্য সোর্স কোডের নির্দেশাবলী পড়ুন। Javadoc মন্তব্যগুলি পরিষেবা, প্রয়োজনীয় অনুমতি এবং অন্যান্য কনফিগারেশনের বিশদ প্রদান করে।
একটি LTZP কনফিগার করতে, ডিভাইস নির্মাতাদের LTZP-এর পরিষেবা হোস্ট করার জন্য একটি অ্যাপ প্রক্রিয়া বেছে নিতে হবে। একটি LTZP এর জন্য একটি উত্সর্গীকৃত প্রক্রিয়া থাকা একটি উচ্চ ওভারহেড; আদর্শভাবে, নির্বাচিত অ্যাপ প্রক্রিয়াটি এমন একটি যা সর্বদা চলমান থাকে যেমন সিস্টেম সার্ভার।
মডুলার সিস্টেম উপাদান (মডিউল) সহ ডিভাইসগুলিতে, LTZP দ্বারা ব্যবহৃত জিও ডেটা এবং টাইম জোন ডেটা মডিউল ( com.android.tzdata
) এ বাহিত সময় অঞ্চল নিয়মগুলির (tzdb) মধ্যে মিথস্ক্রিয়া বিবেচনা করুন৷ একটির আপডেট অন্যটির আপডেট ছাড়াই সংস্করণ তির্যক সমস্যার কারণ হতে পারে। আরও তথ্যের জন্য, বৈশিষ্ট্য গ্রহণের বিবেচনা দেখুন।
AOSP রেফারেন্স LTZP
AOSP-এ packages/modules/GeoTZ
এর অধীনে একটি রেফারেন্স LTZP বাস্তবায়ন রয়েছে। এই রেফারেন্স বাস্তবায়ন ডিভাইসের অবস্থান নির্ধারণ করতে AOSP API ব্যবহার করে এবং একটি টাইম জোন আইডির সেটে অবস্থান ম্যাপ করতে একটি অন-ডিভাইস ডেটা ফাইল ব্যবহার করে।
অন্যান্য ওপেন সোর্স প্রকল্প থেকে প্রাপ্ত একটি রেফারেন্স ডেটা সেট সোর্স কোডের সাথে অন্তর্ভুক্ত করা হয়। আরো বিস্তারিত জানার জন্য, README.md এবং বিভিন্ন লাইসেন্স ফাইল দেখুন।
ডিবাগ এবং পরীক্ষা
নিম্নলিখিত বিভাগটি ডিবাগিং এবং অবস্থানের সময় অঞ্চল সনাক্তকরণ বৈশিষ্ট্য পরীক্ষা করার জন্য শেল কমান্ড বর্ণনা করে।
লোকেশন_টাইম_জোন_ম্যানেজার পরিষেবার সাথে ইন্টারঅ্যাক্ট করুন
লোকেশন অ্যালগরিদম যখন Android 12 বা উচ্চতর সংস্করণে চালিত একটি ডিভাইসে সমর্থিত হয়, তখন Android বুট করার সময় location_time_zone_manager
পরিষেবাকে ইনস্ট্যান্টিয়েট করে।
location_time_zone_manager
এর বর্তমান অবস্থা ডাম্প করতে, ব্যবহার করুন:
adb shell cmd location_time_zone_manager dump
পরীক্ষায় সহায়তা করার জন্য কমান্ড লাইন বিকল্পগুলির একটি বিস্তৃত সেট দেখতে, ব্যবহার করুন:
adb shell cmd location_time_zone_manager help
হেল্প আউটপুট device_config
পরিষেবা বৈশিষ্ট্যগুলিকেও বর্ণনা করে যা পরীক্ষার জন্য বা উত্পাদনের জন্য time_zone_detector
এর আচরণকে প্রভাবিত করতে ব্যবহার করা যেতে পারে। আরও তথ্যের জন্য, device_config পরিষেবা ব্যবহার করে একটি ডিভাইস কনফিগার করা দেখুন।
LTZP বাস্তবায়নগুলি তাদের নিজস্ব ডিবাগিং বা পরীক্ষার সহায়তা প্রদান করতে পারে। উদাহরণস্বরূপ, আপনি AOSP রেফারেন্স LTZP ডিবাগ করতে নিম্নলিখিত কমান্ডটি ব্যবহার করতে পারেন যখন এটি সিস্টেম সার্ভার প্রক্রিয়াতে নিবন্ধিত হয়।
adb shell dumpsys activity service android/com.android.timezone.location.provider.OfflineLocationTimeZoneProviderService