2014-12-10 3 views
0

Я создал концептуальное приложение, которое захватывает три местоположения и отображает их на карте google: Моя школа, мой дом и мое текущее местоположение.Андроид текущее местоположение приводит к сбою приложения

Приложение, используемое для работы, но теперь оно сбой, когда я прошу его вытащить текущее местоположение. Я не внес изменений в приложение на прошлой неделе, но теперь он не будет работать должным образом. Как ни странно, он все равно потянет мою школу и дом.

import android.app.Activity; 
import android.content.Context; 
import android.location.Criteria; 
import android.location.Location; 
import android.location.LocationManager; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.location.Location; 
import com.google.android.gms.location.LocationListener; 
import com.google.android.gms.maps.CameraUpdate; 
import com.google.android.gms.maps.CameraUpdateFactory; 
import com.google.android.gms.maps.GoogleMap; 
import com.google.android.gms.maps.MapFragment; 
import com.google.android.gms.maps.model.LatLng; 
import com.google.android.gms.maps.model.MarkerOptions; 




//Loosely based on an App tutorial from Youtube by ram goud. 

public class MapActivity extends Activity implements android.location.LocationListener { 

    private final LatLng LOCATION_HOME = new LatLng(45.310488, -93.536989); 
    private final LatLng LOCATION_SCHOOL = new LatLng(44.972586, -93.283689); 
    protected LocationManager locationManager; 
    protected LocationListener locationListener; 
    protected boolean gps_enabled, network_enabled; 
    Button homeButton; 
    Button schoolButton; 
    Button currentLocation; 
    private double lat; 
    private double lng; 
    private final LatLng LOCATION_CURRENT = null; 

    private GoogleMap map; 






    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_map); 



     map =((MapFragment) getFragmentManager().findFragmentById(R.id.map)).getMap(); 
     map.setMyLocationEnabled(true); 
     map.getUiSettings().setRotateGesturesEnabled(false); //I dislike this feature. That is why it has been removed. 

//  Criteria criteria = new Criteria(); 
//  String provider = locationManager.getBestProvider(criteria, gps_enabled); 
//  final Location myLocation = locationManager.getLastKnownLocation(provider); 

     locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); 
     locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, this); 


     homeButton = (Button)findViewById(R.id.home_button); 
     homeButton.setOnClickListener(new View.OnClickListener(){ 

      @Override 
      public void onClick(View v) { 
       map.setMapType(GoogleMap.MAP_TYPE_TERRAIN); //MAP_TYPE_TERRAIN sets the map displayed as just a normal Google Map image. 
       CameraUpdate update = CameraUpdateFactory.newLatLngZoom(LOCATION_HOME, 14); // newLatLngZoom is for zooming. the # represents the distance. 21 furthest & 1 being closest. 
       map.animateCamera(update); 
       map.addMarker(new MarkerOptions().position(LOCATION_HOME).title("Hello, Home")); 
      } 

     }); 
     schoolButton = (Button)findViewById(R.id.school_button); 
     schoolButton.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View v) { 
       map.setMapType(GoogleMap.MAP_TYPE_SATELLITE); //MAP_TYPE_SATELLITE sets the map displayed as a sat image 
       CameraUpdate update = CameraUpdateFactory.newLatLngZoom(LOCATION_SCHOOL, 16); // newLatLngZoom is for zooming. the # represents the distance. 21 furthest & 1 being closest. 
       map.addMarker(new MarkerOptions().position(LOCATION_SCHOOL).title("Hello, School")); 
       map.animateCamera(update); 

      } 
     }); 

     currentLocation = (Button)findViewById(R.id.current); 
     currentLocation.setOnClickListener(new View.OnClickListener() { 

      @Override 
      public void onClick(View v) { 
       GoToCurrent(); 

       } 


     }); 


    } 

    private void GoToCurrent() { //Method created to find current lat/long of user. 
     LocationManager locationManager = (LocationManager) getSystemService(LOCATION_SERVICE); 
     map.setMapType(GoogleMap.MAP_TYPE_HYBRID); 
     Criteria criteria = new Criteria(); 
     String provider = locationManager.getBestProvider(criteria, gps_enabled); 
     Location myLocation = locationManager.getLastKnownLocation(provider); 

     double lati = myLocation.getLatitude(); 
     double longi = myLocation.getLongitude(); 
     LatLng latlng = new LatLng(lati, longi); 
     map.moveCamera(CameraUpdateFactory.newLatLng(latlng)); 
     map.animateCamera(CameraUpdateFactory.zoomTo(20)); 
     map.addMarker(new MarkerOptions().position(new LatLng(lati, longi)).title("You are here")); 
    } 


    @Override 
    public void onLocationChanged(Location location) { 


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

    } 

    @Override 
    public void onProviderEnabled(String provider) { 
     // TODO Auto-generated method stub 

    } 

    @Override 
    public void onProviderDisabled(String provider) { 
     // TODO Auto-generated method stub 

    } 




} 

