码迷,mamicode.com
首页 > 其他好文 > 详细

IDL---ENVI

时间:2015-01-30 19:10:44      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:

ENVI;启动envi
file=envi_pickfile();选择文件dialog,返回值就为file
ENVI_OPEN_FIle,file,r_fid=fid;根据文件名打开file,并且返回fid
envi_file_query,fid,NB=NB,NL=NL,NS=NS,dims=dims,data_type=dt,bnames=bnames;根据fid查询图像信息
data=envi_get_data(fid=fid,dims=dims,pos=0)根据fid得到数据dims:维度
window,1,xsize=798,ysize=909l;新建一个window窗体
tv,data;显示数据
tvscl,data;拉伸显示
tvscl,data,/order;idl中左下角为原点,envi中是左上角
envi,/restore_base_save_files ;不启动ENVI调用功能
envi_batch_init:批处理初始化
.e canny.pro;跳转到canny.pro文件

完整工程文件----定义一个button,并添加事件
PRO envi_canny_define_buttons,buttonInfo
;定义button
ENVI_DEFINE_MENU_BUTTON,buttonInfo,$
  value=‘Canny‘,$;显示的值
  uValue=‘‘,$;用户值
  EVENT_PRO=‘envi_canny‘,$;必须与主函数名一致
  pef_value=‘Filter‘,$;区分大小写
  position=1;位置
END
  
pro envi_canny,event          ;定义主函数
;
compile_opt idl2              ;编译环境
;选择数据
envi_select,fid=fid,/BAND_ONLY,pos=pos  ;选择遥感数据文件
;检查数据
print,fid,pos   ;打印
if fid eq -1 then return                ;判断是否得到数据
;查询数据
envi_file_query,fid,dims=dims,ns=ns,$
 nl=nl, nb=1, wl=wl
;获取数据
data=ENVI_GET_DATA(fid=fid,dims=dims,pos=pos)
;canny
result=canny(data)
;显示数据
;TVSCL,result   ;新建窗体并显示数据
output=envi_pickfile(/output)   ;设置并得到输出路径
  if(output eq "")then begin    ;判断得到的输出路径是否为空
    ENVI_ENTER_DATA,result
   endif else begin   
    ;保存数据
   openw,lun,output,/GET_LUN    ;新建二进制文件
   writeu,lun,result                     ;将结果写入    
   FREE_LUN,lun                          ;释放
   ;写头文件
   ENVI_SETUP_HEAD, fname=output,     $
    interleave=0,data_type=1, $
    NS=NS,NB=1,NL=NL,$
     /write, /open, r_fid = r_fid
     end
  
 envi_display_bands, r_fid, 0;显示该文件(只有一个波段)
 
END

;写完主程序之后要进行保存,$
;在控制台中
;save,filename="E:\Program Files\Exelis\ENVI51\classic\save_add\envi_canny.sav", /routines

技术分享

解决方案:
在IDL的帮助中搜素resolve_all,通过语法
RESOLVE_ALL [, CLASS=string] [, /CONTINUE_ON_ERROR] [, /QUIET] [, RESOLVE_EITHER=string] [, RESOLVE_FUNCTION=string] [, RESOLVE_PROCEDURE=string] [, SKIP_ROUTINES=string] [, UNRESOLVED=variable]
在控制台中输入resolve_all,/CONTINUE_ON_ERROR,SKIP_ROUTINES="envi"回车,在save
save,filename="E:\Program Files\Exelis\ENVI51\classic\save_add\envi_canny.sav", /routines

IDL---ENVI

标签:

原文地址:http://www.cnblogs.com/shangguanjinwen/p/4262929.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!