অ্যান্ড্রয়েড লোকেশন বাটন হলো একটি কাস্টমাইজযোগ্য সিস্টেম UI এলিমেন্ট, যা সেশন-ভিত্তিক সুনির্দিষ্ট লোকেশন অ্যাক্সেসের অনুরোধ করার প্রক্রিয়াকে সহজ করার জন্য ডিজাইন করা হয়েছে। ব্যবহারকারীর সরাসরি কার্যকলাপের মাধ্যমে লোকেশনের অনুরোধ শুরু করার ফলে, এই বাটনটি ব্যবহারকারীর গোপনীয়তা উন্নত করে এবং অস্থায়ী "শুধুমাত্র এইবারের জন্য" অনুমতির ক্ষেত্রে সাধারণত যে পুনরাবৃত্তিমূলক অনুমতি ডায়ালগের সম্মুখীন হতে হয়, তার ঝামেলা কমায়।
আপনার অ্যাপটি যদি অ্যান্ড্রয়েড ১৭ (এপিআই লেভেল ৩৭) বা তার পরবর্তী সংস্করণকে টার্গেট করে এবং এতে শুধুমাত্র এমন ফিচার থাকে যেগুলোর কার্যকারিতার জন্য সেশন-ভিত্তিক লোকেশন অ্যাক্সেস প্রয়োজন, তাহলে গুগল প্লে-র নীতি অনুযায়ী আপনাকে লোকেশন বাটন ব্যবহার করতে হবে। আরও বিস্তারিত জানতে, লোকেশন বাটন নীতি দেখুন।

অবস্থান বোতামটি কখন ব্যবহার করবেন
যেসব ফিচারের জন্য ক্ষণস্থায়ী, সেশন-ভিত্তিক সুনির্দিষ্ট লোকেশন অ্যাক্সেসের প্রয়োজন হয়, সেগুলোর জন্য লোকেশন বাটনটি ব্যবহার করুন। এটি সেইসব অ্যাপ্লিকেশনের জন্য আদর্শ, যেগুলোর স্থায়ী লোকেশন অ্যাক্সেসের প্রয়োজন হয় না এবং যা বারবার আসা "শুধু এইবারের জন্য" অনুমতির অনুরোধ কমাতে চায়।
সাধারণ ব্যবহারের ক্ষেত্রগুলোর মধ্যে রয়েছে:
- "আমার কাছাকাছি অনুসন্ধান" ফাংশন: কাছাকাছি হোটেল, দোকান বা রেস্তোরাঁ খুঁজে বের করা।
- অবস্থান শেয়ারিং: বন্ধু বা পরিবারের সাথে আপনার বর্তমান অবস্থান একবার শেয়ার করা।
- সোশ্যাল মিডিয়া: চেক-ইন বা লোকেশন ট্যাগিং।
- ইকমার্স: ডেলিভারির জন্য ঠিকানা স্বয়ংক্রিয়ভাবে পূরণ করা।
UI কাস্টমাইজ করুন
বাটনটি যাতে আপনার অ্যাপের নান্দনিকতার সাথে সামঞ্জস্যপূর্ণ এবং সহজে চেনা যায়, তা নিশ্চিত করতে আপনি নিম্নলিখিত ভিজ্যুয়াল উপাদানগুলো পরিবর্তন করতে পারেন:
- পটভূমি এবং আইকনের রঙের পরিকল্পনা।
- রূপরেখার শৈলী, আকার এবং আকৃতি।
- পূর্বনির্ধারিত তালিকা থেকে টেক্সট লেবেল (যেমন, "সঠিক অবস্থান ব্যবহার করুন", "সঠিক অবস্থান শেয়ার করুন")।