// Это манифест, если кому-то интересно.

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.example.googlemaps" 
    android:versionCode="1" 
    android:versionName="1.0" > 

    <uses-sdk 
     android:minSdkVersion="11" 
     android:targetSdkVersion="19" /> 



    <uses-permission android:name="com.google.android.gms.version"/> 

    <uses-permission android:name="android.permission.INTERNET"/> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> 
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/> 
    <!-- The following two permissions are not required to use 
     Google Maps Android API v2, but are recommended. --> 
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> 

    <!-- The following two permissions are not required to use Google Maps Android API v2, but are recommended. --> 

    <application 
     android:allowBackup="true" 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" > 
     <activity 
      android:name=".MapActivity" 
      android:label="@string/app_name" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 

     <meta-data 
      android:name="com.google.android.maps.v2.API_KEY" 
      android:value="xxxxxxxxxxxxxxxxxxxxxx-xxxxxxxx" /> <!-- API key --> 
       <meta-data 
       android:name="com.google.android.gms.version" 
      android:value="@integer/google_play_services_version"/> 
    </application> 

</manifest> 
+0

Не могли бы вы добавить трассировку стека? –

ответ

0

Вы должны проверить, если значение Вас MyLocation переменная равна нулю или нет перед вызовом каких-либо методов на нем

Location myLocation = locationManager.getLastKnownLocation(provider); 

, если вы посмотрите на документацию, нашел here

вы будете см., что эта функция может возвратить значение

общественное местоположение getLastKnownLocation (String провайдер) Добавлено в API level 1

Возвращает местоположение с указанием данных из последнего известного местоположения исправления, полученного от данного провайдера.

Это можно сделать без запуска провайдера. Обратите внимание, что это местоположение может быть устаревшим, например, если устройство было выключено и переместилось в другое место.

Если провайдер отключен, возвращается null. Параметры поставщик имя поставщика Возвращает

the last known location for the provider, or **null** 

Броски SecurityException, если нет подходящего разрешения не присутствует IllegalArgumentException, если поставщик является нулевым или не существует

-1

Так как ни странно, это работает не. В код не были внесены изменения. Это просто ... работает!

+0

Причина, по которой это работает, заключается в том, что getLastKnownLocation (поставщик) только иногда возвращает null. Если вы посмотрите на документ, я разместил выше, вы увидите, что этот метод __can__ возвращает null. Если вы проигнорируете этот факт, то в какой-то момент приложение __will__ выйдет из строя, как раньше. Легко просто сдуть что-то, что, по-видимому, исправило его, но если вы пытаетесь что-то узнать, тогда проверьте нулевое состояние и покажите тост или напечатайте что-нибудь в журнале или что-нибудь, если оно равно null и __don 't__ вызывает любые методы для нулевого объекта. В худшем случае вы никогда не увидите сообщение с тостом/журналом! – nPn

Смежные вопросы