此文问获得栅格数据的像元值(即高程),有可能部分见解不到位,望大神看到了不惜指教!

/// <summary>

///  得到高程(通过像素值)
        /// </summary>
        /// <param name="maskTifPath">Raster路径</param>
        private List<int> GetElevation(string maskTifPath, List<IPoint> pointColList)//pointcollist是点集合,可以参照博文获得点集合

{

IRaster raster = GetRaster(maskTifPath);//参见博文获得raster数据
            //得到一段光栅带
            IRasterBandCollection rasterBandCollection = (IRasterBandCollection)raster;
            for (int icount = 0; icount < rasterBandCollection.Count; icount++)//测试数据count为1
            {
                IRasterBand rasterBand = rasterBandCollection.Item(icount);
                //像素
                IRawPixels rawPixels = (IRawPixels)rasterBand;
                IRasterProps rasterProps = (IRasterProps)rawPixels;
                //IGeoDataset geodataset = (IGeoDataset)raster;
                //IEnvelope2 envelop = new EnvelopeClass();
                //envelop = (IEnvelope2)geodataset.Extent;
                //IPoint point = envelop.UpperLeft;
                // 像元大致范围
                //double blockX = (double)rasterProps.MeanCellSize().X;//网格X间距
                //double blockY = (double)rasterProps.MeanCellSize().Y;//网格Y间距
                //double blockArea = blockX * blockY;//网格面积

//int columns = rasterProps.Width;//dem列数
                //int rows = rasterProps.Height;//dem行数
                //   指定像素块大小
                IPnt blockSize = new DblPnt();
                //blockSize.X = columns;
                //blockSize.Y = rows;
                blockSize.X = 5;//赋值为多少比较合适?
                blockSize.Y = 5;
                //blockSize.X = blockX;
                //blockSize.Y = blockY;
                //指定像素块大小来创建像素快
                IPixelBlock3 pixelBlock = (IPixelBlock3)rawPixels.CreatePixelBlock(blockSize);
                IPnt blockOrigin = new DblPnt();
                IPoint point = new PointClass();
                List<int> pixels = new List<int>();
                for (int j = 0; j < pointColList.Count; j++)
                {
                    point = pointColList[j];
                    blockOrigin.X = point.X;
                    blockOrigin.Y = point.Y;
                    //   读取指定位置的像素块(blockOrigin为指定位置)
                    rawPixels.Read(blockOrigin, (IPixelBlock)pixelBlock);
                    //存储格网dem的二维数组
                    System.Array pixelData = (System.Array)pixelBlock.get_PixelDataByRef(icount);
                    // 获得每一个栅格的高程值
                    for (int col = 0; col < pixelData.GetLength(0); col++)
                    {
                        for (int row = 0; row < pixelData.GetLength(1); row++)
                        {
                            pixels.Add(Convert.ToInt32(pixelData.GetValue(col, row)));
                        }
                    }
                    return pixels;
                }
               
            }

}

本博文参照http://www.docin.com/p-607056135.html,感谢!

