摘要

        ArcGIS中,对于要素图层的渲染,支持按照要素字段的值渲染要素的大小,其中Graduated Symbols可以对大小进行分级渲染。在个人开发系统的过程中,也可以用来美化数据显示,加强表达。参考ArcMap中对于Graduated Symbols的实现,有助于理解和编写ArcGIS Engine的相关代码。
 

1、ArcMap中Graduated Symbols渲染的实现

        首先,在左侧图层中找到要渲染的图层,右击打开图层属性(Properties),在上方选择样式(Symbology)选项卡,在数量(Quantities)下选择Graduated Symbols。界面如下:
 

图中:A、Value表示符号大小对应的字段,Normalization(归一化)表示将Value字段进行归一化处理。B、Classification表示根据Value字段进行分级,包含分级方式(图中为NaturalBreaks)Classes为分级数量,点击右侧Classify可对Classification进行更改设置。C、Symbol Size表示符号分级的最大最小值,右方,Template点击,可对点要素的表示符号进行设置,可设置样式、颜色、大小、初始角度。D、下方的Advanced点击可选择旋转(Rotation),设置旋转的参照字段和旋转方式(Geographic为Y向起顺时针旋转,Arithmetic为X向起逆时针旋转)。渲染示例图如下:

 
 

2、ArcEngine中Graduated Symbols渲染的实现

        ArcGISEngine中,Graduated Symbols的实现依赖于IClassBreaksRenderer接口,首先需要设定分级的字段和级别数量,根据级别数量设定每一级的样式,设定该级的断点。级别数量对应于ArcMap中的Classes,断点为确定有两种方式,一是调用IClassifyGEN接口,同ArcMap中点击Classify选择相应方式,二是人工设定,同一中的manual。
 
        将IClassBreaksRenderer接口对象转换为IRotationRenderer借口对象,可以实现ArcMap中的Advanced的Rotation功能,设置旋转字段和旋转方式。
 
        (1)人工设定分级进行渲染的代码如下:
  1. public static void ArrowGraduatedRendererFlow2(IFeatureLayer pFeatureLayer, string SizeField, string RotationField)
  2. {
  3. IGeoFeatureLayer pGeoFeatureLayer = pFeatureLayer as IGeoFeatureLayer;
  4. int classCountNum=4;
  5. double[] Classes = {0.0,0.5,1.0,2.0,10.0};
  6. try
  7. {
  8. //声明分级渲染对象
  9. IClassBreaksRenderer pClassBreaksRenderer = new ClassBreaksRendererClass();
  10. pClassBreaksRenderer.Field = SizeField;
  11. pClassBreaksRenderer.BreakCount = classCountNum;
  12. for (int breakIndex = 0; breakIndex < classCountNum; breakIndex++)
  13. {
  14. IRgbColor pColor = GetRGB(225, 80, 10);
  15. ISymbol SetSymbol = SetArrowMarkSymbol(breakIndex, pColor);
  16. pClassBreaksRenderer.set_Symbol(breakIndex, SetSymbol);
  17. pClassBreaksRenderer.set_Break(breakIndex, Classes[breakIndex + 1]);
  18. }
  19. //设置符号旋转的渲染方式
  20. IRotationRenderer pRotationRenderer = (IRotationRenderer)pClassBreaksRenderer;
  21. pRotationRenderer.RotationField = RotationField;//设置旋转基准字段
  22. //pRotationRenderer.RotationType = esriSymbolRotationType.esriRotateSymbolArithmetic;//以x轴为旋转起点
  23. pRotationRenderer.RotationType = esriSymbolRotationType.esriRotateSymbolGeographic;//以y轴为旋转起点
  24. //设置图层的渲染方式
  25. pGeoFeatureLayer.Renderer = (IFeatureRenderer)pClassBreaksRenderer;
  26. }
  27. catch (Exception e)
  28. {
  29. //MessageBox.Show(e.Message);
  30. return;
  31. }
  32. }

其中:SetArrowMarkSymbol(breakIndex, pColor)函数调用了IArrowMarkerSymbol接口,定义箭头标识。

