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

/// <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. 阿里云RDS的mysql数据库占用空间超过90%的处理

    阿里云RDS数据库最大支持2T,目前已经占用了90%,如果进行分库或者迁移比较麻烦,思路是找出占用空间过大的日志或不重要的文件进行删除操作 查询所有数据库占用磁盘空间大小的SQL语句: show bi ...

  2. jQuery-介绍

    一:什么是jQuery jQuery 是一个 JavaScript 库. 二:安装 http://jquery.com/download/ http://jquery.cuishifeng.cn/ j ...

  3. 使用node创建一个服务器,运行vue打包以后的文件

    原理就是使用node里的express框架,搭建一个服务器,然后访问dist文件夹里的文件 prod.server.js var express = require('express') var co ...

  4. 阿里云服务器配置nginx和PHP

    1. 安装及启动nginx 输入yum install nginx命令进行nginx的安装,当需要确认时输入”y“确认. yum install nginx 安装完成后,输入service nginx ...

  5. 2018-2019-2 网络对抗技术 20165301 Exp4 恶意代码分析

    2018-2019-2 网络对抗技术 20165301 Exp4 恶意代码分析 实验内容 系统运行监控 使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是哪里.运行一段时间并分 ...

  6. MySQL一问一答

    一.问:如果有一张表,里面有个字段为id的自增主键,当已经向表里面插入了10条数据之后,删除了id为8,9,10的数据,再把mysql重启,之后再插入一条数据,那么这条数据的id值应该是多少,是8,还 ...

  7. 《python源码剖析》,看看

    这书高级了,有点超出理解能力. 但走出舒适区,不是大家都在说的么?:) 看完了些章节,还是很有收获的, 截图存照.

  8. AC自动机学习笔记-2(Trie图&&last优化)

    我是连月更都做不到的蒟蒻博主QwQ 考虑到我太菜了,考完noip就要退役了,所以我决定还是把博客的倒数第二篇博客给写了,也算是填了一个坑吧.(最后一篇?当然是悲怆のnoip退役记啦QAQ) 所以我们今 ...

  9. 【LOJ】#2108. 「JLOI2015」装备购买

    题解 换成long double才过--出题人丧心病狂卡精度 只要按照费用排序从小到大排序,一个个插入线性基,插入的时候加上费用即可 代码 #include <bits/stdc++.h> ...

  10. Codeforces Round #475 (Div. 2) C - Alternating Sum

    等比数列求和一定要分类讨论!!!!!!!!!!!! #include<bits/stdc++.h> #define LL long long #define fi first #defin ...