2016-02-12 55 views
1

我有一個EditText,其中輸入位置,當按鈕被點擊時,發佈名稱被捆綁並通過意圖發送到詳細信息活動,其中它接收位置名稱並獲取緯度和經度使用Geocoder.But時,我試圖在地圖上顯示它,不幸的是我得到一個RunTimeException.Below是code.Is正確的方式來獲取一個地方的經緯度,請幫助我。我是Google地圖的新手。android從輸入位置獲取緯度和經度

MainActivity.java:

public class MainActivity extends AppCompatActivity { 
    AutoCompleteTextView textView; 
     ArrayAdapter<String> arrayAdapter; 
     @Override 
     protected void onCreate(Bundle savedInstanceState) { 
      super.onCreate(savedInstanceState); 
      setContentView(R.layout.activity_main); 
      Log.e("MainActivity:","Started"); 
      List l = new ArrayList(); 
      l.add("New Delhi"); 
      l.add("Mumbai"); 
      l.add("Chennai"); 
      l.add("Bangalore"); 
      Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
      setSupportActionBar(toolbar); 
      getSupportActionBar().setTitle("Destination"); 

      AutoCompleteTextView textView = (AutoCompleteTextView) findViewById(R.id.autocomplete); 
      arrayAdapter=new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,l); 
      textView.setAdapter(arrayAdapter); 
      final Bundle bundle =new Bundle(); 
      bundle.putString("places",textView.getText().toString()); 


      Button button1 = (Button) findViewById(R.id.enter); 
      button1.setOnClickListener(new View.OnClickListener() { 
       @Override 
       public void onClick(View v) { 
        Intent intent = new Intent(getApplicationContext(),  Details.class); 
        intent.putExtras(bundle); 
        startActivity(intent); 
       } 
      }); 

     }} 

Details.java:(Map不包括在內,在AddressList中的錯誤它得到從地理編碼位置的詳情)

public class Details extends AppCompatActivity { 
SupportMapFragment mapFragment;LatLng latLng;ArrayList<LatLng> markerPoints;LatLng from,to;Polyline polyline;ArrayList<Polyline> polylines; 
    private GoogleMap map;LocationManager manager;Double lat,longt;Location location; 
    // The minimum distance to change Updates in meters 
    private static final long MIN_DISTANCE_CHANGE_FOR_UPDATES = 10; // 10 meters 

    // The minimum time between updates in milliseconds 
    private static final long MIN_TIME_BW_UPDATES = 1000 * 60 * 1; // 1 minute 
    boolean isGPSEnabled = false; 

    // flag for network status 
    boolean isNetworkEnabled = false; 

    boolean canGetLocation = false; 
    List<LatLng> latLngslist; 
    Marker marker;int i;String cityName,destination; 
    int start; ArrayList<LatLng> wapt;Routing routing; 
    Geocoder geocoder;int counter=0; 
    List<Address> wayptdetails; 
    String destinationname; 
    double destinationLatitude; 
    double destinationLongitude; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.details); 
     mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map1); 
     mapFragment.getMapAsync(this); 
     getLocation(); 
     wapt=new ArrayList<LatLng>(); 
     wayptdetails=new ArrayList<Address>(); 
     Bundle bundle= getIntent().getExtras(); 
     destination= bundle.getString("place"); 
     Geocoder geocoder1=new Geocoder(this,Locale.getDefault()); 
     try { 

      List<Address>  addressList=geocoder1.getFromLocationName(destination,1); 
      destinationLatitude= addressList.get(0).getLatitude(); 
      destinationLongitude=addressList.get(0).getLongitude(); 
     Log.e("Destination","Location retreived"); 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 
    }} 

錯誤:

02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime: FATAL EXCEPTION: main 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.jobinsabu.destination/com.example.jobinsabu.destination.Details}: java.lang.IllegalArgumentException: locationName == null 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2252) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2306) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.access$700(ActivityThread.java:153) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1286) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Looper.loop(Looper.java:176) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.main(ActivityThread.java:5302) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invokeNative(Native Method) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invoke(Method.java:511) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at dalvik.system.NativeStart.main(Native Method) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime: Caused by: java.lang.IllegalArgumentException: locationName == null 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.location.Geocoder.getFromLocationName(Geocoder.java:171) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at com.example.jobinsabu.destination.Details.onCreate(Details.java:78) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.Activity.performCreate(Activity.java:5326) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2215) 
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2306)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.access$700(ActivityThread.java:153)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1286)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Handler.dispatchMessage(Handler.java:99)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Looper.loop(Looper.java:176)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.main(ActivityThread.java:5302)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invokeNative(Native Method)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invoke(Method.java:511)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)  
02-12 11:39:11.082 399-399/com.example.jobinsabu.destination E/AndroidRuntime:  at dalvik.system.NativeStart.main(Native Method)  

錯誤(修改過):

02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime: FATAL EXCEPTION: main 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.jobinsabu.destination/com.example.jobinsabu.destination.Details}: java.lang.IndexOutOfBoundsException: Invalid index 0, size is 0 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2252) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2306) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.access$700(ActivityThread.java:153) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1286) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Looper.loop(Looper.java:176) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.main(ActivityThread.java:5302) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invokeNative(Native Method) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invoke(Method.java:511) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at dalvik.system.NativeStart.main(Native Method) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime: Caused by: java.lang.IndexOutOfBoundsException: Invalid index 0, size is 0 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:251) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.util.ArrayList.get(ArrayList.java:304) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at com.example.jobinsabu.destination.Details.onCreate(Details.java:79) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.Activity.performCreate(Activity.java:5326) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2215) 
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2306)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.access$700(ActivityThread.java:153)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1286)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Handler.dispatchMessage(Handler.java:99)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.os.Looper.loop(Looper.java:176)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at android.app.ActivityThread.main(ActivityThread.java:5302)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invokeNative(Native Method)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at java.lang.reflect.Method.invoke(Method.java:511)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)  
02-12 12:00:20.371 4652-4652/com.example.jobinsabu.destination E/AndroidRuntime:  at dalvik.system.NativeStart.main(Native Method)  

回答

1

如在日誌:

java.lang.IllegalArgumentException: locationName == null

由於destination字符串是空的,其從getIntent()得到。

bundle.putString("places",textView.getText().toString()); 
intent.putExtras(bundle); 

還可以使用用於獲取相同的密鑰用於獲取這是在以前的活動中使用的Details活動值相同的密鑰:

捆綁與textView.getText()值上點擊按鈕作爲添加places關鍵。

+0

謝謝你糾正我。我已經改變了它,但現在我得到了另一個錯誤。我將編輯這個問題。 – jobin

+0

@jobin:可能'addressList'爲空,因此在調用get method之前添加索引檢查 –

+0

當我運行日誌檢查時,大小顯示爲零。可能是什麼原因。 – jobin

0

在您的代碼目標爲空,因爲您通過的地方

bundle.putString("places",textView.getText().toString()); 

但收到

destination= bundle.getString("place"); 
    //change into places. 

變化等作爲

destination= bundle.getString("places"); 

傳遞字符串之前檢查textView.getText()。toString()方法是不是空的。