C#+arcengine获得栅格数据的像素值(高程)的更多相关文章

  1. AE IRasterCursor 改变栅格图层像素值

    1 public void ChangePixelValue(double xMax, double xMin, double yMax, double yMin,double[,] PixelCha ...

  2. YUV与像素值之间的关系

    一幅彩色图像的基本要素是什么? 说白了,一幅图像包括的基本东西就是二进制数据,其容量大小实质即为二进制数据的多少.一幅1920x1080像素的YUV422的图像,大小是1920X1080X2=4147 ...

  3. 中文字号VS英文字号(磅)VS像素值

    中文字号VS英文字号(磅)VS像素值八号=5磅(5pt) ==(5/72)*96=6.67 =6px 七号=5.5磅 ==(5.5/72)*96=7.3 =7px 小六=6.5磅 ==(6.5/72) ...

  4. DICOM图像像素值(灰度值)转换为CT值

    CT值的单位是Hounsfield,简称为Hu,范围是-1024-3071.用于衡量人体组织对X射线的吸收率,设定水的吸收率为0Hu. 在DICOM图像读取的过程中,我们会发现图像的像素值有可能不是这 ...

  5. 怎么样用opencv将彩色图片转化成像素值只有0和255的灰度图?

      分类: OpenCV [Q1]怎么样用opencv将彩色图片转化成像素值只有0和255的灰度图? 进行灰度化,IplImage* pImg = cvLoadImage( "C:\\1.b ...

  6. iOS图片的伪裁剪(改变图片的像素值)

    0x00 原理 利用一张图片事先画好的图片(以下称为蒙板),盖在要被裁剪的的图片上,然后遍历蒙板上的像素点,修改被裁剪图片对应位置的像素的色值即可得到一些我们想要的不规则图片了(比如人脸) 0x01 ...

  7. js获取不带单位的像素值

    所谓获取不带单位的像素值就是获取比如元素的宽度.高度.字体大小.外边距.内边距等值但是去掉像素单位. 比如:某一个元素的宽度是100px,现在我要获取这个这个值但是不带单位“px”,对于这种问题你会怎 ...

  8. c#图像处理入门(-bitmap类和图像像素值获取方法)

    c#图像处理入门 -bitmap类和图像像素值获取方法 一.Bitmap类 Bitmap对象封装了GDI+中的一个位图,此位图由图形图像及其属性的像素数据组成.因此Bitmap是用于处理由像素数据定义 ...

  9. Bitmap每个像素值由指定的掩码决定

    bBitmap每个像素值由指定的掩码决定 写了一个小工具来转换Bitmap彩色图片的不同位数. 程序的逻辑是拼接: Bitmap文件头 + Bitmap信息头 + Bitmap数据 在RGB888转换 ...

随机推荐

  1. Java类的继承与多态特性-入门笔记

    相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...

  2. JAVA 基础基本语法---常量与变量

    JAVA 基础基本语法---常量与变量 语法:计算机能够识别的语言的规则: 0. 基本语法 编写Java程序时,应注意以下几点: 大小写敏感:Java是大小写敏感的,这就意味着标识符Hello与hel ...

  3. Oracle学习笔记:外连接(+)的用法

    Oracle中常用 left join 和 right join 来进行外连接,同时,oracle也支持 (+) 的特殊用法,也是表示外连接,并且总是放在非主表的一方. 例如: 左外连接: selec ...

  4. Windows下RabbitMQ安装及配置

    下载rabbitmq_server以及Erlang OTP平台 安装好了启动服务就行了 也可用命令 net start RabbitMQ  或  net stop RabbitMQ 配置用户添加环境变 ...

  5. Spring Cloud与Docker微服务架构实战 PDF

    电子版百度云下载 链接: https://pan.baidu.com/s/115u011CJ8MZzJx_NqutyTQ 提取码: 关注公众号[GitHubCN]回复2019获取 本书的代码 共计70 ...

  6. 【AtCoder】AGC029(A-E)

    A - Irreversible operation 题解 把每个B后面的W个数累加起来即可 代码 #include <bits/stdc++.h> #define fi first #d ...

  7. php返回上一页

    echo "<script>alert('没有获取到订单信息');history.go(-1);</script>";

  8. 使用<c:set>标签配置项目路径

    写在前面的话: 在java项目中,路径的配置是一项最基础也是最必不可少的工作,最初我们配置路径是根据<%=request.getContextPath()%>这个java代码块进行配置的, ...

  9. 基于SOA的银行系统架构

    Part-1  [简述] 1.通过引入面向服务架构(SOA),企业服务总线(ESB),适配器(Adapter)及面向构件等技术,尝试打造一个统一业务流程服务平台,实现面向流程的服务集成. 2.传统银行 ...

  10. Nmap扫描教程之基础扫描详解

    Nmap扫描教程之基础扫描详解 Nmap扫描基础扫描 当用户对Nmap工具了解后,即可使用该工具实施扫描.通过上一章的介绍,用户可知Nmap工具可以分别对主机.端口.版本.操作系统等实施扫描.但是,在 ...