1. আপনি শুরু করার আগে
অ্যান্ড্রয়েড 10 এবং 11 ব্যবহারকারীদের তাদের ডিভাইসের অবস্থানে তাদের অ্যাপের অ্যাক্সেসের উপর আরও নিয়ন্ত্রণ দেয়।
যখন Android 11-এ চলমান একটি অ্যাপ লোকেশন অ্যাক্সেসের অনুরোধ করে, ব্যবহারকারীদের কাছে চারটি বিকল্প থাকে:
- সব সময় অনুমতি দিন
- শুধুমাত্র অ্যাপ ব্যবহার করার সময় অনুমতি দিন (Android 10 এ)
- শুধুমাত্র একবার (Android 11 এ)
- অস্বীকার করুন
অ্যান্ড্রয়েড 10

অ্যান্ড্রয়েড 11

এই কোডল্যাবে, আপনি কীভাবে লোকেশন আপডেট পাবেন এবং অ্যান্ড্রয়েডের যেকোনো সংস্করণে, বিশেষ করে অ্যান্ড্রয়েড 10 এবং 11-এ কীভাবে লোকেশন সমর্থন করবেন তা শিখবেন। কোডল্যাবের শেষে, আপনি একটি অ্যাপ পাওয়ার আশা করতে পারেন যা পুনরুদ্ধারের জন্য বর্তমান সেরা অনুশীলনগুলি অনুসরণ করে। অবস্থান আপডেট।
পূর্বশর্ত
- অ্যান্ড্রয়েড বিকাশের সাথে পরিচিতি
- ক্রিয়াকলাপ , পরিষেবা এবং অনুমতিগুলির সাথে কিছু পরিচিতি
আপনি কি করবেন
- Android এ অবস্থানের জন্য সর্বোত্তম অনুশীলনগুলি অনুসরণ করুন৷
- ফোরগ্রাউন্ড অবস্থানের অনুমতিগুলি পরিচালনা করুন (যখন ব্যবহারকারী অনুরোধ করে যে আপনার অ্যাপটি ব্যবহার করা অবস্থায় ডিভাইসের অবস্থান অ্যাক্সেস করার জন্য)।
- অবস্থানে সদস্যতা নেওয়া এবং সদস্যতা ত্যাগ করার জন্য কোড যোগ করে অবস্থান অ্যাক্সেসের অনুরোধের জন্য সমর্থন যোগ করতে একটি বিদ্যমান অ্যাপ পরিবর্তন করুন।
- ফোরগ্রাউন্ড লোকেশনে বা ব্যবহারের সময় লোকেশন অ্যাক্সেস করার জন্য যুক্তি যোগ করে Android 10 এবং 11-এর জন্য অ্যাপে সমর্থন যোগ করুন।
আপনি কি প্রয়োজন হবে
- অ্যান্ড্রয়েড স্টুডিও 3.4 বা তার পরে কোড চালানোর জন্য
- Android 10 এবং 11-এর ডেভেলপার প্রিভিউ চালানোর জন্য একটি ডিভাইস/এমুলেটর
2. শুরু করা
স্টার্টার প্রজেক্ট রেপো ক্লোন করুন
যত তাড়াতাড়ি সম্ভব আপনাকে শুরু করতে, আপনি এই স্টার্টার প্রকল্পটি তৈরি করতে পারেন। আপনার যদি গিট ইনস্টল থাকে তবে আপনি কেবল নিম্নলিখিত কমান্ডটি চালাতে পারেন:
git clone https://github.com/android/codelab-while-in-use-location
নির্দ্বিধায় সরাসরি গিটহাব পৃষ্ঠাটি দেখুন।
আপনার যদি গিট না থাকে তবে আপনি একটি জিপ ফাইল হিসাবে প্রকল্পটি পেতে পারেন:
প্রকল্পটি আমদানি করুন
অ্যান্ড্রয়েড স্টুডিও খুলুন, স্বাগত স্ক্রীন থেকে " একটি বিদ্যমান অ্যান্ড্রয়েড স্টুডিও প্রকল্প খুলুন " নির্বাচন করুন এবং প্রকল্প ডিরেক্টরি খুলুন।
প্রকল্পটি লোড হওয়ার পরে, আপনি একটি সতর্কতাও দেখতে পারেন যে গিট আপনার সমস্ত স্থানীয় পরিবর্তনগুলি ট্র্যাক করছে না। আপনি উপেক্ষা ক্লিক করতে পারেন। (আপনি গিট রেপোতে কোনও পরিবর্তন ফিরিয়ে আনবেন না।)
প্রজেক্ট উইন্ডোর উপরের বাম কোণে, আপনি যদি অ্যান্ড্রয়েড ভিউতে থাকেন তবে নীচের ছবির মতো কিছু দেখতে পাবেন। (আপনি যদি প্রকল্পের দৃশ্যে থাকেন তবে একই জিনিস দেখতে আপনাকে প্রকল্পটি প্রসারিত করতে হবে।)

