转自原文ArcGIS Engine 编辑- ITask

下面的代码是我们定制的一个工作流-给等高线赋值

namespace EngineApplication

{

[Guid("5b0c0692-eaf7-4d64-9cee-c8c1afaf06f4")]

[ClassInterface(ClassInterfaceType.None)]

[ProgId("EditeTest.ContourTask")]

public class CalculateContour : ESRI.ArcGIS.Editor.IEditTask

{

#region

IEditor pEngineEditor;

IEditSketch pEditSketch;

IEditLayers pEditLayer;

#endregion

#region "IEditTask Implementations"

public void Activate(IEditor pEditor, ESRI.ArcGIS.Editor.IEditTask pEditTask)

{

if (pEditor == null)

return;

pEngineEditor = pEditor;

pEditSketch = pEngineEditor as IEditSketch;

pEditSketch.GeometryType = esriGeometryType.esriGeometryPolyline;

pEditLayer = pEditSketch as IEditLayers;

//Listen to engine editor events

((IEngineEditEvents_Event)pEditSketch).OnTargetLayerChanged += new IEngineEditEvents_OnTargetLayerChangedEventHandler(OnTargetLayerChanged);

((IEngineEditEvents_Event)pEditSketch).OnCurrentTaskChanged += new IEngineEditEvents_OnCurrentTaskChangedEventHandler(OnCurrentTaskChanged);

}

public void Deactivate()

{

// TODO: Add ArcGISClass1.Deactivate implementation

pEditSketch.RefreshSketch();

//Stop listening to engine editor events.

((IEngineEditEvents_Event)pEditSketch).OnTargetLayerChanged -= OnTargetLayerChanged;

((IEngineEditEvents_Event)pEditSketch).OnCurrentTaskChanged -= OnCurrentTaskChanged;

//Release object references.

pEngineEditor = null;

pEditSketch = null;

pEditLayer = null;

}

public string Name

{

get

{

// TODO: Add ArcGISClass1.Name getter implementation

return "ContourTask";

}

}

public string UniqueName

{

get

{

return "ContourTask";

}

}

public string GroupName

{

get

{

//This property allows groups to be created/used in the EngineEditTaskToolControl treeview.

//If an empty string is supplied the task will be appear in an "Other Tasks" group.

//In this example the Reshape Polyline_CSharp task will appear in the existing Modify Tasks group.

return "Other Tasks";

}

}

public void OnDeleteSketch()

{

// TODO: Add ArcGISClass1.OnDeleteSketch implementation

}

public void OnFinishSketch()

{

// TODO: Add ArcGISClass1.OnFinishSketch implementation

//get reference to featurelayer being edited

IFeatureLayer pFeatureLayer = pEditLayer.CurrentLayer as IFeatureLayer;

//get reference to the sketch geometry

IGeometry pPolyline = pEditSketch.Geometry;

if (pPolyline.IsEmpty == false)

{

ParaSetting pFormSetting = new ParaSetting(pFeatureLayer.FeatureClass);

pFormSetting.ShowDialog();

if (pFormSetting.DialogResult == DialogResult.OK)

{

pHeightName = pFormSetting.pFieldNames.Text;

pHeight = Convert.ToDouble(pFormSetting.dHeight.Text);

pInterval = Convert.ToDouble(pFormSetting.dInterval.Text);

pFormSetting.Dispose();

pFormSetting = null;

IFeatureCursor pFeatureCursor = GetFeatureCursor(pPolyline, pFeatureLayer.FeatureClass);

CalculateIntersect(pFeatureCursor, pPolyline);

MessageBox.Show("OK");

}

}

//refresh the display

IActiveView pActiveView = pEngineEditor.Map as IActiveView;

pActiveView.PartialRefresh(esriViewDrawPhase.esriViewGeography, (object)pFeatureLayer, pActiveView.Extent);

}

private IFeatureCursor GetFeatureCursor(IGeometry pGeometry, IFeatureClass pFeatureClass)

{

//空间过虑器的创建

ISpatialFilter pSpatialFilter = new SpatialFilter();

pSpatialFilter.Geometry = pGeometry;

//空间过虑器几何体实体

//空间过虑器参照系

//空间过虑器空间数据字段名

pSpatialFilter.GeometryField = pFeatureClass.ShapeFieldName;

//空间过虑器空间关系类型

pSpatialFilter.SpatialRel = esriSpatialRelEnum.esriSpatialRelIntersects;

//相交

IFeatureCursor pFeatureCursor = pFeatureClass.Search(pSpatialFilter, false);

return pFeatureCursor;

}

//起始等高线值

private double pHeight;

//等高线间距

private double pInterval;

//高程字段名

private string pHeightName;

private void CalculateIntersect(IFeatureCursor pFeatureCursor, IGeometry Geometry)

{

//要素游标

IMultipoint pIntersectionPoints = null;

//多点

IPointCollection pPointColl = null;

List<IFeature> pFeatureList = new List<IFeature>();

//和直线相交的要素集合,未排序

double[,] pIndex = null;

//距离和初始索引

if (pFeatureCursor == null)

{

return;

}

ITopologicalOperator pTopoOperator = Geometry as ITopologicalOperator;

IPointCollection pSketchPointColl = Geometry as IPointCollection;

//所画直线的起点

IPoint P0 = pSketchPointColl.get_Point(0);

IFeature pFeature = pFeatureCursor.NextFeature();

double HValue = 0;

int FldIndex = 0;

pFeatureList.Clear();

while ((pFeature != null))

{

//和直线相交的要素集合

pFeatureList.Add(pFeature);

//

pFeature = pFeatureCursor.NextFeature();

}

//此时pFeatureL中的等值线并不是按顺序(空间)排列,需要排序

//求出各交点到直线起点距离

int pCount = pFeatureList.Count;

pIndex = new double[2, pCount];

for (int i = 0; i <= pCount - 1; i++)

{

try

{

pFeature = pFeatureList[i];

//求交点:

pIntersectionPoints = pTopoOperator.Intersect(pFeature.Shape, esriGeometryDimension.esriGeometry0Dimension) as IMultipoint;

pPointColl = pIntersectionPoints as IPointCollection;

//QI

//原来序号

pIndex[0, i] = i;

//距离

pIndex[1, i] = GetDistace(P0, pPointColl.get_Point(0));

//下个要素

pFeature = pFeatureCursor.NextFeature();

}

catch (Exception e)

{

MessageBox.Show(e.ToString());

}

}

//排序:将和直线相交的等直线按与起点的距离排序,冒泡法

for (int i = 0; i <= pCount - 1; i++)

{

for (int j = i + 1; j <= pCount - 1; j++)

{

if (pIndex[1, j] < pIndex[1, i])

{

double pTempindex = pIndex[0, i];

pIndex[0, i] = pIndex[0, j];

pIndex[0, j] = pTempindex;

//交换索引

double pTemp = pIndex[1, i];

pIndex[1, i] = pIndex[1, j];

pIndex[1, j] = pTemp;

//交换距离

}

}

}

//开始高程赋值

HValue = pHeight;

try

{

for (int i = 0; i <= pCount - 1; i++)

{

pFeature = pFeatureList[i];

//获取高程字段的索引

FldIndex = pFeature.Fields.FindField(pHeightName);

//高程赋值

pFeature.set_Value(FldIndex, HValue as object);

//要素更新

pFeature.Store();

//Get the next feature and next H

HValue = HValue + pInterval;

}

}

catch (Exception e)

{

MessageBox.Show(e.ToString());

}

}

/// <summary>

/// 获取我们画的线和等高线之间的距离

/// </summary>

/// <param name="pPoint1"></param>

/// <param name="pPoint2"></param>

/// <returns></returns>

private double GetDistace(IPoint pPoint1, IPoint pPoint2)

{

return (pPoint1.X - pPoint2.X) * (pPoint1.X - pPoint2.X) + (pPoint1.Y - pPoint2.Y) * (pPoint1.Y - pPoint2.Y);

}

#endregion

public void OnTargetLayerChanged()

{

PerformSketchToolEnabledChecks();

}

void OnCurrentTaskChanged()

{

if (pEngineEditor.CurrentTask.Name == "CalculateContourTask")

{

PerformSketchToolEnabledChecks();

}

}

private void PerformSketchToolEnabledChecks()

{

if (pEditLayer == null)

return;

//Only enable the sketch tool if there is a polyline target layer.

if (pEditLayer.CurrentLayer.FeatureClass.ShapeType != esriGeometryType.esriGeometryPolyline)

{

pEditSketch.GeometryType = esriGeometryType.esriGeometryNull;

return;

}

pEditSketch.GeometryType = esriGeometryType.esriGeometryPolyline;

}

}

}

