Sonntag, Dezember 15, 2019

Android ‚ s Genaueste Standort-API

Um zu arbeiten, meine app erfordert eine location API.
Ich beabsichtige, verwenden Sie die Mapbox-Plattform, um anzupassen sein design (da Google-Maps
nicht dieses Niveau der Anpassung, soweit ich betroffen bin).

Dokumentation sagt, dass sollten wir nutzen, Google-Play API, wenn Gebäude, Standort
apps:

Den Google Play services location-APIs werden bevorzugt über den Android
Rahmen-Standort-APIs (android.Lage) als Zugabe
location awareness für Ihre app. Wenn Sie derzeit mit der Android
Rahmen-Standort-APIs, Sie werden dringend empfohlen zu wechseln
Google Play services location-APIs so bald wie möglich.

Meine Frage ist:
Ist Google Play API, das die meisten effizienten API, wenn es um GPS-Genauigkeit?
Oder sollte ich das LocationManager und LocationListener Weg, es zu tun?

Brauche ich Genauigkeit. Welche soll ich verwenden?
Danke.

  • also wenn es richtig ist, sondern entleert den Akku sind Sie ok mit, dass?
  • Auf den ersten, ja! Ist das der Grund, warum Sie empfehlen, Google-Play API?
  • Ich denke fusedlocation (aka der google location api) ist so konzipiert, effizienter zu sein in Bezug auf die Verwendung des Akkus und des Netzes. Ich habe nicht gesehen, alle benchmarks, so ist dies alles subjektiv und spekulativ; die Genauigkeit, die ich von fusedlocation ist mehr als genug und ich würde nicht alles versuchen, es sei denn, es führt schrecklich.
  • Wie viel genau in Metern?
  • Ich weiß nicht, wie genau.
  • Fused location nutzt Netzwerk und GPS, um weniger Genauigkeit, aber weniger Stromverbrauch als GPS. Wie genau es ist, hängt von vielen Faktoren ab. GPS-alon mit einer Genauigkeit von etwa 5-10m, aber hängt von Telefon-hardware, Sichtweite, atmosphärische Bedingungen, usw.. Fused location weniger präzise, und haben viele der gleichen Bedingungen. Netzwerk zuletzt, um innerhalb von sagen wir 200m aber fast kein Strom. Beide Verschmolzen und Netzwerk-Netzwerkverbindungen benötigen, obwohl (GPS nicht).

InformationsquelleAutor AndroidDev | 2016-07-25

