实现流程
- matlab计算得到的三列数据,分别为x坐标、y坐标和对应坐标的数值,文件名为originalData.dat
- 开启surfer软件,本人用的surfer13
- matlab命令行输入下述代码实现数据的网格化
%启动surfer服务
h = actxGetRunningServer('Surfer.Application')
%设置窗口可见
set(h,'visible',1)
%设置工作目录
set(h,'DefaultFilePath','D:\Program Files\MATLAB\R2010b\work')
%设置图形窗口是否刷新
set(h,'ScreenUpdating',1)
%网格化数据
invoke(h,'GridData','originalData.dat')
- 网格化数据后得到xxx.grd网格化数据之后进行surfer等值线成图
%开启图形窗口
wds=invoke(h.documents,'add',1)
contourframe=invoke(wds.shapes,'AddContourMap','xxx.grd')
ContourMap=contourframe.Overlays.Item(1)
%添加色标文件
invoke(ContourMap.Levels,'LoadFile','rainbow.lvl')
ContourMap.Fillcontours=1
ContourMap.ShowColorScale=1
- 自动调用surfer成图
实现过程初期surfer成图界面一直显示黑色背景,后查找原因是因为set(h,‘ScreenUpdating’,1) 设置为了0,即禁用了屏幕刷新,所以数据无法实时显示为等值线图