(2)Classify分级并渲染的代码如下:

  1. public static void ArrowGraduatedRendererFlow(IFeatureLayer pFeatureLayer, string SizeField, string RotationField)
  2. {
  3. IGeoFeatureLayer pGeoFeatureLayer = pFeatureLayer as IGeoFeatureLayer;
  4. ITable pTable = (ITable)pGeoFeatureLayer;
  5. IQueryFilter pQueryFilter = new QueryFilterClass();
  6. pQueryFilter.AddField("");
  7. ICursor pCursor = pTable.Search(pQueryFilter, true);
  8. //使用统计类得到最大最小值
  9. IDataStatistics pDataStatistics = new DataStatisticsClass();
  10. pDataStatistics.Cursor = pCursor;
  11. //设置统计字段
  12. pDataStatistics.Field = SizeField;
  13. //得到统计结果
  14. IStatisticsResults pStatisticsResult = pDataStatistics.Statistics;
  15. if (pStatisticsResult == null)
  16. {
  17. MessageBox.Show("属性值统计失败!");
  18. return;
  19. }
  20. int classCountNum;
  21. classCountNum = (int)((pStatisticsResult.Maximum - pStatisticsResult.Minimum) / 0.5) + 1;//将(流速)值按0.5m/s分级,得到分级级数
  22. if (classCountNum <= 0)
  23. {
  24. classCountNum = 1;
  25. }
  26. if (classCountNum >= 32)
  27. {
  28. classCountNum = 32;
  29. }
  30. double[] Classes = GetClassBreakpoints(pGeoFeatureLayer, SizeField, classCountNum);//调用函数分级
  31. try
  32. {
  33. //声明分级渲染对象
  34. IClassBreaksRenderer pClassBreaksRenderer = new ClassBreaksRendererClass();
  35. pClassBreaksRenderer.Field = SizeField;
  36. pClassBreaksRenderer.BreakCount = classCountNum;
  37. for (int breakIndex = 0; breakIndex < classCountNum; breakIndex++)
  38. {
  39. IRgbColor pColor = GetRGB(225, 80, 10);
  40. ISymbol SetSymbol = SetArrowMarkSymbol(breakIndex, pColor);
  41. pClassBreaksRenderer.set_Symbol(breakIndex, SetSymbol);
  42. pClassBreaksRenderer.set_Break(breakIndex, Classes[breakIndex + 1]);
  43. }
  44. //设置符号旋转的渲染方式
  45. IRotationRenderer pRotationRenderer = (IRotationRenderer)pClassBreaksRenderer;
  46. pRotationRenderer.RotationField = RotationField;//设置旋转基准字段
  47. //pRotationRenderer.RotationType = esriSymbolRotationType.esriRotateSymbolArithmetic;//以x轴为旋转起点
  48. pRotationRenderer.RotationType = esriSymbolRotationType.esriRotateSymbolGeographic;//以y轴为旋转起点
  49. //设置图层的渲染方式
  50. pGeoFeatureLayer.Renderer = (IFeatureRenderer)pClassBreaksRenderer;
  51. }
  52. catch (Exception e)
  53. {
  54. //MessageBox.Show(e.Message);
  55. return;
  56. }
  57. }

其中,分级采用等间距分级的代码如下:

  1. private static double[] GetClassBreakpoints(IGeoFeatureLayer pGeoFeatureLayer, string FieldName,int ClassesCount)
  2. {
  3. double[] breakPointClasses;
  4. if (pGeoFeatureLayer == null)
  5. return null;
  6. ITable pTable = (ITable)pGeoFeatureLayer;//ITable pTable = (ITable)pGeoFeatureLayer.FeatureClass;
  7. object dataValues;
  8. object dataFrequency;
  9. //从pTable的字段中得到信息给dataValues和dataFrequency两个数组
  10. ITableHistogram pTableHistogram = new BasicTableHistogramClass();
  11. pTableHistogram.Field = FieldName;
  12. pTableHistogram.Table = pTable;
  13. IBasicHistogram pHistogram = (IBasicHistogram)pTableHistogram;
  14. pHistogram.GetHistogram(out dataValues, out dataFrequency);
  15. //下面是分级方法,用于根据获得的值计算得出符合要求的数据
  16. IClassifyGEN pClassify;
  17. //根据条件计算出IClassifyGEN
  18. pClassify = new EqualIntervalClass();
  19. int tt = ClassesCount;
  20. pClassify.Classify(dataValues, dataFrequency, ref tt);
  21. //返回数组
  22. breakPointClasses = (double[])pClassify.ClassBreaks;
  23. return breakPointClasses;
  24. }

最终的渲染效果如下:

 
 from: http://blog.csdn.net/u012223164/article/details/39207369

