编程实现BIP、BSQ、BIL三种格式转换详解培训讲学

上传人:鲁** 文档编号:564899205 上传时间:2022-08-01 格式:DOCX 页数:12 大小:343.14KB
返回 下载 相关 举报
编程实现BIP、BSQ、BIL三种格式转换详解培训讲学_第1页
第1页 / 共12页
编程实现BIP、BSQ、BIL三种格式转换详解培训讲学_第2页
第2页 / 共12页
编程实现BIP、BSQ、BIL三种格式转换详解培训讲学_第3页
第3页 / 共12页
编程实现BIP、BSQ、BIL三种格式转换详解培训讲学_第4页
第4页 / 共12页
编程实现BIP、BSQ、BIL三种格式转换详解培训讲学_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《编程实现BIP、BSQ、BIL三种格式转换详解培训讲学》由会员分享,可在线阅读,更多相关《编程实现BIP、BSQ、BIL三种格式转换详解培训讲学(12页珍藏版)》请在金锄头文库上搜索。

1、编程实现BIP、BSQ、BIL三种格式转换一、实验目的理解遥感图像BIP、BIL、BSQ三种格式数据的组织方式,以及它们互相转换原理 和方法。二、实验原理ENVI栅格图像文件,是以字节数据为单位,再按照指定顺序组织、排列而成,具 体有如下三种方式:1. BIP(像元波段交叉式):以一对像元为基本单位进行记录;2. BIL(波段按行交叉格式):按照扫描行为单位各波段同一扫描行数据依次记录 图像按顺序第一个像元所有的波段,接着是第二个像元的所有波段,然后是第三个像 元的所有波段,等等,直到像元总数为止;3. BSQ(波段顺序格式):以波段为单位,每波段所有扫描行依次记录,每行数据后 面紧接着同一波

2、谱波段的下一行数据。所以实现三种格式的转换,实际上是对图像字节进行重新排序。三、实验思路获取图像相关信息(可通过读取头文件)根据图像格式读取字节数据1对获取的字节数据按照目标文件格式顺序写入、保存四、实验步骤1. 新建项目文件:本实验选用的语言是 C#,开发工具是 VisualStudio2010 ,通 过“文件一新建一项目一 C#Windows窗体应用程序”,命名“格式转换”即 可;2. 编写代码:通过实验思路的流程图,我们确定代码也应该分这三个功能来写, 对应可以组织为三个大方法,再细分,调用即可。(1)编写读取头文件代码:ENVI中栅格图像被分为两个文件存储,一个“.HDR ”头文件和一

3、个数据文件,头文件存储了图像描述信息,它是一个文 本文件,我们可以用 System.lO.SreamReader字符读取流按行读取,再用字符串匹配方法,以读取字段的方式获取图像的行数、列数、波段数、基本数据类 型,即可,具体代码可见后文代码附录;(2) .编写数据读取数据文件代码:图像数据组织方式有BIP、BIL、BSQ三种,那么对应的也应该有三个方法按照行、列、波段交叉顺序对图像字节数据进行读取,具体代码见后文;(3) .编写字节数据重排列存储代码:在读取了图像数据文件后,可以通过FileStream类按照目标类型格式文件组织顺序,把字节数据写入到文件中保存 即可,具体代码见后文。3. 编译

4、与调试:通过用预先知道内部字节数据的实验文件,进行测试,辅助断 点调试,可排除一般问题,接着编译生成目标程序;4. 运行程序查看结果:通过对多种格式、多种基本数据类型、多种像素大小的 文件进行多种方式转换,再利用 ENVI打开两个图像查看是否一样,再辅以“Link ”功能看同一像素点值是否相同,这样可以深层确定转换的正确性。五、结果与分析1. 结果图像数据基本 类型代码, 如:”1”为1字 节 byte, ”2” 为 2字节short等程序运行界面源格式(BSQ)目标格式(BIL )转换后结果2. 分析总结(1) .读取头文件时,不能通过各字段的现有位,按位读取,应该按行读取, 再利用字符串匹