效果如下:

task2

ArcGIS Engine 编辑- ITask的更多相关文章

  1. ArcGIS Engine 编辑介绍

    转自原文 ArcGIS Engine 编辑介绍 IWorkspaceEdit接口是ArcGIS Engine 实现空间数据编辑的重要接口,它让程序启动或者停止一个编辑流程,在这个编辑流程内,可以对数据 ...

  2. ArcGIS Engine 编辑- IWorkspaceEdit

    转自原文 ArcGIS Engine 编辑- IWorkspaceEdit 这个例子中,我创建了1000条要素,并结合缓冲将数据写到文件中,并且添加了时间统计,当然数据是我捏造的,还请原谅,这个花费的 ...

  3. ArcGIS Engine 中的绘制与编辑

    1.线段绘制 基本步骤 构建形状 1. 创建 IPoint IPoint m_Point = new PointClass(); m_Point.PutCoords(x, y); 2. 创建 IPoi ...

  4. ArcGIS Engine开发之地图基本操作(4)

    ArcGIS Engine开发中数据库的加载 1.加载个人地理数据库数据 个人地理数据库(Personal Geodatabase)使用Miscrosoft Access文件(*.mdb)进行空间数据 ...

  5. ArcGIS Engine开发前基础知识(1)

    ArcGIS二次开发是当前gis领域的一项重要必不可少的技能.下面介绍它的基本功能 一.ArcGIS Engine功能 在使用之前首先安装和部署arcgis sdk,(在这里不在赘述相关知识)可以实现 ...

  6. 转-ArcGIS Engine许可初始化

    关于初始化Engine许可的,其实原理都很简单,大家一般都没有问题,但又往往会因为不够细心加上Engine的“小脾气”,让不少程序员都要在这里犯错. 以Engine9.2为例,应用程序是强制初始化许可 ...

  7. 转-ArcGIS Engine中的License设置

    AE开发中的License有两种方法进行设置,一种是通过LicenseControl控件,另一种是通过IAoInitialize接口设置.整个应用程序中只能有一种方式存在,如果进行了两种License ...

  8. ArcGIS Engine中的8种数据访问 (转)

    数据是GIS的基础, 访问数据也是进行任何复杂的空间分析及空间可视化表达的前提.ArcGIS支持的数据格式比较丰富,对不同的数据格式支持的程度也有很大差异.本文主要介绍一下以下八种数据格式在ArcGI ...

  9. ArcGIS Engine中的数据访问

    ArcGIS Engine中的数据访问 数据是GIS的基础, 访问数据也是进行任何复杂的空间分析及空间可视化表达的前提.ArcGIS支持的数据格式比较丰富,对不同的数据格式支持的程度也有很大差异.本文 ...

