Через несколько дней, чтобы узнать, как работает Android, я решил создать свое первое приложение: простое приложение, которое отображает GMap по адресу, предоставленному пользователем, с простым виджетом EditText
.
Я использую Geocoder
сделать это.
После небольшого отслеживания ошибок с помощью logcat, вот исключение, возвращаемое adb:
E/LocationMasfClient( 53): forwardGeocode(): RPC failed with status 1
W/System.err( 262): java.io.IOException: RPC failed with status 1
W/System.err( 262): at android.location.Geocoder.getFromLocationName(Geocoder.java:166)
W/System.err( 262): at fr.meetopia.tinymap.MapViewActivity.testGeoCoder(MapViewActivity.java:104)
W/System.err( 262): at fr.meetopia.tinymap.MapViewActivity.onCreate(MapViewActivity.java:38)
W/System.err( 262): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
W/System.err( 262): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459)
W/System.err( 262): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
W/System.err( 262): at android.app.ActivityThread.access$2200(ActivityThread.java:119)
W/System.err( 262): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
А теперь вот код, указанный трассировкой стека:
Geocoder geoCoder = new Geocoder(this);
MapView mapView = (MapView) findViewById(R.id.mapview);
MapController mc = mapView.getController();
GeoPoint p;
try {
List<Address> addresses = geoCoder.getFromLocationName("paris france", 50);
if (addresses.size() > 0) {
p = new GeoPoint(
(int) (addresses.get(0).getLatitude() * 1E6),
(int) (addresses.get(0).getLongitude() * 1E6));
mc.animateTo(p);
mapView.invalidate();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Очевидно, этот код является частью MapActivity
экземпляра.
Я провел несколько тестов с разными версиями Google APIS (8, 7, 4) и разными версиями платформы SDK (2.2, 2.1, 1.6), но не повезло.Я только что заметил, что Google API 8 содержит известную ошибку и вернул Service Unavailable Exception
вместо RPC Failed 1
.
С другой стороны, я попытался запустить свое приложение непосредственно на моем устройстве (HTC Desire 2.1)и я заметил то же самое поведение (то есть: без поведения, карта с США в центре).
Вот пользовательское разрешение манифеста Android:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />