Excel坐标点转线
- IWorkspaceFactory pShpWksFact = new ShapefileWorkspaceFactory();
- IFeatureWorkspace pFeatWks;
- pFeatWks = (IFeatureWorkspace)pShpWksFact.OpenFromFile(filePath, 0);
- const
string strShapeFieldName = "Shape"; - //定义属性字段
- IFields pFields = new Fields();
- IFieldsEdit pFieldsEdit;
- pFieldsEdit = pFields as IFieldsEdit;
- IField pField = new Field();
- IFieldEdit pFieldEdit = new Field() as IFieldEdit;
- pFieldEdit.Name_2 = strShapeFieldName;
- pFieldEdit.Type_2 = esriFieldType.esriFieldTypeGeometry;
- pField = pFieldEdit as IField;
- //定义几何属性
- IGeometryDef pGeomDef = new GeometryDef();
- IGeometryDefEdit pGeomDefEdit = new GeometryDef() as IGeometryDefEdit;
- pGeomDefEdit = pGeomDef as IGeometryDefEdit;
- switch (shpTypeComboBox.Text)
- {
- case "Point":
- pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPoint;
- break;
- case "Polyline":
- pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
- break;
- case "Polygon":
- pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolygon;
- break;
- }
- pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
- pGeomDefEdit.SpatialReference_2 = new UnknownCoordinateSystem() as ISpatialReference;
- pFieldEdit.GeometryDef_2 = pGeomDef;
- pFieldsEdit.AddField(pField);
- pFields = pFieldsEdit as IFields;
- IFeatureClass pFeatureClass;
- pFeatureClass = pFeatWks.CreateFeatureClass(fileName, pFields, null, null,
- esriFeatureType.esriFTSimple, strShapeFieldName, "");
- //添加属性字段
- for (int i = 0; i < addFieldListBox.Items.Count; i++)
- {
- IField pfield = new Field();
- IFieldEdit pfieldEdit = new Field() as IFieldEdit;
- pfieldEdit.Name_2 = addFieldListBox.Items[i].ToString();
- pfieldEdit.Type_2 = esriFieldType.esriFieldTypeString;
- pfield = pfieldEdit as IField;
- pFeatureClass.AddField(pfield);
- }
- //绘制线
- IFeatureClassWrite fr = pFeatureClass as IFeatureClassWrite;
- IWorkspaceEdit w = (pFeatureClass as IDataset).Workspace as IWorkspaceEdit;
- IFeature f;
- //可选参数的设置
- object Missing = Type.Missing;
- IPoint p = new PointClass();
- w.StartEditing(true);
- w.StartEditOperation();
- //定义一个多义线对象
- IPolyline PlyLine = new PolylineClass();
- //定义一个点的集合
- IPointCollection ptclo = PlyLine as IPointCollection;
- ISpatialReferenceFactory spatialReferenceFactory = new SpatialReferenceEnvironmentClass();
- ISpatialReference spatialReference = spatialReferenceFactory.CreateGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_WGS1984);
- for (int i = 0; i < excelDataGridViewX.Rows.Count - 1; i++)
- {
- f = pFeatureClass.CreateFeature();
- DataGridViewRow dataRow = excelDataGridViewX.Rows[i];
- double pointX, pointY;
- pointX = double.Parse(dataRow.Cells[xComboBoxEx.Text].Value.ToString());
- pointY = double.Parse(dataRow.Cells[yComboBoxEx.Text].Value.ToString());
- p.PutCoords(pointX,pointY);
- ptclo.AddPoint(p, ref Missing, ref Missing);
- for (int j = 0; j < addFieldListBox.Items.Count; j++)
- {
- string fieldName = addFieldListBox.Items[j].ToString();
- f.set_Value(f.Fields.FindField(fieldName),
- dataRow.Cells[fieldName].Value.ToString());
- }
- IPolyline ppolyline = new PolylineClass();
- ppolyline = (IPolyline)ptclo;
- ppolyline.SpatialReference = spatialReference;
- f.Shape = ppolyline;
- fr.WriteFeature(f);
- }
- //f.Store();
- w.StopEditOperation();
- w.StopEditing(true);
- //添加新建的数据至Map中
- axMapControl.AddShapeFile(filePath, fileName);
- //this.Hide();
Excel坐标点转线的更多相关文章
- arcmap坐标点生成线和面(更正版)
一:本博客的脉络 (1 )做了例如以下更正:之前在网上搜到的结果是:arcmap坐标点生成线和面 ------ 注意该功能在ArcGIS10中没有了,当时自己也没有多想就转载了,再此做一下更正或者叫做 ...
- Html报表用Excel打开保持表格线【Html报表模板】
注:本人调试的最简版,前两处红色部分是为了输出Excel表格线:x:str表示输出为文本样式,避免被输出为科学计数法. <!DOCTYPE html PUBLIC "-//W3C//D ...
- 使用Windows驱动的虚拟打印机,打印Excel表格无表格线问题解决(2)
测试: 经前天的测试,最终还是没有明显的定夺到底是驱动的问题,还是打印机的问题.但是按照可能性来排查,最明显的一点就是其他测试环境不变的情况下增加一张图片,就可以打印出表格线,我始终觉得这里是突破点, ...
- Excel坐标自动在AutoCad绘图_6
众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...
- Excel坐标自动在AutoCad绘图_5
众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...
- Excel坐标自动在AutoCad绘图_4
众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...
- Excel坐标自动在AutoCad绘图_3
众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...
- Excel坐标自动在AutoCad绘图_2
众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...
- 【题解】洛谷P1169 [ZJOI2007] 棋盘制作(坐标DP+悬线法)
次元传送门:洛谷P1169 思路 浙江省选果然不一般 用到一个从来没有听过的算法 悬线法: 所谓悬线法 就是用一条线(长度任意)在矩阵中判断这条线能到达的最左边和最右边及这条线的长度 即可得到这个矩阵 ...
随机推荐
- Java Script 第二章.
对象: JavaScript中的所有事物都是对象:字符串,数组,数值,函数..... JavaScript中提供多个内建对象,比如说 String, Date, Array等等.对象只是带有属性和 ...
- PAT天梯赛L2-007 家庭房产
题目链接:点击打开链接 给定每个人的家庭成员和其自己名下的房产,请你统计出每个家庭的人口数.人均房产面积及房产套数. 输入格式: 输入第一行给出一个正整数N(<=1000),随后N行,每行按下列 ...
- tp5分页注意,分页生成的ul class是pagination,有些模板可能将pagination定义为display:none
今天在调用分页时总是无法显示,查看网页源代码是正常的,后来发现是在css文件里将pagination定义为display:none,所以无法显示
- CDN-内容发布网络
整理<CDN技术详解>一书中重要的内容. 互联网与万维网 广义的互联网,由两层组成:一层是以TCP/IP为代表的网络层:另一层是以万维网WWW为代表的应用层.辨识互联网和万维网的区别,是认 ...
- QPS,TPS,吞吐量,响应时间详解及关系
并发数 并发数是指系统同时能处理的请求数量,这个也是反应了系统的负载能力 吞吐量吞吐量是指单位时间内系统能处理的请求数量,体现系统处理请求的能力,这是目前最常用的性能测试指标 响应时间RT(Respo ...
- State模式(状态设计模式)
State??? State模式中,我们用类来表示状态.以类来表示状态后,我们就能通过切换类来方便地改变对象的状态.当需要增加新的状态时,如何修改代码这个问题也会很明确. 直接用状态代替硬编码 依赖于 ...
- html5 替换 历史 记录
history.replaceState({url:"/admin/index"},null,"/admin/index"); url 是 需要替换的路径
- python3——“->”的含义
->:标记返回函数注释,信息作为.__annotations__属性提供,__annotations__属性是字典.键return是用于在箭头后检索值的键.但是在Python中3.5,PEP 4 ...
- 最小生成树(prim算法和kruskal算法)
学习博客:https://www.cnblogs.com/zhangming-blog/p/5414514.html 其实就是加点法:从不属于这个集合的点中找从本集合可以找到的最小边,加入本集合 看代 ...
- Solr7.x介绍安装和配置(单机版)
之前学的是4.x,然后一看官网,奶奶的都7.x了.于是查了一番资料..... 1)下载和安装 wget http://mirror.bit.edu.cn/apache/lucene/solr/7.3. ...