ArcEngine批量添加XY数据
使用ArcGIS Desktop “添加XY数据”或者“创建XY事件图层”工具 可以导入Excel坐标数据,生成临时图层并添加至ArcMap、ArcGlobe或者ArcScene中。在ArcEngine中可以利用GP工具(MakeXYEventLayer)将某个 x,y 坐标表添加到地图、globe 或 scene 中。该数据表中必须包含两个字段:一个用于 x 坐标,一个用于 y 坐标。Excel表的表头最好字段放至第一行,否则会报错。原本想直接将MakeXYEventLayer创建事件图层添加至地图中,但是至今未想到方法。只有暂时生成要素类导出至磁盘中,再添加至地图中。如果高手们有其他方法,希望不吝赐教。
实现思路:
第一步:读取Excel数据表,提取表名、X字段、Y字段
第二步:实例化数据管理工具MakeXYEventLayer
第三步:实例化Geoprocessor,并执行数据管理工具MakeXYEventLayer
第四步:使用复制要素工具将此事件图层导出为磁盘上的要素类
第五步:加载要素至图层中
主要代码如下:
GP执行MakeXYEventLayer工具并复制图层至文件地理数据库中
/// <summary>
/// 执行MakeXYEventLayer工具,并将创建的临时图层转换为要素类
/// </summary>
/// <param
name="xyEventLayer">XY 事件图层tool</param>
/// <param
name="out_Layer_Path">要素输出路径</param>
/// <returns></returns>
private IFeatureClass ConvertExcelToFeatureClass(MakeXYEventLayer
xyEventLayer, string
out_Layer_Path)
{
try
{
Geoprocessor GP = new Geoprocessor();
GP.OverwriteOutput =
true;
GP.Execute(xyEventLayer, null);//执行XY事件
//复制要素
ESRI.ArcGIS.DataManagementTools.CopyFeatures cf = new ESRI.ArcGIS.DataManagementTools.CopyFeatures();
cf.in_features =
xyEventLayer.out_layer;
cf.out_feature_class
= out_Layer_Path + xyEventLayer.out_layer;
IGeoProcessorResult
gpResult = GP.Execute(cf, null) as IGeoProcessorResult;
IFeatureClass
_featureClass;
IQueryFilter qf;//查询过滤
IGPUtilities gpUtils
= new
GPUtilitiesClass();
gpUtils.DecodeFeatureLayer(gpResult.GetOutput(0), out _featureClass, out qf);
IFeatureCursor
cursor = featureClass.Insert(true);
return _featureClass;
}
catch (Exception ex)
{
MessageBox.Show("导入要素失败,原因:" + ex.ToString());
return null;
}
}
调用方法,并将要素添加至地图中
//比如Excel文件:大学校区.xls,表包括(sheet1,sheet2,sheet2)
//tableName即表路径,该路径形式例如:D:\\DataFile\\大学校区.xls\\sheet1$
tableName =
m_fileName + "\\" + comtxt_excel.SelectedItem.ToString();
x = comtxt_x.SelectedItem.ToString();//X坐标
y = comtxt_y.SelectedItem.ToString();//Y坐标
outName =
txt_layername.Text;
//添加XY事件
MakeXYEventLayer
MxyLayer = new MakeXYEventLayer(tableName, x, y, outName);
string tempPath =
GetAppDirectory() + "TempData\\Temp.gdb\\";//要素临时存储路径
featureClass =
ConvertExcelToFeatureClass(MxyLayer, tempPath);
if (featureClass != null)
{
pFeatureLater =
new FeatureLayerClass();
pFeatureLater.FeatureClass = featureClass;
pFeatureLater.Name = featureClass.AliasName;
axMapControl1.Map.AddLayer(pFeatureLater as ILayer);
axMapControl1.Extent = axMapControl1.FullExtent;
}
ArcEngine批量添加XY数据的更多相关文章
- ASP.NET MVC用存储过程批量添加修改数据
用Entity Framework 进行数据库交互,在代码里直接用lamda表达式和linq对数据库操作,中间为程序员省去了数据库访问的代码时间,程序员直接可以专注业务逻辑层的编写.但是对于比较复杂的 ...
- spring MVC 后端 接收 前端 批量添加的数据(简单示例)
第一种方式:(使用ajax的方式) 前端代码: <%@ page contentType="text/html;charset=UTF-8" language="j ...
- mysql+php+pdo批量添加大数据
1.使用insert into插入 ini_set('max_execution_time','0');//限制超时时间,因为第一种时间较长,索性设为0不限制 $pdo = new PDO(" ...
- Arcgis10.3在添加XY数据时出现问题
准备通过excel表格(xls格式)中的经纬度生成点数据,但是选择数据的时候报错:连接到数据库失败,常规功能故障,外部表不是预期的格式.如下图所示: 解决方法: 将xls格式的表格另存为csv格式,重 ...
- 前端JS批量添加校验数据唯一性
<script type="text/javascript"> //维护删除数组中的某一项 Array.prototype.remove = function(val) ...
- CI 框架批量添加数据(如果数据库有就更新数据)
model: public function insert_select($values) { $sql = 'INSERT INTO ' . $this->_table_name . '(ar ...
- mybatis 批量将list数据插入到数据库
随着业务需要,有时我们需要将数据批量添加到数据库,mybatis提供了将list集合循环添加到数据库的方法.具体实现代码如下: 1.mapper层中创建 insertForeach(List < ...
- myBatis批量添加实例
<!-- 批量添加中转地数据 --> <insert id="addBatch" parameterType="com.isoftstone. ...
- EF批量添加数据性能慢的问题的解决方案
//EF批量添加数据性能慢的问题的解决方案 public ActionResult BatchAdd() { using (var db = new ToneRoad.CEA.DbContext.Db ...
随机推荐
- java如何区分是form表单请求,还是ajax请求
requestType = request.getHeader("X-Requested-With"); if(requestType==null) ...
- XML中& <> 单引号' 双引号 " 报错
由于xml中 这些字符是特殊字符,所以把&改成& 就行了 ,注意后面一定要带一个分号; < < 小于号> > ...
- Linux Mint安装jdk8
想到研究Java,可能学习openjdk是比较好的方式,于是去找openjdk.对于Debian based系统的安装指南是: -jdk 然而我的Linux Mint 17却无法安装.搜索之后发现如下 ...
- NDK问题总结
转自 这篇文章中很多东西!!:http://blog.chinaunix.net/uid-20746260-id-3910616.html 1. 创建JNI头文件 在工程目录下输入: javah -c ...
- 修改目的端trail文件的最大大小--转载
本文为原创,转载请注明出处: http://blog.csdn.net/msdnchina/article/details/38346435 修改目的端trail文件的最大大小. 本文产生的背景: 在 ...
- SimpleThreadPool实践
前言 并发(Concurrency)一直谈论java绕不开的一个话题,从移动开发工程师到后端工程师,几乎所有的面试都要涉及到并发/多线程的一些问题.虽然多数时候我们使用线程池,都是已经实现好的框架—— ...
- 4、IMS
链:1:http://www.cnblogs.com/gnuhpc/archive/2012/12/11/2813494.html [笔记] 1.<计算机网络(第五版)>P10-15:电路 ...
- JAVA 多线程和并发学习笔记(四)
1. 多进程 实现并发最直接的方式是在操作系统级别使用进程,进程是运行在它自己的地址空间内的自包容的程序.多任务操作系统可以通过周期性地将CPU从一个进程切换到另一个进程,来实现同时运行多个进程. 尽 ...
- 扩展easyui.datagrid,添加数据loading遮罩效果代码 --来自网摘收集
//jquery.datagrid 扩展 (function (){ $.extend($.fn.datagrid.methods, { //显示遮罩 loading: function(jq){ r ...
- leetcode6:Zigzag Conversion@Python
The string "PAYPALISHIRING" is written in a zigzag pattern on a given number of rows like ...