অবস্থান বোতামটি বাস্তবায়ন করুন
লোকেশন বাটনটি যুক্ত করতে জেটপ্যাক লাইব্রেরি ব্যবহার করুন। এই লাইব্রেরিটি সেটআপ সহজ করে, নতুন প্ল্যাটফর্মগুলোতে নিরাপদ রেন্ডারিং পরিচালনা করে এবং অ্যান্ড্রয়েড ১৬ ও তার নিচের সংস্করণগুলোর জন্য তৈরি অ্যাপগুলোর ক্ষেত্রে একটি ফলব্যাক প্রদান করে।
ধাপ ১: অ্যান্ড্রয়েড ম্যানিফেস্টে অনুমতিগুলো ঘোষণা করুন
আপনাকে অবশ্যই স্ট্যান্ডার্ড লোকেশন পারমিশনের পাশাপাশি সিস্টেমের রিমোট রেন্ডারিং সার্ভিসের জন্য প্রয়োজনীয় ডেডিকেটেড USE_LOCATION_BUTTON পারমিশনটিও ঘোষণা করতে হবে।
<?xml version="1.0" encoding="utf-8"?> <!-- Copyright 2026 The Android Open Source Project Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at https://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <manifest xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 1. Standard Coarse and Fine Location Permissions --> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> <!-- Optional: If your app is only using the location button to access location, you should add the "onlyForLocationButton" flag shown below to your ACCESS_FINE_LOCATION declaration. <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" android:usesPermissionFlags="onlyForLocationButton"/> Note: Adding this flag restricts your app from accessing the precise location permission via the broader permission, and that users will be required to use the location button in order to share precise location with the app. This is designed to improve user privacy & trust when granting location access. --> <!-- 2. CRITICAL: Required system permission for rendering the LocationButton --> <uses-permission android:name="android.permission.USE_LOCATION_BUTTON" /> <application android:icon="@mipmap/ic_launcher" android:label="LocationButtonSample" android:theme="@style/Theme.PinPoint"> <activity android:name=".MainActivity" android:exported="true"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
ধাপ ২: কোটলিন কম্পোজেবল বাস্তবায়ন করুন
নিচে লোকেশন বাটনের একটি উদাহরণমূলক বাস্তবায়ন দেওয়া হলো, যেখানে উপলব্ধ কাস্টমাইজেশন অপশনগুলো ব্যবহারের উদাহরণও রয়েছে, যা দিয়ে UI-কে অ্যাপের বাকি অংশের সাথে সামঞ্জস্যপূর্ণ করে তোলা যায়।
import androidx.compose.foundation.layout.PaddingValues import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.width import androidx.compose.runtime.Composable import androidx.compose.ui.graphics.Color import androidx.compose.ui.unit.dp import androidx.core.locationbutton.compose.LocationButton import androidx.core.locationbutton.compose.LocationButtonTextType @Composable fun LocationPermissionScreen(onPermissionGranted: () -> Unit, onPermissionDenied: () -> Unit) { // Renders the secure system-trusted Location Button composable LocationButton( // Callback triggered when the user taps the secure button and makes a decision on the permission dialog onPermissionResult = { isGranted -> if (isGranted) { onPermissionGranted() } else { onPermissionDenied() } }, /* ============================================================================ * VISUAL CUSTOMIZATIONS * Un-comment any of the parameters below to customize the button's aesthetics. * If omitted, the button falls back to secure, high-contrast system defaults. * ============================================================================ */ /* // LABEL TEXT TYPE: // Predefined system strings rendered inside the secure process. // Options: PreciseLocation, UsePreciseLocation, SharePreciseLocation, // NearMyPreciseLocation, or None (for an icon-only button). textType = LocationButtonTextType.UsePreciseLocation, // COLOR PALETTE: // Customize the container background, text label, and icon tint colors. backgroundColor = Color(0xFF00796B), // e.g., Material Teal textColor = Color.White, iconTint = Color(0xFFFFC107), // e.g., Amber icon tint // CORNER RADIUS & SHAPE: // Define the resting corner radius and the morphed radius when pressed. cornerRadius = 24.dp, // Rounded capsule shape pressedCornerRadius = 12.dp, // Morphs to sharper corners on tap // OUTLINE STROKE (BORDERS): // Add a contrasting outline stroke around the button bounds. strokeColor = Color(0xFF004D40), strokeWidth = 2.dp, // INTERACTIVE TOUCH PADDING: // Defines the secure clickable touch target boundary. // Coerced securely by the system between 4.dp and 8.dp. clickablePadding = PaddingValues(6.dp) */ ) }
ধাপ ৩: পূর্ববর্তী সংস্করণের সাথে সামঞ্জস্যতা নিশ্চিত করুন
জেটপ্যাক লাইব্রেরি অ্যান্ড্রয়েডের নিম্ন সংস্করণগুলিতে স্বয়ংক্রিয়ভাবে ব্যাকওয়ার্ড কম্প্যাটিবিলিটি পরিচালনা করে। অ্যান্ড্রয়েড ১৬ বা তার নিম্ন সংস্করণে চালিত ডিভাইসগুলিতে, লাইব্রেরিটি স্থানীয়ভাবে রেন্ডার করা একটি কম্পোনেন্টে ফিরে যায়, যা কাস্টমাইজড ভিজ্যুয়াল লেআউটটি অক্ষুণ্ণ রাখে কিন্তু স্ট্যান্ডার্ড লোকেশন পারমিশন প্রম্পটটি চালু করে।
এই পদ্ধতি ব্যবহার করে, আপনি অ্যান্ড্রয়েড ১৬ বা তার নিম্নতর সংস্করণে চালিত ডিভাইসগুলোর জন্য একটি সমান্তরাল সমাধান রক্ষণাবেক্ষণ না করেই লোকেশন বাটন ব্যবহারের সুবিধাগুলো গ্রহণ করতে পারেন।