1. IWorkspaceFactory pShpWksFact = new ShapefileWorkspaceFactory();
  2. IFeatureWorkspace pFeatWks;
  3. pFeatWks = (IFeatureWorkspace)pShpWksFact.OpenFromFile(filePath, 0);
  4. const
    string strShapeFieldName = "Shape";
  5. //定义属性字段
  6. IFields pFields = new Fields();
  7. IFieldsEdit pFieldsEdit;
  8. pFieldsEdit = pFields as IFieldsEdit;
  9. IField pField = new Field();
  10. IFieldEdit pFieldEdit = new Field() as IFieldEdit;
  11. pFieldEdit.Name_2 = strShapeFieldName;
  12. pFieldEdit.Type_2 = esriFieldType.esriFieldTypeGeometry;
  13. pField = pFieldEdit as IField;
  14. //定义几何属性
  15. IGeometryDef pGeomDef = new GeometryDef();
  16. IGeometryDefEdit pGeomDefEdit = new GeometryDef() as IGeometryDefEdit;
  17. pGeomDefEdit = pGeomDef as IGeometryDefEdit;
  18. switch (shpTypeComboBox.Text)
  19. {
  20.     case "Point":
  21.         pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPoint;
  22.         break;
  23.     case "Polyline":
  24.         pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
  25.         break;
  26.     case "Polygon":
  27.         pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolygon;
  28.         break;
  29. }
  30.  
  31. pGeomDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
  32. pGeomDefEdit.SpatialReference_2 = new UnknownCoordinateSystem() as ISpatialReference;
  33. pFieldEdit.GeometryDef_2 = pGeomDef;
  34. pFieldsEdit.AddField(pField);
  35. pFields = pFieldsEdit as IFields;
  36. IFeatureClass pFeatureClass;
  37. pFeatureClass = pFeatWks.CreateFeatureClass(fileName, pFields, null, null,
  38.     esriFeatureType.esriFTSimple, strShapeFieldName, "");
  39. //添加属性字段
  40. for (int i = 0; i < addFieldListBox.Items.Count; i++)
  41. {
  42.     IField pfield = new Field();
  43.     IFieldEdit pfieldEdit = new Field() as IFieldEdit;
  44.     pfieldEdit.Name_2 = addFieldListBox.Items[i].ToString();
  45.     pfieldEdit.Type_2 = esriFieldType.esriFieldTypeString;
  46.     pfield = pfieldEdit as IField;
  47.     pFeatureClass.AddField(pfield);
  48. }
  49. //绘制线
  50. IFeatureClassWrite fr = pFeatureClass as IFeatureClassWrite;
  51. IWorkspaceEdit w = (pFeatureClass as IDataset).Workspace as IWorkspaceEdit;
  52. IFeature f;
  53. //可选参数的设置
  54. object Missing = Type.Missing;
  55. IPoint p = new PointClass();
  56. w.StartEditing(true);
  57. w.StartEditOperation();
  58. //定义一个多义线对象
  59. IPolyline PlyLine = new PolylineClass();
  60. //定义一个点的集合
  61. IPointCollection ptclo = PlyLine as IPointCollection;
  62. ISpatialReferenceFactory spatialReferenceFactory = new SpatialReferenceEnvironmentClass();
  63. ISpatialReference spatialReference = spatialReferenceFactory.CreateGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_WGS1984);
  64. for (int i = 0; i < excelDataGridViewX.Rows.Count - 1; i++)
  65. {
  66.     f = pFeatureClass.CreateFeature();
  67.  
  68.     DataGridViewRow dataRow = excelDataGridViewX.Rows[i];
  69.     double pointX, pointY;
  70.     pointX = double.Parse(dataRow.Cells[xComboBoxEx.Text].Value.ToString());
  71.     pointY = double.Parse(dataRow.Cells[yComboBoxEx.Text].Value.ToString());
  72.     p.PutCoords(pointX,pointY);
  73.     ptclo.AddPoint(p, ref Missing, ref Missing);
  74.     for (int j = 0; j < addFieldListBox.Items.Count; j++)
  75.     {
  76.         string fieldName = addFieldListBox.Items[j].ToString();
  77.         f.set_Value(f.Fields.FindField(fieldName),
  78.             dataRow.Cells[fieldName].Value.ToString());
  79.     }
  80.     IPolyline ppolyline = new PolylineClass();
  81.     ppolyline = (IPolyline)ptclo;
  82.     ppolyline.SpatialReference = spatialReference;
  83.     f.Shape = ppolyline;
  84.     fr.WriteFeature(f);
  85. }
  86.  
  87. //f.Store();
  88.  
  89. w.StopEditOperation();
  90. w.StopEditing(true);
  91. //添加新建的数据至Map中
  92. axMapControl.AddShapeFile(filePath, fileName);
  93. //this.Hide();