দুটি ফোল্ডার আছে ( base এবং complete )। প্রতিটি একটি "মডিউল" হিসাবে পরিচিত।
অনুগ্রহ করে মনে রাখবেন যে অ্যান্ড্রয়েড স্টুডিও প্রথমবারের মতো পটভূমিতে প্রকল্পটি কম্পাইল করতে কয়েক সেকেন্ড সময় নিতে পারে। এই সময়ের মধ্যে, আপনি Android স্টুডিওর নীচে স্ট্যাটাস বারে নিম্নলিখিত বার্তাটি দেখতে পাবেন:

কোড পরিবর্তন করার আগে অ্যান্ড্রয়েড স্টুডিও ইন্ডেক্সিং এবং প্রোজেক্ট তৈরি করা শেষ না হওয়া পর্যন্ত অপেক্ষা করুন। এটি অ্যান্ড্রয়েড স্টুডিওকে সমস্ত প্রয়োজনীয় উপাদানগুলিকে টানতে অনুমতি দেবে৷
আপনি যদি একটি প্রম্পট পান যে ভাষা পরিবর্তনগুলি কার্যকর হওয়ার জন্য পুনরায় লোড করুন? বা অনুরূপ কিছু, হ্যাঁ নির্বাচন করুন।
স্টার্টার প্রজেক্ট বুঝুন
আপনি সেট আপ করেছেন এবং অ্যাপে অবস্থানের অনুরোধ করতে প্রস্তুত৷ প্রারম্ভিক বিন্দু হিসাবে base মডিউল ব্যবহার করুন. প্রতিটি ধাপের সময়, base মডিউলে কোড যোগ করুন। এই কোডল্যাবের সাথে আপনার কাজ শেষ হওয়ার সময়, base মডিউলের কোডটি complete মডিউলের বিষয়বস্তুর সাথে মেলে। complete মডিউলটি আপনার কাজ পরীক্ষা করার জন্য বা আপনি যদি কোনো সমস্যার সম্মুখীন হন তাহলে রেফারেন্স করার জন্য ব্যবহার করা যেতে পারে।
মূল উপাদানগুলির মধ্যে নিম্নলিখিতগুলি অন্তর্ভুক্ত রয়েছে:
-
MainActivity—ব্যবহারকারীর জন্য অ্যাপটিকে ডিভাইসের অবস্থান অ্যাক্সেস করার অনুমতি দেওয়ার জন্য UI -
LocationService— এমন পরিষেবা যা সদস্যতা নেয় এবং অবস্থান পরিবর্তনের সদস্যতা ত্যাগ করে, এবং ব্যবহারকারী অ্যাপের কার্যকলাপ থেকে দূরে সরে গেলে নিজেকে একটি অগ্রভাগের পরিষেবাতে (একটি বিজ্ঞপ্তি সহ) প্রচার করে৷ আপনি এখানে অবস্থান কোড যোগ করুন. -
Util—Locationশ্রেণীর জন্য এক্সটেনশন ফাংশন যোগ করে এবংSharedPreferences(সরলীকৃত ডেটা স্তর) এ অবস্থান সংরক্ষণ করে।
এমুলেটর সেটআপ
একটি অ্যান্ড্রয়েড এমুলেটর সেট আপ সম্পর্কে তথ্যের জন্য, এমুলেটর চালান দেখুন।
স্টার্টার প্রকল্প চালান
আপনার অ্যাপ চালান।
- আপনার কম্পিউটারে আপনার অ্যান্ড্রয়েড ডিভাইসটি সংযুক্ত করুন বা একটি এমুলেটর শুরু করুন৷ (নিশ্চিত করুন যে ডিভাইসটি Android 10 বা উচ্চতর সংস্করণে চলছে।)
- টুলবারে, ড্রপ-ডাউন নির্বাচক থেকে
baseকনফিগারেশন নির্বাচন করুন এবং রান ক্লিক করুন:

- লক্ষ্য করুন যে আপনার ডিভাইসে নিম্নলিখিত অ্যাপটি উপস্থিত হয়েছে:

