Android पर उपयोगकर्ता स्थान
Android पर उपयोगकर्ता का स्थान प्राप्त करना iOS पर थोड़ा कम सीधा है। भ्रम शुरू करने के लिए, दो अलग-अलग तरीके हैं जो आप कर सकते हैं। पहला Android APIs का उपयोग कर रहा है android.location.LocationListener
, और दूसरा Google Play Services API का उपयोग कर रहा है com.google.android.gms.location.LocationListener
। चलो दोनों के माध्यम से जाना।
Android का स्थान API
Android का स्थान API स्थान पाने के लिए तीन अलग-अलग प्रदाताओं का उपयोग करता है -
LocationManager.GPS_PROVIDER
- यह प्रदाता उपग्रहों का उपयोग करके स्थान निर्धारित करता है। शर्तों के आधार पर, स्थान तय करने के लिए इस प्रदाता को कुछ समय लग सकता है।
LocationManager.NETWORK_PROVIDER
- यह प्रदाता सेल टॉवर और वाईफाई पहुंच बिंदुओं की उपलब्धता के आधार पर स्थान निर्धारित करता है। परिणाम नेटवर्क लुकअप के माध्यम से प्राप्त होते हैं।
LocationManager.PASSIVE_PROVIDER
- यह प्रदाता अन्य प्रदाताओं द्वारा उत्पन्न स्थानों को लौटाएगा। जब आप अन्य एप्लिकेशन या सेवाएं वास्तव में स्वयं स्थानों का अनुरोध किए बिना अनुरोध करते हैं, तो आप स्थान अपडेट प्राप्त करते हैं।
इसका सार यह है कि आपको LocationManager
सिस्टम से एक ऑब्जेक्ट मिलता है, इसे लागू करना है LocationListener
, और इस requestLocationUpdates
पर कॉल करना है LocationManager
।
यहाँ एक कोड स्निपेट है:
LocationManager locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
// Define a listener that responds to location updates
LocationListener locationListener = new LocationListener() {
public void onLocationChanged(Location location) {
// Called when a new location is found by the network location provider.
makeUseOfNewLocation(location);
}
public void onStatusChanged(String provider, int status, Bundle extras) {}
public void onProviderEnabled(String provider) {}
public void onProviderDisabled(String provider) {}
};
// Register the listener with the Location Manager to receive location updates
locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, locationListener);
स्थान रणनीतियों पर Google का एपीआई गाइडबहुत अच्छी तरह से कोड बताते हैं। लेकिन वे यह भी उल्लेख करते हैं कि ज्यादातर मामलों में, आपको Google स्थान सेवा API का उपयोग करके बेहतर बैटरी प्रदर्शन, साथ ही अधिक उपयुक्त सटीकता प्राप्त होगी । अब भ्रम शुरू होता है!
- Google का स्थान सेवाएँ API
Google का स्थान सेवाएँ API Google Play Services APK का एक हिस्सा है ( यहाँ इसे कैसे सेट किया जाए )। वे Android के API के ऊपर बने हैं। ये एपीआई उपर्युक्त प्रदाताओं के बजाय "फ्यूज्ड लोकेशन प्रोवाइडर" प्रदान करते हैं। यह प्रदाता सटीकता, बैटरी उपयोग आदि के आधार पर स्वचालित रूप से किस अंतर्निहित प्रदाता का उपयोग करता है, यह चुनता है क्योंकि यह तेज़ है क्योंकि आपको सिस्टम-वाइड सेवा से स्थान मिलता है जो इसे अपडेट करता रहता है। और आप अधिक उन्नत सुविधाओं का उपयोग कर सकते हैं जैसे कि जियोफेंसिंग।
Google की स्थान सेवाओं का उपयोग करने के लिए, आपके ऐप को कनेक्ट करना होगा GooglePlayServicesClient
। क्लाइंट से कनेक्ट करने के लिए, आपकी गतिविधि (या टुकड़ा, या तो) को लागू करने GooglePlayServicesClient.ConnectionCallbacks
और GooglePlayServicesClient.OnConnectionFailedListener
इंटरफेस करने की आवश्यकता है । यहाँ एक नमूना कोड है:
public class MyActivity extends Activity implements ConnectionCallbacks, OnConnectionFailedListener {
LocationClient locationClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);
locationClient = new LocationClient(this, this, this);
}
@Override
public void onConnected(Bundle bundle) {
Location location = locationClient.getLastLocation() ;
Toast.makeText(this, "Connected to Google Play Services", Toast.LENGTH_SHORT).show();
}
@Override
public void onDisconnected() {
Toast.makeText(this, "Connected from Google Play Services.", Toast.LENGTH_SHORT).show();
}
@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
// code to handle failed connection
// this code can be found here — http://developer.android.com/training/location/retrieve-current.html
}
locationClient.getLastLocation()
अशक्त क्यों है ?
locationClient.getLastLocation()
ग्राहक से अंतिम ज्ञात स्थान हो जाता है। हालाँकि, फ़्यूस्ड स्थान प्रदाता केवल पृष्ठभूमि स्थान बनाए रखेगा यदि कम से कम एक क्लाइंट इससे जुड़ा हो। एक बार जब पहला ग्राहक जुड़ जाता है, तो यह तुरंत एक स्थान पाने की कोशिश करेगा। अपनी गतिविधि पहले ग्राहक कनेक्ट करने के लिए है और आप कहते हैं तो getLastLocation()
सही में दूर onConnected()
, कि काफी समय पहले स्थान में आने के लिए नहीं हो सकता है। इस में परिणाम होगा location
जा रहा है null
।
इस समस्या को हल करने के लिए, आपको (अनिश्चित काल तक) इंतजार करना होगा जब तक कि प्रदाता को स्थान न मिल जाए और फिर कॉल करें getLastLocation()
, जिसे जानना असंभव है। एक और (बेहतर) विकल्प com.google.android.gms.location.LocationListener
आवधिक स्थान अपडेट प्राप्त करने के लिए इंटरफ़ेस को लागू करना है (और पहला अपडेट प्राप्त करने के बाद इसे बंद कर दें)।
public class MyActivity extends Activity implements ConnectionCallbacks, OnConnectionFailedListener, LocationListener {
// . . . . . . . . more stuff here
LocationRequest locationRequest;
LocationClient locationClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
// . . . . other initialization code
locationClient = new LocationClient(this, this, this);
locationRequest = new LocationRequest();
// Use high accuracy
locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
// Set the update interval to 5 seconds
locationRequest.setInterval(UPDATE_INTERVAL);
// Set the fastest update interval to 1 second
locationRequest.setFastestInterval(FASTEST_INTERVAL);
}
// . . . . . . . . other methods
@Override
public void onConnected(Bundle bundle) {
Location location = locationClient.getLastLocation();
if (location == null)
locationClient.requestLocationUpdates(locationRequest, this);
else
Toast.makeText(getActivity(), "Location: " + location.getLatitude() + ", " + location.getLongitude(), Toast.LENGTH_SHORT).show();
}
// . . . . . . . . other methods
@Override
public void onLocationChanged(Location location) {
locationClient.removeLocationUpdates(this);
// Use the location here!!!
}
इस कोड में, यदि ग्राहक पहले से ही अंतिम स्थान (में onConnected
) है , तो आप जाँच कर रहे हैं । यदि नहीं, तो आप onLocationChanged()
जैसे ही स्थान अपडेट के लिए अनुरोध कर रहे हैं, और जैसे ही आपको अपडेट प्राप्त होता है, अनुरोध ( कॉलबैक में) स्विच करना ।
ध्यान दें कि कॉलबैक के locationClient.requestLocationUpdates(locationRequest, this);
अंदर रहना होगा onConnected
, या फिर आपको IllegalStateException
इसलिए मिलेगा क्योंकि आप Google Play Services क्लाइंट से कनेक्ट किए बिना स्थानों के लिए अनुरोध करने का प्रयास करेंगे।
- उपयोगकर्ता ने स्थान सेवाएँ अक्षम कर दी हैं
कई बार, उपयोगकर्ता स्थान सेवाओं को निष्क्रिय कर दिया जाएगा (बैटरी, या गोपनीयता कारणों को बचाने के लिए)। ऐसे मामले में, उपरोक्त कोड अभी भी स्थान अपडेट के लिए अनुरोध onLocationChanged
करेगा , लेकिन कभी भी कॉल नहीं किया जाएगा। यदि उपयोगकर्ता ने स्थान सेवाओं को अक्षम कर दिया है, तो आप जाँच करके अनुरोधों को रोक सकते हैं।
यदि आपके ऐप को उन्हें स्थान सेवाएं सक्षम करने की आवश्यकता है, तो आप एक संदेश या एक टोस्ट दिखाना चाहेंगे। दुर्भाग्य से, यह जांचने का कोई तरीका नहीं है कि क्या उपयोगकर्ता ने Google के स्थान सेवा एपीआई में स्थान सेवाओं को अक्षम कर दिया है। इसके लिए आपको Android के API का सहारा लेना होगा।
आपकी onCreate
विधि में:
LocationManager manager = (LocationManager) getActivity().getSystemService(Context.LOCATION_SERVICE);
if (!manager.isProviderEnabled(LocationManager.GPS_PROVIDER) && !manager.isProviderEnabled(LocationManager.NETWORK_PROVIDER)) {
locationEnabled = false;
Toast.makeText(getActivity(), "Enable location services for accurate data", Toast.LENGTH_SHORT).show();
}
else locationEnabled = true;
और locationEnabled
अपनी onConnected
विधि में ध्वज का उपयोग इस प्रकार करें:
if (location != null) {
Toast.makeText(getActivity(), "Location: " + location.getLatitude() + ", " + location.getLongitude(), Toast.LENGTH_SHORT).show();
}
else if (location == null && locationEnabled) {
locationClient.requestLocationUpdates(locationRequest, this);
}
अपडेट करें
दस्तावेज़ अपडेट किया गया है, LocationClient हटा दिया गया है और एपीआई संवाद से एक क्लिक के साथ जीपीएस को सक्षम करने का समर्थन करता है:
task.addOnSuccessListener(this, new OnSuccessListener<LocationSettingsResponse>() {
@Override
public void onSuccess(LocationSettingsResponse locationSettingsResponse) {
// All location settings are satisfied. The client can initialize
// location requests here.
// ...
}
});
task.addOnFailureListener(this, new OnFailureListener() {
@Override
public void onFailure(@NonNull Exception e) {
if (e instanceof ResolvableApiException) {
// Location settings are not satisfied, but this can be fixed
// by showing the user a dialog.
try {
// Show the dialog by calling startResolutionForResult(),
// and check the result in onActivityResult().
ResolvableApiException resolvable = (ResolvableApiException) e;
resolvable.startResolutionForResult(MainActivity.this,
REQUEST_CHECK_SETTINGS);
} catch (IntentSender.SendIntentException sendEx) {
// Ignore the error.
}
}
}
});
लिंक https://developer.android.com/training/location/change-location-settings#prompt
नया स्थान क्लाइंट: FusedLocationProviderClient
private FusedLocationProviderClient fusedLocationClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
fusedLocationClient = LocationServices.getFusedLocationProviderClient(this);
}
किसी भी स्थान कार्य को करने से पहले https://developer.android.com/training/location से गुजरने की सलाह दी जाती है।