Я просто пытаюсь сделать простое «учебное» приложение, чтобы узнать местоположение моего телефона (чтобы узнать, как использовать его позже в каком-то другом приложении), но я просто ничего не получаю.
Что я наделал
Руководство для разработчиков Android. Прежде всего, я следовал инструкциям на сайте разработчиков Android (developer.android.com/training/location/receive-location-updates.html).
Как указано там, я использовал Location, LocationClient и LocationRequest, инициализируя их (и настраивая) в onCreate. LocationClient подключается и отключается в onStart и onStop.
Я запрашиваю обновление местоположения после подключения (в onConnected). Я проверяю, доступны ли сервисы GooglePlayServices, прежде чем сделать этот вызов, и я все еще не получаю никаких обновлений в «onLocationChanged».
GoogleApiClient: я заметил, что LocationClient устарел, а LocationServices предпочтительнее (developer.android.com/reference/com/google/android/gms/location/LocationClient.html).
Как указано здесь: https://developer.android.com/reference/com/google/android/gms/location/FusedLocationProviderApi.html, я использую GoogleApiClient и устанавливаю для него LocationServices (также https://stackoverflow.com/a/25013850/).3802589). Итак, я настроил все это, чтобы использовать это, но все равно не получаю никаких обновлений о местоположении.
onLocationChanged он должен печатать, если есть ответ. Я также поставил кнопку, которая печатает местоположение или «ничего».
Примечания
Я проверил с помощью Google Maps, может быть, у меня что-то не так, но все работает нормально.
Проект
build.gradle
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.google.android.gms:play-services:5.0.77'
compile "com.android.support:support-v4:20.0.+"
}
Манифест
...
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
...
<meta-data android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
...
Код
public class MyActivity extends Activity implements
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener,
LocationListener {
private GoogleApiClient mLocationClient;
private Location mCurrentLocation;
LocationRequest mLocationRequest;
...
/* Constant fields - request interval */
...
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);
mLocationClient = new GoogleApiClient.Builder(getApplicationContext())
.addApi(LocationServices.API)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
mLocationRequest = new LocationRequest();
mLocationRequest.setInterval(UPDATE_INTERVAL);
mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
mLocationRequest.setFastestInterval(FASTEST_INTERVAL);
}
@Override
protected void onStart() {
super.onStart();
mLocationClient.connect();
}
@Override
protected void onStop() {
super.onStop();
LocationServices.FusedLocationApi.removeLocationUpdates(mLocationClient, this);
mLocationClient.disconnect();
}
public void onClick(View view) {
if (mCurrentLocation != null) {
Log.i("Location", mCurrentLocation.toString());
} else {
Log.i("Location", "nothing");
}
}
@Override
public void onLocationChanged(Location location) {
Log.d("Location Update", "CHANGED");
mCurrentLocation = location;
}
@Override
public void onConnected(Bundle bundle) {
// Display the connection status
Toast.makeText(this, "Connected", Toast.LENGTH_SHORT).show();
if(servicesConnected()) {
LocationServices.FusedLocationApi.requestLocationUpdates(mLocationClient, mLocationRequest, this);
}
}
@Override
public void onConnectionSuspended(int i) {
Toast.makeText(this, "Disconnected. Please re-connect.",
Toast.LENGTH_SHORT).show();
}
бревенчатый кот
8948-8948/example.android.com.test D/Location Updates﹕ Google Play services is available.
8948-8948/example.android.com.test I/Location﹕ nothing
Я чувствую, что могу забыть что-то очень простое... но я просто не вижу этого, и я потратил слишком много времени, пытаясь получить простое местоположение...
Возможно, я мог бы просто использовать API android.location, но... Меня беспокоит, что это так сложно (предположительно, проще).