在我们的地图的操作中经常会有一些操作是需要通过画多边形或者画线来查找某一块区域内的特定的Graphics比如我们在做的交警的项目中通过框选来查找某一块区域中的摄像机,某一块区域中的警力、警情、警员等相关信息,我们就经常需要使用ArcGIS中的服务来查找相关的结果,但是Arcgis中大部分的查询结果都是都是在异步函数中进行相关查询的,往往我们需要将查询到的结果用一些图标或者其它的方式进行展示,这时就需要通过异步回调函数的方式来进行相关的操作,下面举出一个具体的实例来解释这个过程,首先看一看查询某一图层的数据的具体代码。
public virtual void SearchMapElementsAnsys(ESRI.ArcGIS.Client.Geometry.Geometry geometry,
Action<List<MapElement.BussinessMapElement>> searchCompletedCallback) { LocalGeometryService.GetServiceAsync(localGeometryService => { GeometryService geometryService = new GeometryService(localGeometryService.UrlGeometryService); geometryService.IntersectCompleted += new EventHandler<GraphicsEventArgs>(delegate(object obj, GraphicsEventArgs args) { IList<Graphic> graphics = args.Results; List<MapElement.BussinessMapElement> mapElements = new List<BussinessMapElement>(); for (int i = 0; i <= graphics.Count - 1; i++) { MapPoint intersectPoint = graphics[i].Geometry as MapPoint; if (!double.IsNaN(intersectPoint.X)) { mapElements.Add(this.Graphics[i] as BussinessMapElement); } } if (searchCompletedCallback != null) searchCompletedCallback(mapElements); }); if ((geometry as Envelope) != null) { Envelope env = geometry as Envelope; ESRI.ArcGIS.Client.Geometry.Polygon polygon = new Polygon(); polygon.SpatialReference = new SpatialReference(102100); ObservableCollection<PointCollection> rings = new ObservableCollection<PointCollection>(); PointCollection ptCollection = new PointCollection(); ptCollection.Add(new MapPoint(env.XMin, env.YMin, new SpatialReference(102100))); ptCollection.Add(new MapPoint(env.XMax, env.YMin, new SpatialReference(102100))); ptCollection.Add(new MapPoint(env.XMax, env.YMax, new SpatialReference(102100))); ptCollection.Add(new MapPoint(env.XMin, env.YMax, new SpatialReference(102100))); ptCollection.Add(new MapPoint(env.XMin, env.YMin, new SpatialReference(102100))); rings.Add(ptCollection); polygon.Rings = rings; geometry = polygon; } geometryService.IntersectAsync(this.Graphics, geometry); }); }
这个函数传入两个重要的参数,第一个参数是Geometry对象,第二个参数是一个回调函数,回调函数的参数是List<MapElement.BussinessMapElement>,是一个Graphic的集合。下面就是重点的查询过程了,首先将geometry 转换为一个Envelope对象,Envelope env = geometry as Envelope;然后将env 的边界点放入到一个PointCollection中,然后再将这个PointCollection作为Polygon的Rings,然后最关键的就是调用geometryService.IntersectAsync(this.Graphics, geometry)这个异步函数来查询结果,查询完毕以后执行 IList<Graphic> graphics = args.Results将查询的结果作为参数放到异步回调函数中,这里是if (searchCompletedCallback != null) searchCompletedCallback(mapElements);从而执行回调函数中的结果,那么我们再来看一下回调函数到底在做些什么。
gpsVehicleLyr.SearchMapElementsAnsys(geometry, new Action<List<BussinessMapElement>>(
delegate(List<BussinessMapElement> bussinessMapElements) { try { Application.Current.Dispatcher.Invoke(new Action(delegate() { panel = MapSearchUtility._resultWindow.AddTabItem("4G警车"); CtrG4VehicleResult g4vehicleResult = new CtrG4VehicleResult(); g4vehicleResult.Dock = System.Windows.Forms.DockStyle.Fill; panel.Controls.Add(g4vehicleResult); for (int i = 0; i <= bussinessMapElements.Count - 1; i++) { BussinessMapElement g4Element = bussinessMapElements[i]; g4vehicleResult.AddG4Vehicle(g4Element.Attributes["NAME"].ToString(),
g4Element.Attributes["UNIT"].ToString(), g4Elementbutes["ALARM_DATE"].ToString(),
g4Element.Attributes["CAMERAID"].ToString()); } MapSearchUtility._resultWindow.RefreshChild(); })); } catch (System.Exception ex0) { ApplicationLog.Instance.OutPutLog(ex0.ToString()); } }));
这里就不具体分析这段代码实现的功能,最终查询到的结果会通过回调函数传回到bussinessMapElements这个集合中,从而做一些相关的界面的图表展示。
这篇文章只是提供一个思路如何去通过LocalGeometryService的其中一种方法IntersectAsync(相交)其实LocalGeometryService中还提供了很多种的方式来进行地图的操作,比如合并,穿越等一系列的操作,这些都需要我们去一点点体会,并不断进行总结提炼。