1.算法功能简介

  栅格数据矢量化较为复杂,如果由一幅扫描的数字化地图来建立矢量数据库,则需要经过数字图象处理,如边缘增强、细化、二值化、特征提取及模式识别才能获得矢量数据.人们通常将多色地图分色后逐个元素(如等高线地貌、水系、道路网、地物、符号与注记等)加以识别和提取.如果将数字影像矢量化,则需要事先做好重采样、图象处理、影像匹配和影像理解等过程,才能将影像上的语义和非语义信息提取出来,并形成矢量形式的数据

  PIE支持栅格矢量化算法功能的执行,下面对该算法功能进行介绍。

2.算法功能实现说明

2.1 实现步骤

第一步

算法参数设置

第二步

算法执行

第三步

结果显示

2.2 算法参数

算法名称

栅格矢量化

C#算法DLL

PIE.CommonAlgo.dll

C#算法名称

PIE.CommonAlgo.RasterToVectorAlgo

参数结构体

RasterVectorization_Exchange_Info

参数说明

pchrasterIndexImgPath

String

索引图路径、即输入的影像路径

indexList

IList<Int>

类别列表

pixList

IList<Int>

类别对应像素列表

indexNameList

IList<String>

类别名称列表

savingPathList

IList<String>

保存路径列表

vpixTable

IList<Int>

像素值索引表,通常默认为0 参数可以不设置

isSaveAsOneFile

bool

是否保存单个文件标志

isCountPolygonInfo

bool

是否计算面信息

isNoGeoTransform

bool

是否进行地理坐标转化

m_strOutFile

String

输出矢量数据

 

2.3 示例代码

数据路径

百度云盘地址下/ PIE示例数据/栅格数据/ 08.图像分类/distanceClassify-Julei.tif

示例代码

  1. /// <summary>
  2. /// 栅格矢量化 对分类后的影像distanceClassify-Julei.tif进行矢量化,该类共有5类;
  3. /// </summary>
  4. public void RasterToVector()
  5. {
  6. RasterVectorization_Exchange_Info info = new RasterVectorization_Exchange_Info();
  7. info.indexList = new List<int> {,,,,};//类别列表
  8. info.indexNameList = new List<string> {"Unclassified","water","veg","bare","town" };//类别名称列表
  9. info.isCountPolygonInfo = false;
  10. info.isSaveAsOneFile = true;//是否保存单个文件 fasle 保存多个文件
  11. info.pchrasterIndexImgPath = @"D:\data\图像分类2\distanceClassify-Julei.tif";//输入的栅格路径
  12. info.pixList = new List<int> { , , , , };//类别对应像素列表 和类别列表对应
  13. info.savingPathList = new List<string> {@"D:\data\图像分类2\distanceClassify-Julei_Re.shp" };//保存路径列表:若保存单个文件,一个输出路径即可,若输出多个文件,输出路径即为每一类生成文件路径
  14. //info.vpixTable = new List<int>(); ;//像素值索引表, 可以设置这个参数,默认是0
  15.  
  16. PIE.SystemAlgo.ISystemAlgo algo = PIE.SystemAlgo.AlgoFactory.Instance().CreateAlgo("PIE.CommonAlgo.dll", "PIE.CommonAlgo.RasterToVectorAlgo");
  17. if (algo == null) return;
  18.  
  19. PIE.SystemAlgo.ISystemAlgoEvents algoEvents = algo as PIE.SystemAlgo.ISystemAlgoEvents;
  20. algo.Name = "栅格矢量化";
  21. algo.Params = info;
  22. bool result = PIE.SystemAlgo.AlgoFactory.Instance().ExecuteAlgo(algo);
  23. if (result)
  24. {
  25. MessageBox.Show("栅格矢量化算法执行成功");
  26. IList<ILayer> listLayer = LayerFactory.CreateDefaultLayers(info.savingPathList);
  27. if (listLayer == null) return;
  28. m_HookHelper.ActiveView.FocusMap.AddLayers(listLayer);
  29. m_HookHelper.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
  30. }
  31. }

2.4 示例截图

图1:算法执行结果图

图2:将图1进行唯一值渲染

