使用ArcGIS API for Silverlight 进行复合多条件空间查询

简介: 原文:使用ArcGIS API for Silverlight 进行复合多条件空间查询          这两天帮网上认识的一个兄弟做了一个查询的示例,多多少少总结一下,在此和大家分享。 为什么说是复合多条件呢?因为进行空间查询有时候我们查询的条件会很复杂,比如要求某一要素的某一属性大于多少,且小于多少,且又不等于多少等等。
原文: 使用ArcGIS API for Silverlight 进行复合多条件空间查询

          这两天帮网上认识的一个兄弟做了一个查询的示例,多多少少总结一下,在此和大家分享。

为什么说是复合多条件呢?因为进行空间查询有时候我们查询的条件会很复杂,比如要求某一要素的某一属性大于多少,且小于多少,且又不等于多少等等。而在官网给出的例子中并没有关于复合查询的说明。不过查看API后,你会发现一句很重要的话:

A where clause for the query. Any legal SQL where clause operating on the fields in the layer is allowed, for example: where=POP2000 > 350000.

也就是说在进行空间查询是Query的Where属性实际上是SQL where查询的字符串,所以这样我们写查询条件是就可以仿照SQL where查询语句的方式。具体可参考如下的示例。

一、前台部分

界面设计如下:

 前台XAML代码如下:

MainPage.xaml

View Code

说明:

 在前台页面还增加了要素的Web在线编辑功能,如果要素来自于ArcSDE数据库,那么还可以同步跟新到后台的数据库。

二、后台代码

后台主要是实现查询,查询时通过QueryTask指定查询的图层以及声明查询的任务,QueryTask通过ExecuteAsync方法接收Query参数,然后开始查询,通过QueryCompleted事件返回查询的结果。

其中Query指定查询的条件和查询相关的参数,下面列出了Query的常用参数列表:

参数列表                   参数说明          
Geometry 指定查询的空间过滤器,并可通过Query.SpatialRelationship来描述查询的空间关系,有效的几何类型有:MapPoint, Polyline, Polygon, Envelope, or MultiPoint.   
OutFields 筛选的字段集合即要素包含的属性
ReturnGeometry 返回查询的几何要素,如果返回全部字段,则强制设置了ReturnGeometry为true
Source  如果查询的是动态图层,这设置图层源
SpatialRelationship  描述空间查询被查询的要素与输入的几何要素的空间关系
Text  对应要素服务图层中显示的字段
 Where  查询语句,由一条合法的SQL语句表示

下面看一下查询具体实现的方式:

首先声明QueryTask及查询的目标图层

        //用于查询的Task
        QueryTask queryTask = new QueryTask();
        //查询的目标图层
        FeatureLayer featurelayer;

          //声明一个Draw,用于绘制查询的区域,进行空间查询
          Draw myDraw;

在构造函数中赋值和实例化

 public MainPage()
        {
            InitializeComponent();
            
            featurelayer = map1.Layers["RiverSourceLayer"] as FeatureLayer;

            editorWidget.Loaded += new RoutedEventHandler(editorWidget_Loaded);

            queryTask.Url = featurelayer.Url;
            queryTask.ExecuteCompleted += new EventHandler<QueryEventArgs>(queryTask_ExecuteCompleted);
            queryTask.Failed += new EventHandler<TaskFailedEventArgs>(queryTask_Failed);

              myDraw = new Draw(map1);
              myDraw.DrawMode = DrawMode.Polygon;
              myDraw.IsEnabled = false;

              myDraw.FillSymbol = new SimpleFillSymbol()
              {
                BorderBrush=new SolidColorBrush(Colors.Black),
                BorderThickness=3,
                Fill=new SolidColorBrush (Colors.Red),
               };
              myDraw.DrawComplete += new EventHandler<DrawEventArgs>(myDraw_DrawComplete);

            FiledsCombox.ItemsSource = AttributeString.GraphicAttributesEnNameString;
        }

自定义两个查询方法:

StartQueryBySQL(string sqlString):按SQL 的Where语句进行查询。

private void StartQueryBySQL(string sqlString)
        {
            if (ExpressionTextBox.Text == "")
                return;
            Query query = new Query();
            query.ReturnGeometry = true;
            query.OutFields.AddRange(AttributeString.GraphicAttributesEnNameString);
            query.Where = sqlString;
            query.OutSpatialReference = map1.SpatialReference;
            queryTask.ExecuteAsync(query);
        }

StartQueryBySpatial(ESRI.ArcGIS.Client.Geometry.Geometry geometry):按绘制的空间图形进行查询

private void StartQueryBySpatial(ESRI.ArcGIS.Client.Geometry.Geometry geometry)
        {
            Query query = new Query();
            query.ReturnGeometry = true;
            query.OutFields.AddRange(AttributeString.GraphicAttributesEnNameString);
            query.Geometry = geometry;
            query.OutSpatialReference = map1.SpatialReference;
            queryTask.ExecuteAsync(query);
        }

接下来就是点击不同的按钮进行查询了,并对查询的结果进行处理,例如在地图上显示查询的结果。

注:本文由于查询的是点要素,所以在查询的Completed事件完成函数中只对点进行了Symbol显示操作,如果查询的结果是面要素还需对面进行处理,读者可自行添加。

