I am new to android development and I am developing an android app in which I am converting address to latitude and longitude. I am using geocoder. But when I call that function app force closes. This is my code snippet
public void getLatLongFromGivenAddress(String address)
{
double lat= 0.0, lng= 0.0;
Geocoder geoCoder = new Geocoder(this, Locale.getDefault());
try
{
List<Address> addresses = geoCoder.getFromLocationName(address , 1);
if (addresses.size() > 0)
{
GeoPoint p = new GeoPoint(
(int) (addresses.get(0).getLatitude() * 1E6),
(int) (addresses.get(0).getLongitude() * 1E6));
lat=p.getLatitudeE6()/1E6;
lng=p.getLongitudeE6()/1E6;
String lati =String.valueOf(lat);
String longi =String.valueOf(lng);
Log.d("Latitude", ""+lat);
Toast.makeText(getApplicationContext(), lati, Toast.LENGTH_LONG).show();
Log.d("Longitude", ""+lng);
Toast.makeText(getApplicationContext(), longi, Toast.LENGTH_LONG).show();
}
}
catch(Exception e)
{
e.printStackTrace();
}
}
This is my logcat
04-11 01:33:45.020: E/dalvikvm(25175): Could not find class 'com.google.android.maps.GeoPoint', referenced from method at.vcity.androidim.Messaging.getLatLongFromGivenAddress
04-11 01:34:03.090: E/AndroidRuntime(25175): FATAL EXCEPTION: main
04-11 01:34:03.090: E/AndroidRuntime(25175): Process: at.vcity.androidim, PID: 25175
04-11 01:34:03.090: E/AndroidRuntime(25175): java.lang.NoClassDefFoundError: com.google.android.maps.GeoPoint
04-11 01:34:03.090: E/AndroidRuntime(25175): at at.vcity.androidim.Messaging.getLatLongFromGivenAddress(Messaging.java:300)
04-11 01:34:03.090: E/AndroidRuntime(25175): at at.vcity.androidim.Messaging.appendToMessageHistory(Messaging.java:272)
04-11 01:34:03.090: E/AndroidRuntime(25175): at at.vcity.androidim.Messaging$2.onClick(Messaging.java:131)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.view.View.performClick(View.java:4444)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.view.View$PerformClick.run(View.java:18440)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.os.Handler.handleCallback(Handler.java:733)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.os.Handler.dispatchMessage(Handler.java:95)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.os.Looper.loop(Looper.java:136)
04-11 01:34:03.090: E/AndroidRuntime(25175): at android.app.ActivityThread.main(ActivityThread.java:5047)
04-11 01:34:03.090: E/AndroidRuntime(25175): at java.lang.reflect.Method.invokeNative(Native Method)
04-11 01:34:03.090: E/AndroidRuntime(25175): at java.lang.reflect.Method.invoke(Method.java:515)
04-11 01:34:03.090: E/AndroidRuntime(25175): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:806)
04-11 01:34:03.090: E/AndroidRuntime(25175): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
04-11 01:34:03.090: E/AndroidRuntime(25175): at dalvik.system.NativeStart.main(Native Method)
What are the changes I should do ? Thank you!
Add
<uses-library android:name="com.google.android.maps" />
to your AndroidManifest.xml file, below application tag