我正在尝试使用此ArcGIS服务在android 中围绕Point创建缓冲区:
http://tasks.arcgisonline.com/ArcGIS/rest/services/Geometry/GeometryServer
我想用编程方式创建一个缓冲区:
http://tasks.arcgisonline.com/ArcGIS/rest/services/Geometry/GeometryServer/buffer
这是学校的工作,所以它必须是这项服务,API必须是ArcGIS SDK 10.1.1
Unfourtunelly,关于此的文档并不多。我所知道的是,在某些时刻我应该获得一个Polygon对象,我将添加到地图中。
我需要知道的是(有重点)如何调用服务,传递所需的参数并获取多边形。
谢谢
答案 0 :(得分:1)
我正在使用 MapBox ,我必须在地图上的多边形之上创建一个缓冲区域。我没有使用过ArcGis而是使用了 vividsolutions 中的库
Git回购链接:https://github.com/RanaRanvijaySingh/MapBoxDemo
在 build.gradle 文件中添加
dependencies {
...
compile 'com.vividsolutions:jts:1.13'
}
在 MainActivity 中,我使用了以下几点的多边形:
final List<LatLng> latLngPolygon = new ArrayList<>();
{
latLngPolygon.add(new LatLng(28.6139, 77.2090));//delhi
latLngPolygon.add(new LatLng(22.2587, 71.1924));//gujarat
latLngPolygon.add(new LatLng(18.5204, 73.8567));//pune
latLngPolygon.add(new LatLng(12.9716, 77.5946));//banglore
latLngPolygon.add(new LatLng(25.5941, 85.1376));//patna
//this is needed to completed a covered area, without this it would not work
latLngPolygon.add(new LatLng(28.6139, 77.2090));//delhi
}
下面是在地图上创建多边形和缓冲多边形的功能
/**
* Function is called on click of Buffer Example button
*
* @param view View
*/
public void onClickBufferExample(View view) {
//Initialize geometry factory object to get Geometry object.
geometryFactory = new GeometryFactory();
//Create geometry object using your own lat lang points
//TODO : latLngPolygon - Used in this example is to show a bigger picture. Replace it
//TODO : with your requirement.
Geometry geometryOriginal = getGeometryForPolygon(latLngPolygon);
//Draw polygon on map
createPolygon(geometryOriginal);
/**
* Create geometry object with given buffer distance
* Now buffer distance will vary on your requirement
* Range could be anything
* Hit and try
*/
Geometry geometryBuffered = geometryOriginal.buffer(1);
//Draw buffer polygon
createPolygon(geometryBuffered);
}
/**
* Function to get Geometry object (Class from vividsolutions)
* from given list of latlng
*
* @param bounds List
* @return Geometry (Class from vividsolutions)
*/
public Geometry getGeometryForPolygon(List<LatLng> bounds) {
List<Coordinate> coordinates = getCoordinatesList(bounds);
if (!coordinates.isEmpty()) {
return geometryFactory.createPolygon(getLinearRing(coordinates), null);
}
return null;
}
/**
* Function to create a list of coordinates from a list of lat lng
*
* @param listLatLng list<LatLng>
* @return List<Coordinate> (Class from vividsolutions)
*/
private List<Coordinate> getCoordinatesList(List<LatLng> listLatLng) {
List<Coordinate> coordinates = new ArrayList<>();
for (int i = 0; i < listLatLng.size(); i++) {
coordinates.add(new Coordinate(
listLatLng.get(i).getLatitude(), listLatLng.get(i).getLongitude()));
}
return coordinates;
}
/**
* Function to create a polygon on the map
*
* @param geometry Geometry Class from vividsolutions
*/
private void createPolygon(Geometry geometry) {
LatLng[] points = getPoints(geometry.getCoordinates());
mapboxMap.addPolyline(new PolylineOptions()
.add(points)
.width(4)
.color(Color.parseColor("#FF0000")));
}
/**
* Function to convert array of Coordinates (Class from vividsolutions)
* to Android LatLng array
*
* @param coordinates Coordinates (Class from vividsolutions)
* @return LatLng[]
*/
@NonNull
private LatLng[] getPoints(Coordinate[] coordinates) {
List<LatLng> listPoints = new ArrayList<>();
for (Coordinate coordinate : coordinates) {
listPoints.add(new LatLng(coordinate.x, coordinate.y));
}
return listPoints.toArray(new LatLng[listPoints.size()]);
}
/**
* Function to create LinearRing (Class from vividsolutions) from a list of
* Coordinate (Class from vividsolutions)
*
* @param coordinates List
* @return LinearRing
*/
@NonNull
private LinearRing getLinearRing(List<Coordinate> coordinates) {
return new LinearRing(getPoints(coordinates), geometryFactory);
}
/**
* Function to get points of CoordinateArraySequence (Class from vividsolutions)
*
* @param coordinates List (Class from vividsolutions)
* @return CoordinateArraySequence (Class from vividsolutions)
*/
@NonNull
private CoordinateArraySequence getPoints(List<Coordinate> coordinates) {
return new CoordinateArraySequence(getCoordinates(coordinates));
}
/**
* Function to get coordinates array from a list of coordinates
*
* @param coordinates List<Coordinate> (Class from vividsolutions)
* @return Coordinate [] (Class from vividsolutions)
*/
@NonNull
private Coordinate[] getCoordinates(List<Coordinate> coordinates) {
return coordinates.toArray(new Coordinate[coordinates.size()]);
}
DONE。
按照你想要的方式继续进行重构,但就是这样。
答案 1 :(得分:0)
如果我是你,我会跳过GeometryServer并使用GeometryEngine.buffer(Geometry, SpatialReference, double, Unit)。您不需要以这种方式调用服务。 这是正确的方法。
但是,如果您的学校作业需要拨打电话,请转到the service并点击API参考链接以显示the documentation for GeometryServer。你必须使用f = json并使用JSON。 GeometryEngine有geometryToJson和jsonToGeometry方法可以帮助您,但如果您愿意,也可以使用a JSON library。如果您不知道如何在Android / Java代码中打开URL连接,请使用Google。