почему onLocationchanged никогда не вызывается - PullRequest
0 голосов
/ 20 октября 2018

Я реализовал способ получения текущего местоположения из Google Maps, и он работал хорошо.

Но он не работает внезапно.

, поэтому я проверил код в прошлом,но все равно не работает.

Я выяснил, какие функции не работали, и заметил, что onLocationChanged () не был вызван.

Я не знаю, в чем проблема, потому что нет сообщения об ошибкеотображается в журнале.

Это соответствующий код.

код во фрагменте с Google Maps

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    previous_marker = new ArrayList<>();
    getActivity().getWindow().setFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON, WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
    final ViewGroup rootView = (ViewGroup) inflater.inflate(R.layout.activity_main, container, false);
    ButterKnife.bind(this, rootView);

    mActivity = getActivity();
    mcontext = getContext();
    Initialize();

    mGoogleApiClient = new GoogleApiClient.Builder(mActivity)
            .enableAutoManage(mActivity, 1, this)
            .addConnectionCallbacks(this)
            .addApi(Places.GEO_DATA_API)
            .addApi(Places.PLACE_DETECTION_API)
            .addApi(LocationServices.API)
            .build();

    mapFragment = (SupportMapFragment) getChildFragmentManager().findFragmentById(R.id.googleMap);
    mapFragment.getMapAsync(this);

    locationRequest = LocationRequest.create();
    locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
    locationRequest.setInterval(UPDATE_INTERVAL_MS);
    locationRequest.setFastestInterval(FASTEST_UPDATE_INTERVAL_MS);

другие коды

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    switch (requestCode) {
        case GPS_ENABLE_REQUEST_CODE:
            if (checkLocationServicesStatus()) {
                if (checkLocationServicesStatus()) {
                    if ( mGoogleApiClient.isConnected() == false ) {
                        Log.d( TAG, "onActivityResult : mGoogleApiClient connect ");
                        mGoogleApiClient.connect();
                    }
                    return;
                }
            }
            break;


 @Override
public void onLocationChanged(Location location) {
    setCurrentLocation(location);
    currentPosition = new LatLng(location.getLatitude(), location.getLongitude());
    saveLat = location.getLatitude();
    saveLng = location.getLongitude();

    chooseLat  = location.getLatitude();
    chooseLng = location.getLongitude();
    district = getDistrict(mcontext, location.getLatitude(), location.getLongitude());
    getToken();
    setDefaultPlace(location.getLatitude(), location.getLongitude());
}

@Override
public void onResume() {
    super.onResume();
    if (mGoogleApiClient.isConnected()) {
        if (!mRequestingLocationUpdates) startLocationUpdates();
    }
    if (askPermissionOnceAgain) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            askPermissionOnceAgain = false;
            checkPermissions();
        }
    }
}

private void startLocationUpdates() {
    if (!checkLocationServicesStatus()) {
        Log.d(TAG, "startLocationUpdates : call showDialogForLocationServiceSetting");
        showDialogForLocationServiceSetting();
    }else {
        if (ActivityCompat.checkSelfPermission(mcontext, android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED
                && ActivityCompat.checkSelfPermission(mcontext, android.Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
            return;
        }
        LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, locationRequest, this);
        mRequestingLocationUpdates = true;
        mGoogleMap.setMyLocationEnabled(false);
    }
}

public boolean checkLocationServicesStatus() {
    locationManager = (LocationManager) mActivity.getSystemService(LOCATION_SERVICE);

    return locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)
            || locationManager.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
}


@Override
public void onStart() {
    if(mGoogleApiClient != null && mGoogleApiClient.isConnected() == false){
        Log.d(TAG, "onStart: mGoogleApiClient connect");
        mGoogleApiClient.connect();
    }
    if(!firstLoad){
        mRequestingLocationUpdates = true;
    }
    super.onStart();
}

@Override
public void onStop() {
    firstLoad = false;
    if (mRequestingLocationUpdates) {
        Log.d(TAG, "onStop : call stopLocationUpdates");
        stopLocationUpdates();
    }
    if ( mGoogleApiClient.isConnected()) {
        Log.d(TAG, "onStop : mGoogleApiClient disconnect");
        mGoogleApiClient.disconnect();
    }
    super.onStop();
}

@Override
public void onConnected(Bundle connectionHint) {
    if ( mRequestingLocationUpdates == false ) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            int hasFineLocationPermission = ContextCompat.checkSelfPermission(mcontext,
                    android.Manifest.permission.ACCESS_FINE_LOCATION);
            if (hasFineLocationPermission == PackageManager.PERMISSION_DENIED) {
                ActivityCompat.requestPermissions(mActivity,
                        new String[]{android.Manifest.permission.ACCESS_FINE_LOCATION},
                        PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION);
            } else {
                Log.d(TAG, "onConnected : call startLocationUpdates");
                startLocationUpdates();
                mGoogleMap.setMyLocationEnabled(true);
            }

        } else {
            Log.d(TAG, "onConnected : call startLocationUpdates");
            startLocationUpdates();
            mGoogleMap.setMyLocationEnabled(true);
        }
    }
}

@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
    setDefaultLocation();
}

@Override
public void onConnectionSuspended(int cause) {
    if (cause == CAUSE_NETWORK_LOST)
        Log.e(TAG, "onConnectionSuspended(): Google Play services " +
                "connection lost.  Cause: network lost.");
    else if (cause == CAUSE_SERVICE_DISCONNECTED)
        Log.e(TAG, "onConnectionSuspended():  Google Play services " +
                "connection lost.  Cause: service disconnected");
}

и это мое разрешение

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

Если вы знаете причину или неправильную часть кода, я был бы признателен, если бы вы дали мне знать.

Спасибо, что прочитали этостатья.Хорошего дня

1 Ответ

0 голосов
/ 20 октября 2018

проверьте эти строки в методе mapready

public void onMapReady(GoogleMap googleMap) {


            mMap = googleMap;

            mMap.setMyLocationEnabled(true);

    // Setting event handler for location change
            mMap.setOnMyLocationChangeListener(this);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...