ArcGIS Desktop和Engine中对点要素图层Graduated Symbols渲染的实现 Rotation Symbol (转)的更多相关文章

  1. Engine中如何更改矢量图层字段别名?

    [解决办法]:使用IClassSchemaEdit.AlterFieldAliasName方法可以更改数据源的别名,如果想在图层的属性中更改显示的别名需要使用ITableFields.FieldInf ...

  2. ArcGIS Engine中如何获取Map中已经选择的要素呢(转)

    ArcGIS Engine中如何获取Map中已经选择的要素呢   1.使用IEnumFeturea对象获取map中的FeatureSelection,该方法可以获取所有图层的选择要素.IMap中的Fe ...

  3. C#+ArcGIS Engine 获取地图中选中的要素

    转自 C#+ArcGIS Engine 获取地图中选中的要素 C#+ArcGIS Engine 获取地图中选中的要素 提供一种简单遍历获取地图中选中要素的方法,代码如下: List<IFeatu ...

  4. ArcGIS Engine中删除要素的几种方法总结

    转自原文 ArcGIS Engine中删除要素的几种方法总结 /// <summary> /// 通过IFeature.Delete方法删除要素 /// </summary> ...

  5. ArcGIS Engine中如何获取Map中已经选择的要素呢

    1.使用IEnumFeturea对象获取map中的FeatureSelection,该方法可以获取所有图层的选择要素.IMap中的FeatureSelection可不是IFeatureSelectio ...

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

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

  7. ArcGIS Engine中的数据访问

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

  8. ArcGIS Engine开发之旅03--ArcGIS Engine中的控件

    原文:ArcGIS Engine开发之旅03--ArcGIS Engine中的控件 制图控件,如MapControl.PageLayoutControl,其中MapControl控件主要用于地理数据的 ...

  9. ArcGIS Engine开发之旅02--ArcGIS Engine中的类库

    原文:ArcGIS Engine开发之旅02--ArcGIS Engine中的类库 System类库 System类库是ArcGIS体系结构中最底层的类库.System类库包含给构成ArcGIS的其他 ...

随机推荐

  1. 异常mongodb:Invalid BSON field name XXXXXX:YYYYY.zz

    1.本周遇到这个问题. 定位到发现一个很神奇的现象上面的结构无法顺利以map的key值存入mongodb里面. 而且到线上才发现这个问题. 而且是部分用户才会出现这样的情况 大部分人的该数据是这样的 ...

  2. python urllib和urllib3包

    urllib.request urllib当中使用最多的模块,涉及请求,响应,浏览器模拟,代理,cookie等功能. 1. 快速请求 urlopen返回对象提供一些基本方法: read 返回文本数据 ...

  3. debian修改主机名

    hostnamectl set-hostname aaa 或者 vim /etc/hostname 记得更新 /etc/hosts

  4. Avalon总线概述

    Nios系统的所有外设都是通过Avalon总线与Nios CPU相接的,Avalon总线是一种协议较为简单的片内总线,Nios通过Avalon总线与外界进行数据交换. Avalon总线接口分类 可分为 ...

  5. Oracle sqlldr数据加载

    1 sqlldr 传统路径:sqlldr会利用sql插入为我们加载数据 直接路径加载:sqlldr不适用sql,直接格式化数据块,绕开undo,避开redo,最快的方法就是并行直接路径加载 sqlld ...

  6. python开发初识函数:函数定义,返回值,参数

    一,函数的定义 1,函数mylen叫做函数名 #函数名 #必须由字母下划线数字组成,不能是关键字,不能是数字开头 #函数名还是要有一定的意义能够简单说明函数的功能 2,def是关键字 (define) ...

  7. 浏览器访问IPv6地址

    http://[IPv6]:port/index.html http://[3ffe:3201:1200:1::91]:8080/index.html 目前现在的网络运营商基本都不支持基于IPv6地址 ...

  8. Halcon学习之边缘检测函数

    sobel_amp ( Image : EdgeAmplitude : FilterType, Size : ) 根据图像的一次导数计算图像的边缘 close_edges ( Edges, EdgeI ...

  9. Mycat实战之主键数据库自增方式

    创建一个 person表,主键为Id,hash方式分片,主键自增(采用数据库方式) #person表结构如下 Id,主键,Mycat自增主键 name,字符串,16字节最长 school,毕业学校,数 ...

  10. Python基础学习四 列表、元组、字典、集合

    列表list,用中括号“[ ]”表示 1.任意对象的有序集合 列表是一组任意类型的值,按照一定顺序组合而成的 2.通过偏移读取 组成列表的值叫做元素(Elements).每一个元素被标识一个索引,第一 ...