下面是查询完成对结果处理的代码:

  private void queryTask_ExecuteCompleted(object sender, QueryEventArgs e)
        {
            GraphicsLayer graphicsLayer = map1.Layers["QueryResultLayer"] as GraphicsLayer;
            graphicsLayer.ClearGraphics();

            if (e.FeatureSet.Features.Count > 0)
            {
                foreach (Graphic resultFeature in e.FeatureSet.Features)
                {
                    resultFeature.Symbol = new SimpleMarkerSymbol()
                        {
                            Color=new SolidColorBrush(Colors.Red),
                            Size=18,
                            Style=SimpleMarkerSymbol.SimpleMarkerStyle.Circle,
                        };
                    graphicsLayer.Graphics.Add(resultFeature);
                }
            }
            else
            {
                MessageBox.Show("没有查询到目标要素!");
            }
        }

空间查询时在Draw的Competed事件中提交空间查询请求:

private void myDraw_DrawComplete(object sender, DrawEventArgs e)
        {
            StartQueryBySpatial(e.Geometry);
            myDraw.IsEnabled = false;
        }

其他部分的代码就是对查询的输入进行的一下控制,以及对程序Bug的一些处理(当然依旧还有些bug没有修复,不过不影响查询的整体功能,读者可以自己再修改完善)。

下面给出完整的代码:Coding-Behind

MainPage.cs
AttributeString.cs

最后的效果示意图(结果用红色的点表示,点击要素可查看其属性列表):

1.Where查询:

a、查询条件一:Source_ID > 1 and Source_ID < 20 and Source_ID ! = 14

查询结果:

b、查询条件二:Source_ID > 1 and Source_Emissions is  not  null  and Source_Emissions < 200

查询结果:

c.空间查询

输入查询多边形:

查询出多边形内的要素:

源码及测试数据下载:【下载代码

数据使用说明:压缩文件中的的数据为ArcMap导出的XML文件,使用时,在ArcMap中新建一个地理数据库,然后右键导入,选择该xml文件,即可生成本例的数据。建议将该数据的服务发布成要素服务,这样支持Web在线编辑。

(版权所有,转载请标明出处)

目录
相关文章
|
2月前
|
JSON 自然语言处理 搜索推荐
银行卡归属地及开户行查询API查询实战指南
银行卡归属地及开户行查询API,通过卡号快速识别发卡行、开户地及卡种信息,支持全国1500+银行,数据实时更新。提供结构化数据返回,广泛应用于支付、风控、用户画像等场景,助力金融系统高效、安全运行。
742 5
|
1月前
|
移动开发 算法 API
淘宝/天猫:使用物流查询API实时显示包裹位置,减少客服咨询量
电商平台中物流咨询占客服工作40%以上,用户频繁追问包裹位置。本文介绍通过物流查询API实现包裹实时追踪,降低75.6%咨询量,提升用户体验与复购率,助力降本增效。(238字)
274 0
|
1月前
|
人工智能 JSON API
淘宝/天猫:使用物流查询API实时显示包裹位置,减少客服咨询量
在电商竞争激烈的环境下,淘宝、天猫通过集成物流查询API,实现实时追踪包裹位置,显著减少用户咨询量。本文解析其原理、实现步骤与效益,展示如何以技术手段提升用户体验、降低客服压力,助力平台高效运营。(238字)
225 0
|
2月前
|
JSON Unix API
1688查询榜单列表API详解
1688榜单API提供实时热销、新品等商品榜单数据,支持20+品类及40+字段筛选,适用于选品与市场分析。每小时更新,响应迅速。提供Python调用示例,开发者可快速集成。
|
1月前
|
监控 安全 算法
快递查询API|一次接通2700+快递服务商的物流轨迹
在物流数字化的浪潮中,企业对接多家快递服务商的痛点日益凸显:每新增一家合作物流商,技术团队就要投入 5-7 个工作日进行接口开发,不同服务商的接口协议差异导致系统稳定性差,物流轨迹数据分散在各平台难以整合分析。快递鸟快递查询 API 通过标准化接口架构,创新性地实现了 2700 + 国内外快递服务商的一键接入,将传统模式下的周级开发周期压缩至小时级,彻底重构了物流数据对接的技术范式。
138 0
|
2月前
|
JSON API 数据格式
银行卡联行号查询API:在风控中的落实践
银行卡联行号查询API,基于HTTPS协议,支持Token认证与跨域调用,提供精准高效的银行信息查询服务,助力支付系统提升成功率与稳定性。
308 0
|
3月前
|
JSON API PHP
化学元素信息,元素周期表查询免费API完整指南
本接口提供权威化学元素的100+项参数查询服务,涵盖原子结构、物理性质、分布数据等科研级参数。支持中文名称、元素符号(区分大小写)或原子序数查询,适用于教育软件、化学工具和科研系统开发。数据版权归属接口盒子。
|
1月前
|
人工智能 API
阿里云百炼API-KEY在哪查询?如何获取阿里云AI百炼大模型的API-KEY?
阿里云百炼是阿里云推出的AI大模型平台,用户可通过其管理控制台获取API-KEY。需先开通百炼平台及大模型服务,即可创建并复制API-KEY。目前平台提供千万tokens免费额度,详细操作流程可参考官方指引。
|
1月前
|
JSON 前端开发 API
汽车配件:使用VIN码查询API精准匹配车型配件,提升用户信任
VIN码是汽车的唯一“身份证”,通过API可精准解析车型信息,实现配件99.5%以上匹配度。本文详解VIN码API的工作流程、技术实现与信任提升价值,助力汽配销售从经验判断迈向数据驱动,降低退货率,提升用户体验与复购。
384 0
|
1月前
|
JSON 监控 API
Minecraft(我的世界)服务器信息查询免费API接口详解
本文介绍接口盒子提供的免费Minecraft服务器查询API,涵盖参数说明、返回解析及PHP/Python调用示例,助您快速集成服务器监控功能。

热门文章

最新文章