আপনি লক্ষ্য করতে পারেন যে আউটপুট স্ক্রিনে কোনও অবস্থানের তথ্য উপস্থিত হয় না। কারণ আপনি এখনও লোকেশন কোড যোগ করেননি।
3. অবস্থান যোগ করা হচ্ছে
ধারণা
এই কোডল্যাবের ফোকাস হল আপনাকে দেখানো যে কিভাবে লোকেশন আপডেট পাবেন এবং অবশেষে Android 10 এবং Android 11 সমর্থন করবেন।
যাইহোক, আপনি কোডিং শুরু করার আগে, মূল বিষয়গুলি পর্যালোচনা করা বোধগম্য।
অবস্থান অ্যাক্সেসের ধরন
কোডল্যাবের শুরু থেকে লোকেশন অ্যাক্সেসের জন্য আপনি চারটি ভিন্ন বিকল্প মনে রাখতে পারেন। তারা কি বোঝায় তা একবার দেখুন:
- শুধুমাত্র অ্যাপ ব্যবহার করার সময় অনুমতি দিন
- এই বিকল্পটি বেশিরভাগ অ্যাপের জন্য প্রস্তাবিত বিকল্প। "ব্যবহারের সময়" বা "শুধুমাত্র ফোরগ্রাউন্ড" অ্যাক্সেস হিসাবেও পরিচিত, এই বিকল্পটি Android 10-এ যোগ করা হয়েছিল এবং অ্যাপটি সক্রিয়ভাবে ব্যবহার করার সময়ই বিকাশকারীদের অবস্থান পুনরুদ্ধার করতে দেয়। নিম্নলিখিতগুলির মধ্যে যেকোনো একটি সত্য হলে একটি অ্যাপ সক্রিয় বলে বিবেচিত হয়:
- একটি কার্যকলাপ দৃশ্যমান হয়.
- একটি ফোরগ্রাউন্ড পরিষেবা একটি চলমান বিজ্ঞপ্তি সহ চলছে৷
- শুধু একবার
- অ্যান্ড্রয়েড 11-এ যোগ করা হয়েছে, এটি শুধুমাত্র অ্যাপ ব্যবহার করার সময় অনুমতি দেওয়ার মতো, কিন্তু সীমিত সময়ের জন্য। আরও তথ্যের জন্য, একবারের অনুমতি দেখুন।
- অস্বীকার করুন
- এই বিকল্পটি অবস্থানের তথ্য অ্যাক্সেস করতে বাধা দেয়।
- সব সময় অনুমতি দিন
- এই বিকল্পটি সর্বদা অবস্থান অ্যাক্সেসের অনুমতি দেয়, তবে Android 10 এবং উচ্চতর সংস্করণের জন্য একটি অতিরিক্ত অনুমতি প্রয়োজন ৷ আপনাকে অবশ্যই নিশ্চিত করতে হবে যে আপনার একটি বৈধ ব্যবহারের কেস আছে এবং অবস্থান নীতি মেনে চলছেন। আপনি এই কোডল্যাবে এই বিকল্পটি কভার করবেন না, কারণ এটি একটি বিরল ব্যবহারের ক্ষেত্রে। যাইহোক, যদি আপনার একটি বৈধ ব্যবহারের ক্ষেত্রে থাকে এবং ব্যাকগ্রাউন্ডে অবস্থান অ্যাক্সেস সহ সার্বক্ষণিক অবস্থান কীভাবে সঠিকভাবে পরিচালনা করবেন তা বুঝতে চান, LocationUpdatesBackgroundKotlin নমুনাটি পর্যালোচনা করুন।
পরিষেবা, ফোরগ্রাউন্ড পরিষেবা এবং বাঁধাই৷
শুধুমাত্র অ্যাপ্লিকেশান অবস্থান আপডেটগুলি ব্যবহার করার সময় অনুমতি দেওয়াকে সম্পূর্ণরূপে সমর্থন করতে, ব্যবহারকারী কখন আপনার অ্যাপ থেকে দূরে নেভিগেট করবে তার জন্য আপনাকে অ্যাকাউন্ট করতে হবে৷ আপনি যদি সেই পরিস্থিতিতে আপডেটগুলি পাওয়া চালিয়ে যেতে চান, তাহলে আপনাকে একটি অগ্রভাগের Service তৈরি করতে হবে এবং এটিকে একটি Notification সাথে সংযুক্ত করতে হবে৷
উপরন্তু, আপনার অ্যাপটি দৃশ্যমান হলে এবং ব্যবহারকারী যখন আপনার অ্যাপ থেকে দূরে নেভিগেট করে তখন অবস্থান আপডেটের অনুরোধ করতে আপনি একই Service ব্যবহার করতে চাইলে, আপনাকে সেই Service UI উপাদানের সাথে আবদ্ধ/আবদ্ধ করতে হবে।
কারণ এই কোডল্যাবটি শুধুমাত্র অবস্থানের আপডেট পাওয়ার উপর ফোকাস করে, আপনি ForegroundOnlyLocationService.kt ক্লাসে আপনার প্রয়োজনীয় সমস্ত কোড খুঁজে পেতে পারেন। তারা কীভাবে একসাথে কাজ করে তা দেখতে আপনি সেই ক্লাস এবং MainActivity.kt এর মাধ্যমে ব্রাউজ করতে পারেন।
আরও তথ্যের জন্য, পরিষেবার ওভারভিউ এবং আবদ্ধ পরিষেবার ওভারভিউ দেখুন।
অনুমতি
একটি NETWORK_PROVIDER বা GPS_PROVIDER থেকে অবস্থানের আপডেট পেতে, আপনাকে অবশ্যই আপনার Android ম্যানিফেস্ট ফাইলে যথাক্রমে ACCESS_COARSE_LOCATION বা ACCESS_FINE_LOCATION অনুমতি ঘোষণা করে ব্যবহারকারীর অনুমতির জন্য অনুরোধ করতে হবে৷ এই অনুমতিগুলি ছাড়া, আপনার অ্যাপ রানটাইমে অবস্থানে অ্যাক্সেসের অনুরোধ করতে সক্ষম হবে না।
এই অনুমতিগুলি শুধুমাত্র এক সময় কভার করে এবং শুধুমাত্র অ্যাপ ব্যবহার করার সময় অনুমতি দেয় যখন আপনার অ্যাপটি Android 10 বা তার উচ্চতর সংস্করণে চালিত ডিভাইসে ব্যবহার করা হয়।
অবস্থান
আপনার অ্যাপ com.google.android.gms.location প্যাকেজে ক্লাসের মাধ্যমে সমর্থিত অবস্থান পরিষেবার সেট অ্যাক্সেস করতে পারে।
প্রধান ক্লাস দেখুন:
-
FusedLocationProviderClient - এটি অবস্থান কাঠামোর কেন্দ্রীয় উপাদান। একবার তৈরি হয়ে গেলে, আপনি অবস্থান আপডেটের অনুরোধ করতে এবং সর্বশেষ পরিচিত অবস্থান পেতে এটি ব্যবহার করেন।
-
LocationRequest - এটি একটি ডেটা অবজেক্ট যাতে অনুরোধের জন্য পরিষেবার মান-অবজেক্ট থাকে (আপডেট, অগ্রাধিকার এবং নির্ভুলতার জন্য ব্যবধান)। যখন আপনি অবস্থান আপডেটের অনুরোধ করেন তখন এটি
FusedLocationProviderClientএর কাছে পাঠানো হয়। -
LocationCallback - যখন ডিভাইসের অবস্থান পরিবর্তিত হয় বা আর নির্ধারণ করা যায় না তখন এটি বিজ্ঞপ্তি পাওয়ার জন্য ব্যবহৃত হয়। এটি একটি
LocationResultপাস করা হয়েছে যেখানে আপনি আপনার ডাটাবেসে সংরক্ষণ করার জন্যLocationপেতে পারেন।
এখন আপনি কি করছেন তার একটি প্রাথমিক ধারণা আছে, কোড দিয়ে শুরু করুন!
4. অবস্থান বৈশিষ্ট্য যোগ করুন
এই কোডল্যাবটি সর্বাধিক-সাধারণ অবস্থান বিকল্পের উপর ফোকাস করে: অ্যাপটি ব্যবহার করার সময় শুধুমাত্র অনুমতি দিন ।
অবস্থানের আপডেটগুলি পেতে, আপনার অ্যাপের অবশ্যই একটি দৃশ্যমান কার্যকলাপ থাকতে হবে বা অগ্রভাগে চলমান একটি পরিষেবা থাকতে হবে (একটি বিজ্ঞপ্তি সহ)৷
অনুমতি
এই কোডল্যাবের উদ্দেশ্য হল লোকেশনের আপডেটগুলি কীভাবে গ্রহণ করা যায় তা দেখানো, কীভাবে লোকেশন অনুমতির অনুরোধ করা যায় না, তাই অনুমতি-ভিত্তিক কোডটি ইতিমধ্যেই আপনার জন্য লেখা হয়েছে। আপনি যদি এটি ইতিমধ্যে বুঝতে পারেন তবে নির্দ্বিধায় এটি এড়িয়ে যান।
নিম্নলিখিত অনুমতি হাইলাইট (এই অংশের জন্য কোন কর্মের প্রয়োজন নেই):
- আপনি
AndroidManifest.xmlএ কোন অনুমতি ব্যবহার করছেন তা ঘোষণা করুন। - অবস্থানের তথ্য অ্যাক্সেস করার চেষ্টা করার আগে, ব্যবহারকারী আপনার অ্যাপকে এটি করার অনুমতি দিয়েছেন কিনা তা পরীক্ষা করুন। যদি আপনার অ্যাপ এখনও অনুমতি না পায়, অ্যাক্সেসের অনুরোধ করুন।
- ব্যবহারকারীর অনুমতি পছন্দ হ্যান্ডেল. (আপনি এই কোডটি
MainActivity.ktএ দেখতে পারেন।)
আপনি যদি TODO: Step 1.0, Review Permissions AndroidManifest.xml বা MainActivity.kt এ অনুমতি পর্যালোচনা করুন, আপনি অনুমতির জন্য লেখা সমস্ত কোড দেখতে পাবেন।
আরও তথ্যের জন্য, অনুমতি ওভারভিউ দেখুন।
এখন, কিছু লোকেশন কোড লেখা শুরু করুন।
অবস্থান আপডেটের জন্য প্রয়োজনীয় মূল ভেরিয়েবল পর্যালোচনা করুন
base মডিউলে, TODO: Step 1.1, Review variables
ForegroundOnlyLocationService.kt ফাইল।
এই ধাপে কোন কর্মের প্রয়োজন নেই। অবস্থান আপডেট পেতে আপনি যে মূল ক্লাস এবং ভেরিয়েবলগুলি ব্যবহার করেন তা বোঝার জন্য আপনাকে মন্তব্য সহ নিম্নলিখিত কোড ব্লকটি পর্যালোচনা করতে হবে।
// TODO: Step 1.1, Review variables (no changes).
// FusedLocationProviderClient - Main class for receiving location updates.
private lateinit var fusedLocationProviderClient: FusedLocationProviderClient
// LocationRequest - Requirements for the location updates, i.e., how often you
// should receive updates, the priority, etc.
private lateinit var locationRequest: LocationRequest
// LocationCallback - Called when FusedLocationProviderClient has a new Location.
private lateinit var locationCallback: LocationCallback
// Used only for local storage of the last known location. Usually, this would be saved to your
// database, but because this is a simplified sample without a full database, we only need the
// last location to create a Notification if the user navigates away from the app.
private var currentLocation: Location? = null
FusedLocationProviderClient সূচনা পর্যালোচনা করুন
base মডিউলে, TODO অনুসন্ধান করুন: ধাপ 1.2, ForegroundOnlyLocationService.kt ফাইলে TODO: Step 1.2, Review the FusedLocationProviderClient । আপনার কোড এই মত কিছু দেখতে হবে:
// TODO: Step 1.2, Review the FusedLocationProviderClient.
fusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this)
পূর্ববর্তী মন্তব্যে উল্লেখ করা হয়েছে, অবস্থান আপডেট পাওয়ার জন্য এটি প্রধান শ্রেণী। ভেরিয়েবলটি ইতিমধ্যেই আপনার জন্য আরম্ভ করা হয়েছে, তবে এটি কীভাবে শুরু করা হয়েছে তা বোঝার জন্য কোডটি পর্যালোচনা করা গুরুত্বপূর্ণ। অবস্থান আপডেটের অনুরোধ করতে আপনি পরে এখানে কিছু কোড যোগ করুন।
LocationRequest আরম্ভ করুন
-
baseমডিউলে,TODO: Step 1.3, Create a LocationRequestForegroundOnlyLocationService.ktফাইলে একটি অবস্থানের অনুরোধ তৈরি করুন। - মন্তব্যের পরে নিম্নলিখিত কোড যোগ করুন.
LocationRequest ইনিশিয়ালাইজেশন কোড আপনার অনুরোধের জন্য প্রয়োজনীয় পরিষেবার প্যারামিটারের অতিরিক্ত গুণমান যোগ করে (ব্যবধান, সর্বোচ্চ অপেক্ষার সময় এবং অগ্রাধিকার)।
// TODO: Step 1.3, Create a LocationRequest.
locationRequest = LocationRequest.create().apply {
// Sets the desired interval for active location updates. This interval is inexact. You
// may not receive updates at all if no location sources are available, or you may
// receive them less frequently than requested. You may also receive updates more
// frequently than requested if other applications are requesting location at a more
// frequent interval.
//
// IMPORTANT NOTE: Apps running on Android 8.0 and higher devices (regardless of
// targetSdkVersion) may receive updates less frequently than this interval when the app
// is no longer in the foreground.
interval = TimeUnit.SECONDS.toMillis(60)
// Sets the fastest rate for active location updates. This interval is exact, and your
// application will never receive updates more frequently than this value.
fastestInterval = TimeUnit.SECONDS.toMillis(30)
// Sets the maximum time when batched location updates are delivered. Updates may be
// delivered sooner than this interval.
maxWaitTime = TimeUnit.MINUTES.toMillis(2)
priority = LocationRequest.PRIORITY_HIGH_ACCURACY
}
- প্রতিটি কিভাবে কাজ করে তা বুঝতে মন্তব্যের মাধ্যমে পড়ুন।
LocationCallback আরম্ভ করুন
-
baseমডিউলে, TODO অনুসন্ধান করুন: ধাপ 1.4,ForegroundOnlyLocationService.ktফাইলেTODO: Step 1.4, Initialize the LocationCallback - মন্তব্যের পরে নিম্নলিখিত কোড যোগ করুন.
// TODO: Step 1.4, Initialize the LocationCallback.
locationCallback = object : LocationCallback() {
override fun onLocationResult(locationResult: LocationResult) {
super.onLocationResult(locationResult)
// Normally, you want to save a new location to a database. We are simplifying
// things a bit and just saving it as a local variable, as we only need it again
// if a Notification is created (when the user navigates away from app).
currentLocation = locationResult.lastLocation
// Notify our Activity that a new location was added. Again, if this was a
// production app, the Activity would be listening for changes to a database
// with new locations, but we are simplifying things a bit to focus on just
// learning the location side of things.
val intent = Intent(ACTION_FOREGROUND_ONLY_LOCATION_BROADCAST)
intent.putExtra(EXTRA_LOCATION, currentLocation)
LocalBroadcastManager.getInstance(applicationContext).sendBroadcast(intent)
// Updates notification content if this service is running as a foreground
// service.
if (serviceRunningInForeground) {
notificationManager.notify(
NOTIFICATION_ID,
generateNotification(currentLocation))
}
}
}
আপনি এখানে যে LocationCallback তৈরি করেন সেটি হল একটি নতুন অবস্থান আপডেট উপলব্ধ হলে FusedLocationProviderClient কল করবে।
আপনার কলব্যাকে, আপনি প্রথমে একটি LocationResult অবজেক্ট ব্যবহার করে সর্বশেষ অবস্থান পাবেন। এর পরে, আপনি স্থানীয় সম্প্রচার ব্যবহার করে (যদি এটি সক্রিয় থাকে) ব্যবহার করে আপনার নতুন অবস্থানের Activity অবহিত করেন বা এই পরিষেবাটি অগ্রভাগের Service হিসাবে চলমান থাকলে আপনি Notification আপডেট করেন৷
- প্রতিটি অংশ কি করে তা বুঝতে মন্তব্যগুলি পড়ুন।
অবস্থান পরিবর্তন সাবস্ক্রাইব করুন
এখন যেহেতু আপনি সবকিছু শুরু করেছেন, আপনাকে FusedLocationProviderClient কে জানাতে হবে যে আপনি আপডেট পেতে চান।
-
baseমডিউলে, ধাপ 1.5 অনুসন্ধান করুন,ForegroundOnlyLocationService.ktফাইলেStep 1.5, Subscribe to location changes। - মন্তব্যের পরে নিম্নলিখিত কোড যোগ করুন.
// TODO: Step 1.5, Subscribe to location changes.
fusedLocationProviderClient.requestLocationUpdates(locationRequest, locationCallback, Looper.getMainLooper())
requestLocationUpdates() কলটি FusedLocationProviderClient কে জানতে দেয় যে আপনি অবস্থানের আপডেট পেতে চান।
আপনি সম্ভবত LocationRequest এবং LocationCallback চিনতে পারেন যা আপনি আগে সংজ্ঞায়িত করেছেন। তারা FusedLocationProviderClient আপনার অনুরোধের জন্য পরিষেবার মান-পরিমাণ এবং এটির আপডেট হলে কী বলা উচিত তা জানতে দেয়। অবশেষে, Looper অবজেক্ট কলব্যাকের জন্য থ্রেড নির্দিষ্ট করে।
আপনি লক্ষ্য করতে পারেন যে এই কোডটি একটি try/catch বিবৃতির মধ্যে রয়েছে। এই পদ্ধতিতে এই ধরনের একটি ব্লক প্রয়োজন কারণ আপনার অ্যাপের কাছে অবস্থানের তথ্য অ্যাক্সেস করার অনুমতি না থাকলে একটি SecurityException ঘটে।
অবস্থান পরিবর্তন থেকে সদস্যতা ত্যাগ করুন
যখন অ্যাপটির আর অবস্থানের তথ্যে অ্যাক্সেসের প্রয়োজন হয় না, তখন অবস্থানের আপডেটগুলি থেকে সদস্যতা ত্যাগ করা গুরুত্বপূর্ণ৷
-
baseমডিউলে, TODO অনুসন্ধান করুন: ধাপ 1.6,ForegroundOnlyLocationService.ktফাইলেTODO: Step 1.6, Unsubscribe to location changes। - মন্তব্যের পরে নিম্নলিখিত কোড যোগ করুন.
// TODO: Step 1.6, Unsubscribe to location changes.
val removeTask = fusedLocationProviderClient.removeLocationUpdates(locationCallback)
removeTask.addOnCompleteListener { task ->
if (task.isSuccessful) {
Log.d(TAG, "Location Callback removed.")
stopSelf()
} else {
Log.d(TAG, "Failed to remove Location Callback.")
}
}
removeLocationUpdates() পদ্ধতিটি FusedLocationProviderClient কে জানাতে একটি টাস্ক সেট আপ করে যে আপনি আর আপনার LocationCallback জন্য অবস্থান আপডেট পেতে চান না। addOnCompleteListener() সমাপ্তির জন্য কলব্যাক দেয় এবং Task চালায়।
আগের ধাপের মতো, আপনি হয়তো লক্ষ্য করেছেন যে এই কোডটি একটি try/catch স্টেটমেন্টের মধ্যে রয়েছে। এই পদ্ধতিতে এই ধরনের একটি ব্লক প্রয়োজন কারণ একটি SecurityException ঘটে যখন আপনার অ্যাপের অবস্থানের তথ্য অ্যাক্সেস করার অনুমতি নেই
আপনি আশ্চর্য হতে পারেন যখন সাবস্ক্রাইব/আনসাবস্ক্রাইব কোড ধারণ করা পদ্ধতিগুলি কল করা হয়। ব্যবহারকারী যখন বোতামে ট্যাপ করে তখন সেগুলি প্রধান শ্রেণীতে ট্রিগার হয়। আপনি যদি এটি দেখতে চান তবে MainActivity.kt ক্লাসটি দেখুন।
অ্যাপ চালান
অ্যান্ড্রয়েড স্টুডিও থেকে আপনার অ্যাপ চালান এবং অবস্থান বোতাম চেষ্টা করুন।
আপনি আউটপুট পর্দায় অবস্থান তথ্য দেখতে হবে. এটি Android 9 এর জন্য একটি সম্পূর্ণ কার্যকরী অ্যাপ।


