读写栅格
利用geotiffread或读栅格imread读取,区别在于geotiffread能同时读取栅格的数值和地理参考坐标,而imread需要分两步,首先利用地理参考信息,再读取图像。
geotiffread
data:image/s3,"s3://crabby-images/1cf15/1cf15938e056e57a28ad6b22448c20884e75a969" alt=""
data:image/s3,"s3://crabby-images/68e4b/68e4b08492be279085e0cf65bcd2530cff31692a" alt=""
运行[X,cmap,refmat,bbox]=geotiffread('E:/code/data/stationRaster.tif');
data:image/s3,"s3://crabby-images/d07dc/d07dc9b0d53f86613b6c24dabb0cec8f2392c156" alt=""
其中,X是数据网格,cmap是颜色映射,bbox是边界,refmat是referencing matrix,用于相互转换栅格行列索引和地理坐标。
data:image/s3,"s3://crabby-images/cd149/cd149f59c0109a41c822f148c6985062315e4b8a" alt=""
简单例子
stationfile='E:/code/data/stationRaster.tif';
%利用geotiffread读取
[staionsRaster,Rstation] = geotiffread(stationfile);
imread
data:image/s3,"s3://crabby-images/d95bb/d95bbee09b6428c3d0dd696aeb8c46e1576847f2" alt=""
个人理解,和geotiffread的区别在于geotiffread能直接读出数据值和地理参考信息,而imread只是将tiff文件当成图片处理。后期如果要用到地理参考信息,可用georasterref(投影坐标)和worldfileread(地理坐标)函数来获取。
Rstation = georasterref('RasterSize',size(staionsRaster), 'Latlim',[30 34], 'Lonlim', [118 120]);
stationfile='E:/code/data/stationRaster.tif';
staionsRaster=imread(stationfile);
对应栅格写法
geotiffwrite和imwrite
data:image/s3,"s3://crabby-images/0a8eb/0a8eb1d904a00357bdab31022d74304a963aa5a3" alt=""
data:image/s3,"s3://crabby-images/15188/1518804fbcbd931bf47979eec15fd4dc59ef8166" alt=""
stationfile='E:/code/data/stationRaster.tif';
[staionsRaster,Rstation] = geotiffread(stationfile);
info=geotiffinfo(stationfile);
savepath='E:\code\result\';
geotiffwrite([savepath,'新保存的图像.tif'], staionsRaster, Rstation, 'GeoKeyDirectoryTag', info.GeoTIFFTags.GeoKeyDirectoryTag);
可视化展示
geoshow或mapshow。区别在于geoshow中的R是georasterref获得的对象,绘制的可视化图是经纬度坐标,而mapshow是geotiffread获得的地理参考信息(下图中的Rstation),实际是投影信息,绘制的可视化图以长度为单位。
data:image/s3,"s3://crabby-images/31b9e/31b9eeb510414541f669b0f1283ad90ce14638fd" alt=""
stationfile='E:/code/data/stationRaster.tif'; %加油站点
[staionsRaster,Rstation] = geotiffread(stationfile);
R= georasterref('RasterSize',size(staionsRaster), 'Latlim',[30 34], 'Lonlim', [118 120]);
%geoshow,设置DisplayType显示颜色
figure
geoshow(staionsRaster,R,'DisplayType', 'texturemap');
%mapshow
figure
mapshow(staionsRaster,Rstation,'DisplayType', 'texturemap');
data:image/s3,"s3://crabby-images/2e746/2e74635e29a080cda29e06dd7ae27f59da978432" alt=""
data:image/s3,"s3://crabby-images/d21c1/d21c18c45aa7251c313dd0d916ca9e2fd65a02c5" alt=""
网友评论