web-dev-qa-db-fra.com

Android ne peut pas résoudre la méthode requestLocationUpdates FusedLocationProviderAPI

J'essaie de suivre le didacticiel Android Réception de mises à jour de l'emplacement . L'exemple de code est ici sur Github .

Tout fonctionne sauf la ligne suivante: LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, mLocationRequest, this);

Il génère une erreur cannot resolve method requestLocationUpdates. Je ne vois rien dans la documentation , mais je suis assez nouveau sur Android, il se peut qu'il manque quelque chose :).

Voici le code complet. Des idées où je vais mal? Merci!

package location.test.example.com;

import Android.app.Fragment;
import Android.content.Intent;
import Android.location.Location;
import Android.location.LocationListener;
import Android.os.Bundle;
import Android.support.v4.app.NavUtils;
import Android.text.format.DateFormat;
import Android.util.Log;
import Android.view.ActionMode;
import Android.view.LayoutInflater;
import Android.view.Menu;
import Android.view.MenuInflater;
import Android.view.View;
import Android.view.ViewGroup;
import Android.widget.Button;
import Android.widget.TextView;
import Android.widget.Toast;

import com.google.Android.gms.common.ConnectionResult;
import com.google.Android.gms.common.api.GoogleApiClient;
import com.google.Android.gms.location.LocationRequest;
import com.google.Android.gms.location.LocationServices;

import Java.util.ArrayList;
import Java.util.Date;

public class LocationFragment extends Fragment implements
        GoogleApiClient.ConnectionCallbacks, GoogleApiClient.OnConnectionFailedListener, LocationListener {

    protected GoogleApiClient mGoogleApiClient;
    protected Location mCurrentLocation;
    protected LocationRequest mLocationRequest;
    protected String mLastUpdateTime;

    public static final long UPDATE_INTERVAL_IN_MILLISECONDS = 5000;

    public static final long FASTEST_UPDATE_INTERVAL_IN_MILLISECONDS = UPDATE_INTERVAL_IN_MILLISECONDS / 5;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        mLastUpdateTime = "";

        buildGoogleApiClient();

        if (NavUtils.getParentActivityName(getActivity()) != null) {
            getActivity().getActionBar().setDisplayHomeAsUpEnabled(true);
        }
        setHasOptionsMenu(true);

    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.fragment_location, container, false);    

        return v;
    }

    protected synchronized void buildGoogleApiClient() {
        mGoogleApiClient = new GoogleApiClient.Builder(getActivity())
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .addApi(LocationServices.API)
                .build();
        createLocationRequest();
    }

    protected void createLocationRequest() {
        mLocationRequest = new LocationRequest();

        mLocationRequest.setInterval(UPDATE_INTERVAL_IN_MILLISECONDS);

        mLocationRequest.setFastestInterval(FASTEST_UPDATE_INTERVAL_IN_MILLISECONDS);

        mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
        startLocationUpdates();
    }

    protected void startLocationUpdates() {
        LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, mLocationRequest, this);
    }

    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {

    }

    @Override
    public void onProviderEnabled(String provider) {

    }

    @Override
    public void onProviderDisabled(String provider) {

    }

    @Override
    public void onLocationChanged(Location location) {
        mCurrentLocation = location;
        mLastUpdateTime = DateFormat.getDateFormat(getActivity()).format(new Date());
        Toast.makeText(getActivity(), location.toString() + "", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onConnected(Bundle connectionHint) {

    }

    @Override
    public void onConnectionFailed(ConnectionResult result) {
        Log.i("LocationFragment", "Connection failed: ConnectionResult.getErrorCode() " + result.getErrorCode());
    }

    @Override
    public void onConnectionSuspended(int cause) {
        Log.i("LocationFragment", "Connection suspended");
        mGoogleApiClient.connect();
    }

}
15
Tom Hammond

Vous devez utiliser LocationListener pour LocationServices.FusedLocationApi.requestLocationUpdates's locationListener

ne pas

Android.location.LocationListener

mais 

com.google.Android.gms.location.LocationListener

70
jyasthin

Importation

import com.google.Android.gms.location.LocationListener;

au lieu de

import Android.location.LocationListener;
6
Deepak

Remplacer

import Android.location.LocationListener;

De

import com.google.Android.gms.location.LocationListener;

et supprimer ces méthodes de substitution

public void onStatusChanged(String provider, int status, Bundle extras) {}
@Override
public void onProviderEnabled(String provider) {}
@Override
public void onProviderDisabled(String provider) {}
4
Hamza_Developer

L'importation de Android.location.LocationListener ou com.google.Android.gms.location.LocationListener est inutile car les packages restent inutilisés . L'interface Implement com.google.Android.gms.location.LocationListener fera l'affaire.

0
Akash Srivastava

Au lieu de modifier l'instruction d'importation, Utilisation implémente com.google.Android.gms.location.LocationListener

que simplement LocationListener/Android.location.LocationListener.

Cela a résolu mon problème.

0
Pavani

besoin de la version de mise à jour de google play services 10.0.0+

compile 'com.google.Android.gms:play-services:10.0.0'
0
genocsb