5. Android 10 সমর্থন করে
এই বিভাগে, আপনি Android 10 এর জন্য সমর্থন যোগ করুন।
আপনার অ্যাপ্লিকেশান ইতিমধ্যেই অবস্থান পরিবর্তনের সদস্যতা নিয়েছে, তাই খুব বেশি কাজ করতে হবে না৷
প্রকৃতপক্ষে, আপনাকে যা করতে হবে তা হল আপনার ফোরগ্রাউন্ড পরিষেবাটি অবস্থানের উদ্দেশ্যে ব্যবহার করা হয় তা উল্লেখ করা।
লক্ষ্য SDK 29
-
baseমডিউলে,build.gradleফাইলেTODO: Step 2.1, Target Android 10 and then Android 11.অনুসন্ধান করুন। - এই পরিবর্তনগুলি করুন:
-
targetSdkVersion29এ সেট করুন।
আপনার কোড এই মত কিছু দেখতে হবে:
android {
// TODO: Step 2.1, Target Android 10 and then Android 11.
compileSdkVersion 29
defaultConfig {
applicationId "com.example.android.whileinuselocation"
minSdkVersion 26
targetSdkVersion 29
versionCode 1
versionName "1.0"
}
...
}
আপনি এটি করার পরে, আপনাকে আপনার প্রকল্প সিঙ্ক করতে বলা হবে। এখন সিঙ্ক এ ক্লিক করুন।

