1. 数据介绍

信息提取和解译的过程中,经常会生成一部分中间临时栅格数据,这些数据在执行完对应操作后就失去了存在的价值,针对这种情况,PIE增加了内存栅格数据集,来协助用户完成对自定义栅格数据的读取和显示。

下面以一副影像数据的抠图算法来演示自定义栅格数据的应用。

2. 实现思路及原理说明

第一步

打开原始栅格数据;

第二步

读取部分数据至内存中,设置读取的起始点、读取范围等参数;

第三步

建立栅格内存数据集;

第四步

将内存中的数据写入内存数据集;

第五步

通过内存数据集创建栅格图层;

第六步

添加栅格图层到地图并刷新;

3. 核心接口与方法

接口/类

方法

说明

IRasterDataset

GetBandCount()

获取波段个数

GetRasterBand()

获取指定索引的波段

Read()

将数据读取至内存中

Write()

将内存数据写入栅格数据集中

SetGeoTransform

设置六参数

SpatialReference

空间参考

DatasetFactory

CreateRasterDataset()

创建栅格数据集

4. 示例代码

项目名称

百度云盘地址下/PIE示例程序/03.数据加载/11.打开自定义栅格数据

数据位置

百度云盘地址下/PIE示例数据/栅格数据/04.World/World.tif

视频位置

百度云盘地址下/PIE视频教程/03.数据加载/11.打开自定义栅格数据.avi

示例代码

 方法(一)打开自定义栅格数据
if (mapControlMain.FocusMap.LayerCount == )return;
IRasterLayer pRasterLayer = mapControlMain.ActiveView.CurrentLayer as IRasterLayer;
if (pRasterLayer == null)return;
IRasterLayer memLayer = OpenMemRasterLayer(pRasterLayer, , );
if(memLayer!=null)
{
mapControlMain.FocusMap.AddLayer(memLayer as ILayer);
mapControlMain.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
} /// <summary>
/// 自定义栅格数据读取(通过内存RasterData构建RasterLayer)
/// </summary>
/// <param name="rasterLayer">栅格数据路径</param>
/// <param name="startX">读取起始位置X</param>
/// <param name="startY">读取起始位置Y</param>
/// <param name="?"></param>
/// <returns></returns>
private IRasterLayer OpenMemRasterLayer(IRasterLayer rasterLayer, int startX, int startY)
{
IRasterLayer memRasterLayer = null;
object array = null;//存储读取出的数据
//栅格图层参数读取
IRasterDataset rasterDataset = rasterLayer.Dataset;
int bandCount = rasterDataset.GetBandCount();
PixelDataType rasterDataType = rasterDataset.GetRasterBand().GetRasterDataType(); //读取栅格数据块大小
int width = ;
int height = ;
switch (rasterDataType)
{
case PixelDataType.UInt16:
array = new UInt16[width * height * bandCount];
break;
case PixelDataType.Byte:
array = new Byte[width * height * bandCount];
break;
default:
break;
}
int[] bandMap = new int[bandCount];
for (int i = ; i < bandCount; i++)
{
bandMap[i] = i + ;
}
//将pRasterLayer中的数据读取至数组中
bool oK = rasterDataset.Read(startX, startY, width, height, array, width, height, rasterDataType, bandCount, bandMap); //栅格读取
double[] geoTrans = rasterDataset.GetGeoTransform(); //创建内存数据集
IRasterDataset newRDataset = DatasetFactory.CreateRasterDataset("", width, height, bandCount, rasterDataType, "MEM", null);
//数组中的数据写入内存数据集中
oK = newRDataset.Write(, , width, height, array, width, height, rasterDataType, bandCount, bandMap); //栅格写入
//设置参数
newRDataset.SetGeoTransform(geoTrans);//设置仿射变换参数
newRDataset.SpatialReference = rasterDataset.SpatialReference;//设置空间参考 //创建RasterLayer
memRasterLayer = PIE.Carto.LayerFactory.CreateDefaultRasterLayer(newRDataset);
return memRasterLayer;
}

5. 示例截图