5 Kommentare

  1. 11

    In android auch gibt es drei Arten von Ort :

    1. GPS_PROVIDER
    2. NETWORK_PROVIDER
    3. PASSIVE_PROVIDER

    So, wie pro meine coding-Erfahrung kam ich zu wissen, dass, wenn Sie verwenden :

    locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 5000, 10, new MyLocationListener());

    erhalten Sie Präzision bis zu 14+ Nachkommastellen.

    Aber wenn Sie fusion von Ihnen wie diese :

    LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, mLocationRequest, my_google_listener);

    erhalten Sie Präzision bis zu 6 bis 7 Dezimalstellen. probieren Sie es aus !!! Referenz

    Aber beachten Sie einige Dinge hier, GPS-Anbieter nimmt sich Zeit, um fetch Lage während Google Standort viel schneller als es ruft Daten von API-Aufruf, um seine google-server-Datenbank.

    GPS funktioniert offline, während die google-provider wird die Position über Mobilfunk oder wifi-Daten.

    • Aber – tut Dezimalstelle zählen, korrelieren die tatsächlichen Standort-Genauigkeit? Meine Vermutung wäre Nein.
    • ^ Ja! dezimale Zählung beeinflusst die Genauigkeit der Position. Genauere Koordinaten bedeuten mehr die genaue Lage.
    • Nicht mehr genauen Koordinaten bedeutet nicht mehr genau, es bedeutet nur mehr Nachkommastellen. Die Anzahl der Dezimalstellen eingestellt werden sollte, nach Genauigkeit, jedoch sehe ich keine Fakten hier, die angeben, dass ist so.
    • was ist my_google_listener in deinem code?
  2. 1

    Sollten Sie verwenden LocationManager für die Richtigkeit.
    Auch Sie können diese Klasse verwenden.

    //GPSTracker.java
    import android.app.AlertDialog;
    import android.app.Service;
    import android.content.Context;
    import android.content.DialogInterface;
    import android.content.Intent;
    import android.location.Location;
    import android.location.LocationListener;
    import android.location.LocationManager;
    import android.os.Bundle;
    import android.os.IBinder;
    import android.provider.Settings;
    import android.util.Log;
    
    public class GPSTracker extends Service implements LocationListener {
    
    private final Context mContext;
    
    //flag for GPS status
    boolean isGPSEnabled = false;
    
    //flag for network status
    boolean isNetworkEnabled = false;
    
    //flag for GPS status
    boolean canGetLocation = false;
    
    Location location; //location
    double latitude; //latitude
    double longitude; //longitude
    float bearing; //bearing
    
    //The minimum distance to change Updates in meters
    private static final long MIN_DISTANCE_CHANGE_FOR_UPDATES = 10; //10 meters
    
    //The minimum time between updates in milliseconds
    private static final long MIN_TIME_BW_UPDATES = 1000 * 60 * 1; //1 minute
    
    //Declaring a Location Manager
    protected LocationManager locationManager;
    
    public GPSTracker(Context context) {
        this.mContext = context;
        getLocation();
    }
    
    public Location getLocation() {
        try {
            locationManager = (LocationManager) mContext
                    .getSystemService(LOCATION_SERVICE);
    
            //getting GPS status
            isGPSEnabled = locationManager
                    .isProviderEnabled(LocationManager.GPS_PROVIDER);
    
            //getting network status
            isNetworkEnabled = locationManager
                    .isProviderEnabled(LocationManager.NETWORK_PROVIDER);
    
            if (!isGPSEnabled && !isNetworkEnabled) {
                //no network provider is enabled
            } else {
                this.canGetLocation = true;
                if (isNetworkEnabled) {
                    locationManager.requestLocationUpdates(
                            LocationManager.NETWORK_PROVIDER,
                            MIN_TIME_BW_UPDATES,
                            MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                    Log.d("Network", "Network");
                    if (locationManager != null) {
                        location = locationManager
                                .getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
                        if (location != null) {
                            latitude = location.getLatitude();
                            longitude = location.getLongitude();
                            bearing = location.getBearing();
                        }
                    }
                }
                //if GPS Enabled get lat/long using GPS Services
                if (isGPSEnabled) {
                    if (location == null) {
                        locationManager.requestLocationUpdates(
                                LocationManager.GPS_PROVIDER,
                                MIN_TIME_BW_UPDATES,
                                MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                        Log.d("GPS Enabled", "GPS Enabled");
                        if (locationManager != null) {
                            location = locationManager
                                    .getLastKnownLocation(LocationManager.GPS_PROVIDER);
                            if (location != null) {
                                latitude = location.getLatitude();
                                longitude = location.getLongitude();
                                bearing = location.getBearing();
                            }
                        }
                    }
                }
            }
    
        } catch (Exception e) {
            e.printStackTrace();
        }
    
        return location;
    }
    
    /**
     * Stop using GPS listener
     * Calling this function will stop using GPS in your app
     * */
    public void stopUsingGPS(){
        if(locationManager != null){
            locationManager.removeUpdates(GPSTracker.this);
        }
    }
    
    /**
     * Function to get latitude
     * */
    public double getLatitude(){
        if(location != null){
            latitude = location.getLatitude();
        }
    
        //return latitude
        return latitude;
    }
    
    /**
     * Function to get longitude
     * */
    public double getLongitude(){
        if(location != null){
            longitude = location.getLongitude();
        }
    
        //return longitude
        return longitude;
    }
    
    public float getBearing() {
        if (location != null) {
            bearing = location.getBearing();
        }
        return bearing;
    }
    
    /**
     * Function to check GPS/wifi enabled
     * @return boolean
     * */
    public boolean canGetLocation() {
        return this.canGetLocation;
    }
    
    /**
     * Function to show settings alert dialog
     * On pressing Settings button will lauch Settings Options
     * */
    public void showSettingsAlert(){
        AlertDialog.Builder alertDialog = new AlertDialog.Builder(mContext);
    
        //Setting Dialog Title
        alertDialog.setTitle("GPS is settings");
    
        //Setting Dialog Message
        alertDialog.setMessage("GPS is not enabled. Do you want to go to settings menu?");
    
        //On pressing Settings button
        alertDialog.setPositiveButton("Settings", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog,int which) {
                Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
                mContext.startActivity(intent);
            }
        });
    
        //on pressing cancel button
        alertDialog.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int which) {
                dialog.cancel();
            }
        });
    
        //Showing Alert Message
        alertDialog.show();
    }
    
    @Override
    public void onLocationChanged(Location location) {
    }
    
    @Override
    public void onProviderDisabled(String provider) {
    }
    
    @Override
    public void onProviderEnabled(String provider) {
    }
    
    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {
    }
    
    @Override
    public IBinder onBind(Intent arg0) {
        return null;
    }
    
    }
    
    //MainActivity.java
    GPSTracker gps = new GPSTracker(MainActivity.this);
  3. 0

    In meiner Erfahrung, die Dienste von Google Location API sind vorzugsweise zur Verwendung in folgenden Aspekten:

    • beschäftigen Sie sich mit Benutzer-Einstellungen, die Auswahl der besten verfügbaren location provider. Wenn Sie wählen, um mit zu arbeiten LocationManager direkt im code behandeln muss, die.
    • Sie könnten erwarten to get eine bessere Lage, mit weniger Stromverbrauch, da Google regelmäßig updates Ihrer algorithmen für die Bestimmung der Lage mithilfe von WiFi, Mobilfunkmasten, etc.

    Meiner Erfahrung mit Google-Dienste, den Standort mit einer Genauigkeit, die ausreichend für eine mapping-Anwendung (die einige zehn Meter) in vielen Fällen nicht die benötigen GPS-Daten. Das könnte auch der Fall sein mit FusedLocationProvider, obwohl, vielleicht mit einer Ausnahme für die Verwendung des Akkus zahlen.

    Schließen, wenn Sie keine Argumente, NICHT Google-Services nutzen (wie Sie Ziel-ein Land, in dem Sie nicht verfügbar sind, oder verteilen möchten, die über alternative Märkte) sollten Sie Ihre Location API.

Kostenlose Online-Tests

Ihre Entwicklerrolle