এর পরে, আপনার অ্যাপ Android 10 এর জন্য প্রায় প্রস্তুত।
ফোরগ্রাউন্ড পরিষেবার ধরন যোগ করুন
অ্যান্ড্রয়েড 10-এ, ব্যবহারের সময় অবস্থান অ্যাক্সেসের প্রয়োজন হলে আপনাকে আপনার ফোরগ্রাউন্ড পরিষেবার ধরন অন্তর্ভুক্ত করতে হবে। আপনার ক্ষেত্রে, এটি অবস্থানের তথ্য পেতে ব্যবহার করা হচ্ছে।
base মডিউলে, TODO এর জন্য অনুসন্ধান করুন: 2.2, AndroidManifest.xml এ TODO: 2.2, Add foreground service type এবং <service> উপাদানে নিম্নলিখিত কোড যোগ করুন:
android:foregroundServiceType="location"
আপনার কোড এই মত কিছু দেখতে হবে:
<application>
...
<!-- Foreground services in Android 10+ require type. -->
<!-- TODO: 2.2, Add foreground service type. -->
<service
android:name="com.example.android.whileinuselocation.ForegroundOnlyLocationService"
android:enabled="true"
android:exported="false"
android:foregroundServiceType="location" />
</application>
তাই তো! আপনার অ্যাপ Android-এ অবস্থানের জন্য সর্বোত্তম অনুশীলনগুলি অনুসরণ করে "ব্যবহারের সময়" জন্য Android 10 অবস্থান সমর্থন করে৷
অ্যাপ চালান
অ্যান্ড্রয়েড স্টুডিও থেকে আপনার অ্যাপ চালান এবং অবস্থান বোতাম চেষ্টা করুন।
সবকিছু আগের মতোই কাজ করা উচিত, কিন্তু এখন এটি অ্যান্ড্রয়েড 10-এ কাজ করে। আপনি যদি আগে অবস্থানের জন্য অনুমতি গ্রহণ না করে থাকেন, তাহলে আপনাকে এখন অনুমতি স্ক্রীন দেখতে হবে!



