Получение проблемы при получении местоположения в другом режиме запроса местоположения - PullRequest
0 голосов
/ 10 апреля 2019

Для получения местоположения я использовал GoogleAPIClient с FusedLocationProvider API.

Эти функции в методе onCreate().

 createLocationRequest();
 mGoogleApiClient = new GoogleApiClient.Builder(this)
            .addApi(LocationServices.API)
            .addConnectionCallbacks(this)
            .addOnConnectionFailedListener(this)
            .build();
 gpsChecker();

Полный код

 protected void createLocationRequest() {
    mLocationRequest = new LocationRequest();
    mLocationRequest.setInterval(INTERVAL);
    mLocationRequest.setFastestInterval(FASTEST_INTERVAL);
    mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
}

public void gpsChecker() {
    LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder()
            .addLocationRequest(mLocationRequest);
    builder.setAlwaysShow(true);
    PendingResult<LocationSettingsResult> result =
            LocationServices.SettingsApi.checkLocationSettings(mGoogleApiClient, builder.build());
    result.setResultCallback(new ResultCallback<LocationSettingsResult>() {
        @Override
        public void onResult(LocationSettingsResult result) {
            final Status status = result.getStatus();
            switch (status.getStatusCode()) {
                case LocationSettingsStatusCodes.SUCCESS:
                    // All location settings are satisfied. The client can initialize location
                    // requests here.
                    break;
                case LocationSettingsStatusCodes.RESOLUTION_REQUIRED:
                    // Location settings are not satisfied. But could be fixed by showing the user
                    // a dialog.
                    try {
                        // Show the dialog by calling startResolutionForResult(),
                        // and check the result in onActivityResult().
                        status.startResolutionForResult(
                                AddVisitActivity.this, 1000);
                    } catch (IntentSender.SendIntentException e) {
                        // Ignore the error.
                    }
                    break;
                case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
                    // Location settings are not satisfied. However, we have no way to fix the
                    // settings so we won't show the dialog.
                    break;
            }
        }
    });
}

Для разрешений во время выполнения я сделал это.

  protected void startLocationUpdates() {
    if (ActivityCompat.shouldShowRequestPermissionRationale
            (AddVisitActivity.this, android.Manifest.permission.ACCESS_FINE_LOCATION)) {
        Snackbar.make(findViewById(android.R.id.content),
                "Please Grant Permissions",
                Snackbar.LENGTH_INDEFINITE).setAction("ENABLE",
                new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        if (ActivityCompat.checkSelfPermission(AddVisitActivity.this, android.Manifest.permission.ACCESS_FINE_LOCATION)
                                != PackageManager.PERMISSION_GRANTED) {
                            ActivityCompat.requestPermissions(AddVisitActivity.this,
                                    new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION},
                                    REQUEST_CODE_LOCATION);
                        } else {
                            LocationServices.FusedLocationApi.requestLocationUpdates(
                                    mGoogleApiClient, mLocationRequest, AddVisitActivity.this);
                            Log.d(TAG, "Location update started ...: ");
                        }
                    }
                }).show();
    } else {

        if (ActivityCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_FINE_LOCATION)
                != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(this,
                    new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION},
                    REQUEST_CODE_LOCATION);
        } else {
            LocationServices.FusedLocationApi.requestLocationUpdates(
                    mGoogleApiClient, mLocationRequest, this);
            Log.d(TAG, "Location update started ...: ");
        }
    }

}

Для проверки, включен ли GPS на экране настроек или нет, с помощью gpsChecker () с кодом запроса 1000 и в onActivityResult () я сделал это.

 if (requestCode == 1000) {
        switch (resultCode) {
            case Activity.RESULT_OK:
                Log.i(TAG, "User agreed to make required location settings changes.");
                startLocationUpdates();
                break;
            case Activity.RESULT_CANCELED:
                Log.i(TAG, "User chose not to make required location settings changes.");
                finish();
                break;
        }
    }

Хотя я выполняю этот код на некоторых устройствах, он работает, а на некоторых устройствах запрос местоположения автоматическиустановить Только для устройства или Экономия батареи , хотя я установил mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);

Примечание: Mi Note 4, Vivo V9 Pro, Mi Note5 Pro и какое-то другое устройство получает проблему

Так что мне нужно изменить в моем коде, чтобы он работал должным образом с высокой точностью?

Ответы [ 2 ]

2 голосов
/ 10 апреля 2019

Окончательно решено путем изменения

mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);

до

mLocationRequest.setPriority(LocationRequest.PRIORITY_BALANCED_POWER_ACCURACY);

и изменить

private static final long INTERVAL = 1000 * 60 * 60;
private static final long FASTEST_INTERVAL = 1000 * 5;

интервал времени до 30 минут и самый быстрый интервал до 5 секунд означает, что один раз получить местоположение через 5 секунд, после чего новое местоположение будет получено через 30 минут.

0 голосов
/ 10 апреля 2019

Попробуйте это решение с провайдером GPS и убедитесь, что ваша служба GPS включена.

static final int LOCATION_INTERVAL = 1000;static final float LOCATION_DISTANCE = 10f;

// поместить это в onCreate ();LocationManager locationManager = (LocationManager) this.getSystemService (Context.LOCATION_SERVICE);

    Criteria criteria = new Criteria();

    mprovider = locationManager.getBestProvider(criteria, false);

    if (mprovider != null && !mprovider.equals("")) {
        if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
            return;
        }
        Location location = locationManager.getLastKnownLocation(mprovider);
        locationManager.requestLocationUpdates(mprovider, LOCATION_INTERVAL, LOCATION_DISTANCE, this);

        if (location != null)
            onLocationChanged(location);
        else
            Toast.makeText(getBaseContext(), "No Location Provider Found Check Your Code", Toast.LENGTH_SHORT).show();
    }

    //put this LocationListener after onCreate();
    public LocationListener mLocationListener = new LocationListener() {

    @Override
    public void onLocationChanged(Location location) {
        if (location != null) {
            Log.e(String.format("%f, %f", location.getLatitude(), location.getLongitude()), "");
            Log.e("Location available", "Location available");
            locationManager.removeUpdates(mLocationListener);
        } else {
            Log.e("Location is null", "Location is null");
        }

        current_latitude = location.getLatitude();
        current_longitude = location.getLongitude();

       /* LatLng latLng = new LatLng(current_latitude, current_longitude);
        points.add(latLng);
        redrawLine();*/

        Log.e("current_latitude", String.valueOf(current_latitude));
        Log.e("current_longitude", String.valueOf(current_longitude));

        if (location.hasSpeed()) {
            //progressBarCircularIndeterminate.setVisibility(View.GONE);
            String speed = String.format(Locale.ENGLISH, "%.0f", location.getSpeed() * 3.6) + "km/h";

            SpannableString s = new SpannableString(speed);
            s.setSpan(new RelativeSizeSpan(0.25f), s.length() - 4, s.length(), 0);
            txt_current_speed.setText(s);
        }

    }

    @Override
    public void onStatusChanged(String s, int i, Bundle bundle) {

    }

    @Override
    public void onProviderEnabled(String s) {

    }

    @Override
    public void onProviderDisabled(String s) {

    }
};
...