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

/// <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. KVM -> 虚拟化简介&虚拟机安装_01

    什么是虚拟化? 在计算机技术中,虚拟化(技术)或虚拟技术(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源(CPU.内存.磁盘空间.网络适配器等),予以抽象.转换后呈现 ...

  2. IPsec学习笔记

    IPsec是什么 IPsec(IP Security)是一系列为IP通信提供安全性的协议和服务的集合,工作在IP层,可以为上层协议和应用提供透明的安全服务.IPsec提供两种安全机制:认证和加密. 认 ...

  3. 部分Web服务器信息对比

    本文参考wikipedia的Web服务器比较页面的数据,选取了其中自己感兴趣的Web服务器的信息进行了对比,包括,Apache HTTP Server.Apache Tomcat.Nginx.Catt ...

  4. .NetCore源码阅读笔记系列之Security (一) Authentication & AddCookie

    如果你使用过.NetCore开发过程序,你会很清楚,在其中我们经常会用到一些如下的代码 services.AddAuthentication(options => { options.Defau ...

  5. hdu 5011 nim博弈 (2014西安网赛E题)

    n堆石子,每次可以选一堆取走至少一个,之后你可以不操作或者把该堆石子分成两堆,每堆至少一个,和还是原来(取完石子后)的石子个数. Sample Input1121 131 2 3 Sample Out ...

  6. Matlab保存uint16格式文件的相关注意事项

    在matlab中,我们常使用imshow()函数来显示图像,而此时的图像矩阵可能经过了某种运算.在matlab中,为了保证精度,经过了运算的图像矩阵I其数据类型会从unit8型变成double型.如果 ...

  7. CentOS和Windows下配置MySQL远程访问的教程

    CentOS和Windows下配置MySQL远程访问的教程   一.前言 由于实验在云服务器上跑的结果不是很理想.所以,现在切换到局域网服务器.因此,需要重新配置 Windows 服务器和 CentO ...

  8. linux学习笔记-7.文件属性

    1.查看文件夹属性 ls -ld test 2.文件夹的rwx --x:可以cd进去r-x:可以cd进去并ls-wx:可以cd进去并touch,rm自己的文件,并且可以vi其他用户的文件-wt:可以c ...

  9. UI自动化测试(一)简介及Selenium工具的介绍和环境搭建

    自动化测试简介 1.1何为自动化测试? 是把以人为驱动的测试转化为机器执行的一种过程,它是一种以程序测试程序的过程.换言之,就是以程序实现的方式来代替手工测试. 1.2自动化测试分类 分为功能自动化测 ...

  10. hadoop 基础视频1

    hadoop 基础视频1 一, 大致内容: 1, 源起与体系结构2,实施Hadoop 集群3,分布式HDFS, 大数据存储实战4,Map-Reduce 体系架构5,Map-Reduce 数据分析之一 ...