随机推荐

  1. Vue的学习--环境配置

    1.  下载vue.min.js或者使用CDN 2.  安装Vue-cli环境 我在window7 32位下使用命令行cmd进行的操作 安装之前应该使用node -v和npm -v检查一下node和n ...

  2. Django项目之Web端电商网站的实战开发(二)

    说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家! 接着上一篇博客继续往下写 :https://blog.csdn.net/qq_41782425/article/details/8 ...

  3. python处理文件

    打开文件:     open是内建函数,一个方法 open("test.txt","r",buffering=1) test.txt 表示被打开的文件名,如果不 ...

  4. STM32 之ADC单次转换模式和连续转换模式

    一.背景 在STM32中的AD的单通道采样中可以设置成单次转换模式和连续转换模式,如何理解这两个转换模式的区别,通过程序又是怎样实现的? 二.正文 首先理解单次转换模式,即ADC进行单次转换(单样本) ...

  5. SQLITE数据表主键设置Id自增方法

    SQLITE数据表主键设置Id自增方法 标签: sqliteintegerinsertnulltableapi 2010-01-12 08:39 35135人阅读 评论(8) 收藏 举报  分类: S ...

  6. Mysql多实例安装+主从复制+读写分离 -学习笔记

    Mysql多实例安装+主从复制+读写分离 -学习笔记 .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px ...

  7. 关于后台接收参数为null的问题之ajax--contentType

    ajax方法中的参数: contentType:发送至服务器时内容的编码类型,一般默认:application/x-www-form-urlencoded(适应大多数的场合) dataType:预期服 ...

  8. 《从零開始学Swift》学习笔记(Day 59)——代码排版

    原创文章,欢迎转载.转载请注明:关东升的博客 代码排版包括: 空行.空格.断行和缩进等内容.代码排版内容比較多工作量非常多.可是非常重要. 空行 空行将逻辑相关的代码段分隔开.以提高可读性. 下列情况 ...

  9. Android 一个异步SocketHelper

    发送流程:首先定义一个缓冲池,发送数据时仅仅是将待发送的数据加入到缓冲池中,再由后台的工作线程从缓冲池中取得待发送数据进行发送.可能某些情况下在数据发送完成时需要做一些处理(比如写日志),便定义了一个 ...

  10. Java核心技术 卷Ⅰ 基础知识(3)

    第五章 继承 继承已存在的类就是复用这些类的方法和域.反射是指在程序运行期间发现更多的类及其属性的能力. . 反射 . 使用反射编写泛型数组代码 继承设计的技巧