PIE SDK栅格矢量化算法的更多相关文章

  1. PIE SDK栅格数据集的读写

    1. 功能简介 栅格数据包含很多信息,在数据的运用中需要对数据的信息进行读取或写入,目前PIE SDK支持多种数据格式的数据读取和写入,下面对栅格数据格式的数据读写功能进行介绍. 2. 功能实现说明 ...

  2. PIE SDK栅格RGB渲染

    1. 功能简介 RGB色彩模式是一种颜色标准,是通过对红(R).绿(G).蓝(B)三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB即是代表红.绿.蓝三个通道的颜色,这个标准几乎包 ...

  3. PIE SDK栅格增强控制

    1. 功能简介 亮度是指发光体(反光体)表面发光(反光)强弱的物理量:对比度指的是一幅图像中明暗区域最亮的白和最暗的黑之间不同亮度层级的测量:透明度是描述光线透过的程度 栅格数据增强控制主要是通过对亮 ...

  4. PIE SDK栅格图层渲染变化事件监听

    1. 功能简介 通过PIE SDK加载图层后,会默认的赋值给数据一个渲染.当用户重新给数据赋值Render或改变数据显示效果时,会触发渲染变化事件. 所谓的事件监听是在事件触发时,将执行用户指定的函数 ...

  5. PIE SDK栅格分级渲染

    1.  功能简介 栅格数据分级渲染是根据不同的分级规则,对像元值进行等级划分:并通过对每一级设置不同的显示符号和标注信息,从而达到分级显示的效果. 2.功能实现说明 2.1. 实现思路及原理说明 第一 ...

  6. PIE SDK栅格生成等值线、面

      1.算法功能简介 等值线图能直观地展示数据的变化趋势,是众多领域展示成果的重要图建之一,被广泛应用于石油勘探.矿物开采.气象预报等众多领域.等值线的绘制是指从大量采样数据中提取出具有相同值的点的信 ...

  7. PIE SDK栅格拉伸渲染

    1. 功能简介 栅格数据拉伸渲染是对指定的波段进行图像拉伸,并设置拉伸之后的颜色带,根据像元值和颜色带进行数据渲染. 2. 功能实现说明 2.1. 实现思路及原理说明 第一步 实例化拉伸渲染对象示例 ...

  8. PIE SDK栅格拉伸控制

    1. 功能简介 在我们的实际应用中,对于一般16bit或者更大比特深度的影像,像元值都是大于255的.这种情况下,RGB的显示器是不能够直接使用像元值进行显示的,需要将像元值换算到0~255的区间内以 ...

  9. PIE SDK矢量数据的投影转换

    1. 功能简介 目前在地理信息领域中数据包括矢量和栅格两种数据组织形式 ,每一种数据都可以对投影进行转换,目前PIE SDK支持矢量和栅格数据的投影转换功能,下面对矢量数据的投影转换功能进行介绍. 2 ...

随机推荐

  1. 3-14 Pandas绘图

      1.魔法指令:%matplotlib inline :数据画图 In [1]: %matplotlib inline import pandas as pd In [2]: import nump ...

  2. 十五、Mysql字符集的那些事

    1. 设置默认字符集 #vim /etc/mysql/my.cnf .(5.5以后系统)如下修改: [client] default-character-set=utf8 [mysqld] defau ...

  3. 【买衣服】I'm looking for a jacket

    核心句型: I 'm looking for a jacket. 我想买一件夹克. 场景对话 A: Are you looking for anything? 您想买什么吗? B: Yes. I'm ...

  4. html基础内容

    HTML基础 1. HTML 标题 HTML 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的. 2. HTML 段落 HTML 段落是通过 <p& ...

  5. VIJOS-P1064 迎春舞会之数字舞蹈

    洛谷 P1538 迎春舞会之数字舞蹈 洛谷传送门 JDOJ 1245: VIJOS-P1064 迎春舞会之数字舞蹈 JDOJ传送门 Description ​ 在越来越讲究合作的时代,人们注意的更多的 ...

  6. 团队冲刺---Four

    今天的计划: 研究css模板. 昨天做了什么: 寻找css模板,研究界面布局. 遇到的问题: css模板,代码看不太懂,好多标签都不会用.

  7. Redis笔记2-Redis安装、配置

    下载安装包 wget http://download.redis.io/releases/redis-4.0.8.tar.gz解压 tar xzvf redis-4.0.8.tar.gz安装 cd r ...

  8. 从Java官网下载最新的文档(包含API文档)

    Java学习资料(适合c转java的同学): Java中带包(创建及引用)的类的编译 - 小明快点跑 JAVA 对象引用,以及对象赋值 - 飘来荡去. Java官网下载页:https://www.or ...

  9. oracle--状态查询

  10. 推荐一款语音直播连麦App YAMI

    推荐一款语音直播连麦App YAMI 1 介绍 功能描述:[语音直播]:海量超有才主播,游戏送礼抢红包,嗨玩不停:[多人聊天室]:连麦交友处CP,主持人带你玩游戏,边聊边玩:[语音交友]:海量声优专属 ...