6. Android 11 সমর্থন করে
এই বিভাগে, আপনি Android 11 টার্গেট করেছেন।
দারুণ খবর, আপনাকে build.gradle ফাইল ছাড়া অন্য কোনো ফাইলে পরিবর্তন করতে হবে না!
টার্গেট SDK 11
-
baseমডিউলে,TODO: Step 2.1, Target SDKbuild.gradleফাইলে টার্গেট SDK। - এই পরিবর্তনগুলি করুন:
-
30এcompileSdkVersion -
targetSdkVersionসংস্করণ30
আপনার কোড এই মত কিছু দেখতে হবে:
android {
TODO: Step 2.1, Target Android 10 and then Android 11.
compileSdkVersion 30
defaultConfig {
applicationId "com.example.android.whileinuselocation"
minSdkVersion 26
targetSdkVersion 30
versionCode 1
versionName "1.0"
}
...
}
আপনি এটি করার পরে, আপনাকে আপনার প্রকল্প সিঙ্ক করতে বলা হবে। এখন সিঙ্ক এ ক্লিক করুন।

এর পরে, আপনার অ্যাপ Android 11 এর জন্য প্রস্তুত!
অ্যাপ চালান
অ্যান্ড্রয়েড স্টুডিও থেকে আপনার অ্যাপ চালান এবং বোতামে ক্লিক করার চেষ্টা করুন।
সবকিছু আগের মতোই কাজ করা উচিত, কিন্তু এখন এটি অ্যান্ড্রয়েড 11-এ কাজ করে। আপনি যদি আগে অবস্থানের জন্য অনুমতি গ্রহণ না করেন, তাহলে আপনার এখন অনুমতি স্ক্রীন দেখতে হবে!


