AE根据记录信息获得地图元素信息并定位地图位置

简介:
    

AE根据记录信息获得地图元素信息并定位地图位置

 

ContractedBlock.gif ExpandedBlockStart.gif Code
                //获得属性值
                string ManagerId = dgvK001.Rows[e.RowIndex].Cells[0].Value.ToString();
                
string RoadId = dgvK001.Rows[e.RowIndex].Cells[2].Value.ToString();
                
if (RoadId.IndexOf("S"!= -1 || RoadId.IndexOf("G"!= -1)
                    RoadId 
= RoadId.Substring(04);
                
string StartStake = dgvK001.Rows[e.RowIndex].Cells[5].Value.ToString();
                
//遍历整个地图
                for (int i = 0; i < axMapControl.LayerCount; i++)
                {
                    IFeatureLayer pLayer 
= null;
                    IFeatureClass iFeatureClass 
= null;
                    
//获得图层
                    pLayer = (IFeatureLayer)axMapControl.get_Layer(i);
                    iFeatureClass 
= pLayer.FeatureClass;
                    
//定义AE游标
                    IFeatureCursor pCursor;
                    
//构建查询条件
                    IQueryFilter pFilter = new QueryFilterClass();

                    
//多字段查询
                    pFilter.WhereClause = " LXBM = '" + RoadId.Trim() + "'" + " AND DWDM = '" + ManagerId.Trim() + "'" + "  AND QDZH=" + StartStake.Trim() + "";
                    
try
                    {
                        pCursor 
= iFeatureClass.Search(pFilter, false);
                        IFeature pFeature;
//获得查询的元素
                        pFeature = pCursor.NextFeature();

                        
if (pFeature != null)
                        {
                            
//要素的定义,如果是点直接定位
                            if (pFeature.Shape.GeometryType == esriGeometryType.esriGeometryPoint)
                            {
                                
this.axMapControl.CenterAt((IPoint)pFeature.Shape);
                            }
                            
else
                            {
                                
//获得定位的范围
                                IEnvelope pEnv = pFeature.Shape.Envelope;
                                pEnv.Expand(
55true);
                                axMapControl.ActiveView.Extent 
= pEnv;
                            }
                            axMapControl.ActiveView.Refresh();
                            axMapControl.ActiveView.ScreenDisplay.UpdateWindow();
                            
//用于解决先定位后闪烁的问题
                            
//自定义闪烁功能
                            switch (pFeature.Shape.GeometryType)
                            {
                                
case esriGeometryType.esriGeometryPoint:
                                    FlashFeature.FlashPoint(axMapControl, axMapControl.ActiveView.ScreenDisplay, pFeature.Shape);
                                    
break;
                                
case esriGeometryType.esriGeometryPolyline:
                                    FlashFeature.FlashLine(axMapControl, axMapControl.ActiveView.ScreenDisplay, pFeature.Shape);
                                    
break;
                                
case esriGeometryType.esriGeometryPolygon:
                                    FlashFeature.FlashPolygon(axMapControl, axMapControl.ActiveView.ScreenDisplay, pFeature.Shape);
                                    
break;
                                
default:
                                    
break;
                            }

                            axMapControl.ActiveView.PartialRefresh(esriViewDrawPhase.esriViewGeoSelection, 
nullnull);
                            axMapControl.ActiveView.PartialRefresh(esriViewDrawPhase.esriViewGeography, 
nullnull);
                            
break;
                        }   
                    }
                    
catch { }
                }

 

这边要注意的是你需要定位的图层必须要有你需要查询的属性,在遍历整个地图的话则比较难统一字段,所以在获得元素的地方需要Catch掉容错.

图层也可以直接定义,假如你知道的话.

版权说明

  如果标题未标有<转载、转>等字则属于作者原创,欢迎转载,其版权归作者和博客园共有。
  作      者:温景良
  文章出处:http://wenjl520.cnblogs.com/  或  http://www.cnblogs.com/

posted @ 2009-01-12 09:55 温景良(Jason) Views( 1005) Comments( 0) Edit 收藏
 

公告

 
 
本文转 我的程序人生博客园博客,原文链接: http://www.cnblogs.com/wenjl520/archive/2009/01/12/1373984.html /,如需转载请自行联系原作者
相关文章
|
9月前
|
Python
ROS节点检测ArUco标签并记录空间坐标
利用Realsense D435i相机检测ArUco标签,使用Python程序订阅相机的ROS话题,记录Time和标签的XYZ值,储存在一个csv文件中;当出现识别不到标签或者反馈坐标为0,0,0的情况时,不进行记录。
172 0
|
2月前
|
API Python
文件位置标记及其定位
文件位置标记及其定位
13 2
|
4月前
|
C++ 索引 Python
区域和检索 - 数组不可变(C++)
区域和检索 - 数组不可变(C++)
19 0
|
6月前
|
小程序 API
小程序在获取当前位置信息在地图上显示
小程序在获取当前位置信息在地图上显示
105 0
|
6月前
|
资源调度 Java Python
如何在地图上寻找最密集点的位置?
最近我在工作中遇到了一个小的需求点,大概是需要在地图上展示出一堆点中的点密度最密集的位置。最开始没想到好的方法,就使用了一个非常简单的策略——所有点的坐标求平均值,这个方法大部分的时候好用,因为大部分城市所有点位基本上都是围绕某个中心点向四周发散的。但我们实际在线上使用的时候,遇到了两个特殊的case。
36 0
|
11月前
|
搜索推荐 JavaScript 定位技术
百度地图绘制地区的棱柱效果-定位-自定义点-文本标记-信息弹窗
百度地图绘制地区的棱柱效果-定位-自定义点-文本标记-信息弹窗
155 0
|
定位技术
使用地图显示我的位置
使用地图显示我的位置
75 0
|
人工智能 数据可视化 定位技术
查看选定区域Landsat数据覆盖情况
查看选定区域Landsat数据覆盖情况
|
JavaScript API
如何判断元素是否在可视区域内
如何判断元素是否在可视区域内
|
定位技术 开发工具 Android开发
百度地图开发-显示实时位置信息 04
百度地图开发-显示实时位置信息 04
172 0
百度地图开发-显示实时位置信息 04