Я запутался в том, чтобы создавать эффекты наведения для многоугольников в слое геоджонов с помощью android google map. Я восстановил детали геоджона с веб-сервера, чтобы показать вещи на карте. в слое geojson, когда пользователь перемещается по нему. Ниже я разместил свой код, как я реализовал слой geojson, используя карту Google. Заранее спасибо.
сильный текст
Класс DownloadGeoJsonFile расширяет AsyncTask
{
protected void onPreExecute()
{
super.onPreExecute();
progressBar.setVisibility(View.VISIBLE);
}
@Override
protected GeoJsonLayer doInBackground(String... params)
{
try
{
// Open a stream from the URL
InputStream stream = new URL(params[0]).openStream();
String line;
StringBuilder result = new StringBuilder();
BufferedReader reader = new BufferedReader(new InputStreamReader(stream));
while ((line = reader.readLine()) != null)
{
// Read and save each line of the stream
result.append(line);
}
// Close the stream
reader.close();
stream.close();
return new GeoJsonLayer(mMap, new JSONObject(result.toString()));
} catch (IOException e) {
Log.e(mLogTag, "GeoJSON file could not be read");
} catch (JSONException e) {
Log.e(mLogTag, "GeoJSON file could not be converted to a JSONObject");
}
return null;
}
@Override
protected void onPostExecute(GeoJsonLayer layer) {
Log.e("sundar","success");
progressBar.setVisibility(View.GONE);
if (layer != null) {
Log.e("sundar","successsuccess");
addGeoJsonLayerToMap(layer);
}
}
}
private void retrieveFileFromUrl()
{
new DownloadGeoJsonFile().execute(getString(R.string.geojson_url2));
}
private void addGeoJsonLayerToMap(final GeoJsonLayer layer)
{
if (layer != null)
{
try
{
Log.e("sundar", "successsuccess");
layer.addLayerToMap();
final GeoJsonPolygonStyle style =layer.getDefaultPolygonStyle();
style.setStrokeColor(Color.BLACK);
style.setStrokeWidth(3F);
mMap.moveCamera(CameraUpdateFactory.newLatLng(new LatLng(20.593683, 78.962883)));
layer.setOnFeatureClickListener(new GeoJsonLayer.GeoJsonOnFeatureClickListener() {
@Override
public void onFeatureClick(Feature feature)
{
Log.e("type",feature.getGeometry().getGeometryType().toString());
}
});
}
catch(Exception e)
{
Log.e("exception","exception occured");
}
}
}