PIE SDK打开自定义栅格数据的更多相关文章

  1. PIE SDK打开自定义矢量数据

    1. 数据介绍 信息提取和解译的过程中,经常会生成一部分中间临时矢量数据,这些数据在执行完对应操作后就失去了存在的价值,针对这种情况,PIE增加了内存矢量数据集,来协助用户完成对自定义矢量数据的读取和 ...

  2. PIE SDK打开栅格数据

    1. 功能简介 GIS将地理空间数据表示为矢量数据和栅格数据.矢量数据模型使用点.线和多边形来表示具有清晰空间位置和边界的空间要素,如控制点.河流和宗地等,每个要素被赋予一个ID,以便与其属性相关联. ...

  3. PIE SDK打开网络地图数据

    1. 数据介绍 网络地图数据是在线地图服务发布出来的数据,其支持数据的网络查看和传输,极大的促进了GIS的发展. 目前PIE SDK支持百度地图.谷歌地图.高德地图.天地图.Bing地图.ArcGIS ...

  4. PIE SDK打开矢量数据

    1. 功能简介 GIS将地理空间数据表示为矢量数据和栅格数据.矢量数据模型使用点.线和多边形来表示具有清晰空间位置和边界的空间要素,如控制点.河流和宗地等,每个要素被赋予一个ID,以便与其属性相关联. ...

  5. PIE SDK矢量自定义渲染

    1. 功能简介 PIE SDK中关于矢量渲染提供了多种方案,包括简单渲染.分级渲染.唯一值渲染,这几种渲染方式具有一定的通用性,可以满足用户绝大多数的需求. 当面对复杂的业务,当前渲染方案无法满足用户 ...

  6. PIE SDK打开HDF、NC数据

    1. 功能简介 HDF 是美国国家高级计算应用中心(National Center for Supercomputing Application)为了满足各种领域研究需求而研制的一种能高效存储和分发科 ...

  7. PIE SDK打开静止卫星数据

    1. 功能简介 静止卫星是位于地球赤道上空约3.58万km处,与地面始终保持相对静止的卫星,静止卫星的特点是覆盖区域广,具有很强的机动灵活性,能够对特定区域进行分钟级高重复观测,可快速监测灾害目标的动 ...

  8. PIE SDK打开长时间序列数据

    1. 功能简介 时间序列数据(time series data)是在不同时间上收集到的数据,这类数据是按时间顺序收集到的,用于所描述现象随时间变化的情况.当前随着遥感卫星技术日新月异的发展,遥感卫星的 ...

  9. PIE SDK打开GDB、Dwg数据

    1. 功能简介 目前不同的GIS软件平台具有自己独特支持的数据格式,如ESRI的File GeoDataBase和Personal GeoDataBase.MapInfo的mif数据.AutoCAD的 ...

随机推荐

  1. 奇怪的ifcfg-eth0被自动还原

    最近,一台虚拟机是从外网下载的,然后导入本地测试环境使用. 发现一个奇怪的问题:修改了 /etc/sysconfig/network-scripts/ifcfg-eth0 保存后, 重启网络服务( s ...

  2. Ubuntu 18.04上安装Apache, MySQL, PHP, LAMP

    1.安装 Apache $ sudo apt update && sudo apt install apache2 中间会遇到停顿询问是否继续, 输入 y 然后 回车. 2.测试 Ap ...

  3. CCF-CSP 201709-3 JSON查询 题解

    试题编号: 201709-3 试题名称: JSON查询 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 JSON (JavaScript Object Notation) 是一 ...

  4. java 获取安全随机字符

    private static final char[] CHAR_32 = new char[] {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', ...

  5. 防止xss攻击的前端的方法

    项目当中在进行安全测试的时候,遇到了xss的攻击,要求前端来做个防御,针对于遇到的xss攻击,做个总结 1.xss---存储型xss的攻击 前端只要在接收到后台数据的时候做个特殊字符的过滤,即可抵制攻 ...

  6. 201871010126 王亚涛 《面向对象程序设计(java)》 第6-7周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  7. 代码审计-strcmp比较字符串

    <?php $flag = "flag{xxxxx}"; if (isset($_GET['a'])) { if (strcmp($_GET['a'], $flag) == ...

  8. python基础语法20 面向对象5 exec内置函数的补充,元类,属性查找顺序

    exec内置函数的补充 exec: 是一个python内置函数,可以将字符串的代码添加到名称空间中; - 全局名称空间 - 局部名称空间 exec(字符串形式的代码, 全局名称空间, 局部名称空间) ...

  9. 使用表格 代替 txt文件(未完结)

    使用xlrd读取用户数据 首先创建一个xls文件 xlrd模块的简单使用 添加处理execl的接口: 使用excel生成测试报表

  10. Spark & Scala:

    https://blog.csdn.net/do_yourself_go_on/article/details/76033252 Spark源码之reduceByKey与GroupByKey     ...