Excel坐标点转线的更多相关文章

  1. arcmap坐标点生成线和面(更正版)

    一:本博客的脉络 (1 )做了例如以下更正:之前在网上搜到的结果是:arcmap坐标点生成线和面 ------ 注意该功能在ArcGIS10中没有了,当时自己也没有多想就转载了,再此做一下更正或者叫做 ...

  2. Html报表用Excel打开保持表格线【Html报表模板】

    注:本人调试的最简版,前两处红色部分是为了输出Excel表格线:x:str表示输出为文本样式,避免被输出为科学计数法. <!DOCTYPE html PUBLIC "-//W3C//D ...

  3. 使用Windows驱动的虚拟打印机,打印Excel表格无表格线问题解决(2)

    测试: 经前天的测试,最终还是没有明显的定夺到底是驱动的问题,还是打印机的问题.但是按照可能性来排查,最明显的一点就是其他测试环境不变的情况下增加一张图片,就可以打印出表格线,我始终觉得这里是突破点, ...

  4. Excel坐标自动在AutoCad绘图_6

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  5. Excel坐标自动在AutoCad绘图_5

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  6. Excel坐标自动在AutoCad绘图_4

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  7. Excel坐标自动在AutoCad绘图_3

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  8. Excel坐标自动在AutoCad绘图_2

    众所周知,Excel对数据处理的功能非常强大,它可以进行数据处理.统计分析已经辅助决策的操作,该软件已经渗透到各个领域.作为一个测绘人,GISer, 也经常利用excel完成一些测量表格的自动化计算, ...

  9. 【题解】洛谷P1169 [ZJOI2007] 棋盘制作(坐标DP+悬线法)

    次元传送门:洛谷P1169 思路 浙江省选果然不一般 用到一个从来没有听过的算法 悬线法: 所谓悬线法 就是用一条线(长度任意)在矩阵中判断这条线能到达的最左边和最右边及这条线的长度 即可得到这个矩阵 ...

随机推荐

  1. retrying模块的安装及使用

    安装retrying模块: win10用户在联网的情况下直接在cmd.exe里面键入"pip install retrying"  即可安装retrying模板 在网页正常浏览的过 ...

  2. 洛谷P2826 LJJ的数学课

    题目背景 题目描述(本题是提高组第二题难度+) 题目描述 \(LJJ\)又要开始上数学课啦!(\(T1\),永恒不变的数学) \(LJJ\)的\(Teacher\)对上次的考试很不满意(其实是出题人对 ...

  3. idea dao使用@Mapper注解 业务类使用@Autowired 注入dao 爆红问题

    实际项目跑起来无影响,但是看起来不太爽. 可以在dao类添加org.springframework.stereotype.Repository 注解 或者可以在service类中使用 javax.an ...

  4. HDU - 5920 Ugly Problem 求解第一个小于n的回文数

    http://acm.hdu.edu.cn/showproblem.php?pid=5920 http://www.cnblogs.com/xudong-bupt/p/4015226.html 把前半 ...

  5. 下载安装MariaDB Galera 10.1

    因为无法访问外网, 配置官网的yum无法下载MariaDB Galera(在MariaDB 10.1 及之后内置了Galera, 不像之前那样需要独立安装) 需要在下载的包 MariaDB-10.1. ...

  6. android 开发-spinner下拉框控件的实现

    Android提供实现下拉框功能的非常实用的控件Spinner. spinner控件需要向xml资源文件中添加spinner标签,如下: <Spinner android:id="@+ ...

  7. Java基础反射-调用类

    Student类 package com.test.wang; import java.lang.reflect.Constructor; import java.lang.reflect.Field ...

  8. magento新增商品属性以及将属性加入Flat table

    magento的EAV模型非常强大且灵活,但是如果不做优化的话,性能会非常低,因为attributes都存放在附表里,要获取一个entity的attribute,需要表联结一次,如果需要获取多条att ...

  9. Fiddler 抓包工具总结(转)

    Fiddler 抓包工具总结   阅读目录 1. Fiddler 抓包简介 1). 字段说明 2). Statistics 请求的性能数据分析 3). Inspectors 查看数据内容 4). Au ...

  10. NumPy(数组计算)

    一.介绍 NumPy是高性能科学计算和数据分析的基础包.它是pandas等其他各种工具的基础. 1.主要功能 1)ndarray,一个多维数组结构,高效且节省空间2)无需循环对整组数据进行快速运算的数 ...