7. Android এর জন্য অবস্থান কৌশল
এই কোডল্যাবে দেখানো উপায়ে অবস্থানের অনুমতিগুলি পরীক্ষা করে এবং অনুরোধ করার মাধ্যমে, আপনার অ্যাপটি ডিভাইসের অবস্থান সম্পর্কিত তার অ্যাক্সেসের স্তরটি সফলভাবে ট্র্যাক করতে পারে।
এই পৃষ্ঠাটি অবস্থানের অনুমতি সম্পর্কিত কয়েকটি মূল সেরা অনুশীলনের তালিকা দেয়। আপনার ব্যবহারকারীদের ডেটা কীভাবে সুরক্ষিত রাখবেন সে সম্পর্কে আরও তথ্যের জন্য, অ্যাপের অনুমতির সেরা অনুশীলনগুলি দেখুন৷
শুধুমাত্র আপনার প্রয়োজনীয় অনুমতিগুলির জন্য জিজ্ঞাসা করুন
প্রয়োজন হলেই অনুমতি চাও। যেমন:
- একেবারে প্রয়োজনীয় না হলে অ্যাপ স্টার্টআপে অবস্থানের অনুমতির অনুরোধ করবেন না।
- যদি আপনার অ্যাপটি Android 10 বা তার পরবর্তী সংস্করণগুলিকে লক্ষ্য করে এবং আপনার কাছে একটি ফোরগ্রাউন্ড পরিষেবা থাকে, তাহলে ম্যানিফেস্টে
"location"-এর একটিforegroundServiceTypeঘোষণা করুন৷ - ব্যাকগ্রাউন্ড অবস্থানের অনুমতির জন্য অনুরোধ করবেন না যদি না আপনার কাছে ব্যবহারকারীর অবস্থানে নিরাপদ এবং আরও স্বচ্ছ অ্যাক্সেসে বর্ণিত একটি বৈধ ব্যবহারের ক্ষেত্রে থাকে৷
অনুমতি না দেওয়া হলে করুণাময় অবক্ষয় সমর্থন করুন
একটি ভাল ব্যবহারকারীর অভিজ্ঞতা বজায় রাখতে, আপনার অ্যাপটি এমনভাবে ডিজাইন করুন যাতে এটি নিম্নোক্ত পরিস্থিতিগুলি সুন্দরভাবে পরিচালনা করতে পারে:
- আপনার অ্যাপের অবস্থানের তথ্যে কোনো অ্যাক্সেস নেই।
- ব্যাকগ্রাউন্ডে চলার সময় আপনার অ্যাপের অবস্থানের তথ্যে অ্যাক্সেস থাকে না।
8. অভিনন্দন
আপনি শিখেছেন কীভাবে Android-এ লোকেশন আপডেট পেতে হয়, সেরা অনুশীলনগুলি মাথায় রেখে!
আরও জানুন
- ব্যাকগ্রাউন্ড লোকেশন ব্যবহার করার জন্য সম্পূর্ণ নমুনা যদি আপনার কাছে বৈধ ব্যবহারের ক্ষেত্রে থাকে
- অবস্থান আপডেট অনুরোধ