Андроид:Обратное геокодирование — getFromLocation
-
19-08-2019 - |
Вопрос
Я пытаюсь получить адрес на основе долготы/широты.кажется, что-то вроде этого должно работать?
Geocoder myLocation = Geocoder(Locale.getDefault());
List myList = myLocation.getFromLocation(latPoint,lngPoint,1);
Проблема в том, что я продолжаю получать:Метод Geocoder(Locale) не определен для типа savemaplocation.
Любая помощь будет полезна.Спасибо.
Спасибо, я попробовал контекст, сначала локаль, но это не удалось, и я смотрел на некоторые другие конструкторы (я видел один, в котором упоминался только локаль).Несмотря ни на что,
Это не сработало, так как я все еще получаю:Метод Geocoder(Context, Locale) не определен для типа savemaplocation.
Я должен :импортировать android.location.Geocoder;
Решение
Следующий фрагмент кода делает это для меня (lat и lng - это двойные числа, объявленные выше этого бита):
Geocoder geocoder = new Geocoder(this, Locale.getDefault());
List<Address> addresses = geocoder.getFromLocation(lat, lng, 1);
Другие советы
Вот полный пример кода с использованием Thread и обработчика для получения ответа геокодера без блокировки пользовательского интерфейса.
Процедура вызова геокодера, может быть расположена в классе Helper
public static void getAddressFromLocation(
final Location location, final Context context, final Handler handler) {
Thread thread = new Thread() {
@Override public void run() {
Geocoder geocoder = new Geocoder(context, Locale.getDefault());
String result = null;
try {
List<Address> list = geocoder.getFromLocation(
location.getLatitude(), location.getLongitude(), 1);
if (list != null && list.size() > 0) {
Address address = list.get(0);
// sending back first address line and locality
result = address.getAddressLine(0) + ", " + address.getLocality();
}
} catch (IOException e) {
Log.e(TAG, "Impossible to connect to Geocoder", e);
} finally {
Message msg = Message.obtain();
msg.setTarget(handler);
if (result != null) {
msg.what = 1;
Bundle bundle = new Bundle();
bundle.putString("address", result);
msg.setData(bundle);
} else
msg.what = 0;
msg.sendToTarget();
}
}
};
thread.start();
}
Вот вызов этой процедуры геокодера в вашем пользовательском интерфейсе.
getAddressFromLocation(mLastKownLocation, this, new GeocoderHandler());
И обработчик для отображения результатов в вашем пользовательском интерфейсе:
private class GeocoderHandler extends Handler {
@Override
public void handleMessage(Message message) {
String result;
switch (message.what) {
case 1:
Bundle bundle = message.getData();
result = bundle.getString("address");
break;
default:
result = null;
}
// replace by what you need to do
myLabel.setText(result);
}
}
Не забудьте добавить следующее разрешение в ваш Manifest.xml
<uses-permission android:name="android.permission.INTERNET" />
Похоже, здесь происходят две вещи.
1) Вы пропустили new
ключевое слово перед вызовом конструктора.
2) Параметр, который вы передаете в конструктор геокодера, неверен.Вы проходите мимо Locale
где он ожидает Context
.
Есть два Geocoder
конструкторы, оба из которых требуют Context
, и один также принимает Locale
:
Geocoder(Context context, Locale locale)
Geocoder(Context context)
Решение
Измените свой код, чтобы он передавался в действительный контекст, и включите new
и вам должно быть хорошо идти.
Geocoder myLocation = new Geocoder(getApplicationContext(), Locale.getDefault());
List<Address> myList = myLocation.getFromLocation(latPoint, lngPoint, 1);
Примечание
Если у вас все еще возникают проблемы, возможно, это проблема с разрешением.Геокодирование неявно использует Интернет для выполнения поиска, поэтому вашему приложению потребуется INTERNET
использует тег разрешения в вашем манифесте.
Добавьте следующий узел разрешения на использование в manifest
узел вашего манифеста.
<uses-permission android:name="android.permission.INTERNET" />
Причиной этого является несуществующая внутренняя служба:
Классу Geocoder требуется бэкэнд-сервис, который не включен в базовую платформу Android. Методы запроса Geocoder вернут пустой список, если на платформе нет бэкэнда. Р>
Сначала получите широту и долготу, используя класс Location и LocationManager. Теперь попробуйте код ниже, чтобы получить город, адрес информация
double latitude = location.getLatitude();
double longitude = location.getLongitude();
Geocoder gc = new Geocoder(this, Locale.getDefault());
try {
List<Address> addresses = gc.getFromLocation(lat, lng, 1);
StringBuilder sb = new StringBuilder();
if (addresses.size() > 0) {
Address address = addresses.get(0);
for (int i = 0; i < address.getMaxAddressLineIndex(); i++)
sb.append(address.getAddressLine(i)).append("\n");
sb.append(address.getLocality()).append("\n");
sb.append(address.getPostalCode()).append("\n");
sb.append(address.getCountryName());
}
Информация о городе теперь в сб. Теперь преобразуйте sb в String (используя sb.toString ()). Р>
Ну, я все еще в тупике. Так что вот еще код. Р>
Прежде чем покинуть карту, я звоню SaveLocation(myMapView,myMapController);
. Это то, что в итоге вызывает мою информацию о геокодировании.
Но поскольку getFromLocation
может выдать IOException
, мне пришлось сделать следующее, чтобы вызвать SaveLocation
try
{
SaveLocation(myMapView,myMapController);
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
Затем я должен изменить SaveLocation, сказав, что он выбрасывает IOException:
public void SaveLocation(MapView mv, MapController mc) throws IOException{
//I do this :
Geocoder myLocation = new Geocoder(getApplicationContext(), Locale.getDefault());
List myList = myLocation.getFromLocation(latPoint, lngPoint, 1);
//...
}
И он каждый раз падает.
Я слышал, что Geocoder находится на ошибочной стороне. Недавно я собрал пример приложения, которое использует сервис геокодирования http для поиска местоположения по широте / долготе. Не стесняйтесь проверить это здесь
Используйте это
Geocoder geocoder = new Geocoder(this, Locale.getDefault());
List<Address> addresses = geocoder.getFromLocation(lat, lng, 1);