5、配方式,找到指定字段,这样避免字段位变化时读取出错误信 息;(2) .再读取数据文件和写入存储时,应该要以基本数据类型长度个字节为单位进行,不能单纯的以一个字节操作,不然会不具有普遍性,遇到以“int、float ”为基本类型的文件时,就会出错;(3) 要想节省代码,可先将各种格式数据读取存储为一种格式字节数组中, 再从这个格式往其他格式进行转换,这样可以节省不少工作量,但是引入了中 间数组,耗费了内存。六、源代码附录1.读取头文件信息/III读取头文件信息/vparamn ame=strFileNamex/param头文件路径和名称/vparamn ame=iColu mn sCou ntx

6、/param像素列数/vparamn ame=iL in esCou ntx/param像素行数/vparamn ame=iBa ndsCou ntx/param波段数/vparamname=iTypev/param基本数据类型代码/vparamn ame=strI nterLeavex/param文件组织格式/vretur nsv/retur ns返回是否读取成功publicstaticboolReadHDRStri ngstrFileName, outiLin esCou nt,out intiBandsCount, outint iType, outout intStr ingstrI

7、nterLeint iColu mn sCou nt.ave)boolbln Successfalse ;iColum nsCou nt-1;iLin esCou nt-1;iBan dsCou nt-1;iType-1;strl nterLeaveIII!/初始化各个变量StreamReader hdrfile= null ;tryexOf( = )+1,exOf( = )+1,hdrfile = new StreamReader (strFileName);string content=;while (hdrfile.EndOfStream!=true )/获取像素列数content =

8、hdrfile.ReadLi ne();if (content.Contains(samples)String samples = conten t.Substr in g(c onten t.I nd content.Length-content.IndexOf(= )-1).Trim();iColu mn sCou nt= Con vert .ToI nt32(samples);System. Con sole .WriteLi ne(samples);break ;while (hdrfile.EndOfStream != true )/获取像素行数content = hdrfile.R

9、eadL in e();exOf( = )+1,ifconten t.Le ngth(conten t.C ontains(li nes)Stri ng lines = conten t.Substr in g(c onten t. Ind -content.IndexOf(= )-1).Trim();iLin esCou nt = Con vert .ToI nt32(li nes);System. Con sole .WriteL in e(l in es);break ;!= true )while (hdrfile.E ndOfStream /获取波段个数content = hdrfi

10、le.ReadLi ne();if(content.Contains(bands)Stri ngbands = conten t.Substr in g(c onten t. Indcontent.Length- content.IndexOf( = )-1).Trim();iBa ndsCou nt = Con vert .ToI nt32(ba nds);System. Con sole .WriteL in e(ba nds);break ;while (hdrfile.EndOfStream != true )/获取数据种类content = hdrfile.ReadLi ne();i

11、f(content.Contains(data type)dexOf( =)+1,conten t.Le ngthString type = conten t.Substri ng(c onten t.l n content.IndexOf(=)-1).Trim();iType = Con vert .ToI nt32(type);System. Con sole .WriteLi ne(type);break ;while(hdrfile.EndOfStream!= true )/获取数据解译方式content = hdrfile.ReadLi ne();if(conten t.C onta

12、ins(in terleave )tent.lndexOf(=)+ 1,conten t.Le ngthStringin terleve= conten t.Substri ng(c on-content.IndexOf( = )-1).Trim();strI nterLeave =in terleve;System. Con sole .WriteLi ne(i nterleve);bln Success = true ;break ;catch/读取失败hdrfile.Close();hdrfile.Dispose();return false ;hdrfile.Close();hdrfi

13、le.Dispose();/关闭文件流,释放内存retur nbln Success;2.读取数据文件进行转换存储/bip转换为bsq/源文件名称与路径/目标文件名称与路径/像素行数/像素列数/ 波段数/基本数据类型代码/v/retur ns是否转换成功le, intOpe n);public staticpixComCounts, intbool BipToBsq( stringstrlnputFile,pixL in eCou nts, int ban ds, int type)str ingbool bln Success = true ;FileStream inputF = new FileStream (strInputFile,FileStre

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号