Read/write georeferenced image

36 visualizaciones (últimos 30 días)
Massimo Zanetti
Massimo Zanetti el 28 de Sept. de 2022
Respondida: Yan Tong el 16 de Ag. de 2023
Hi, here I am wondering why this simple operation of reading a georeferenced .tif image and writing some results in the same georeferenced framework is so difficult. Here is my example:
[A,R] = readgeoraster("input_image.tif");
O = f(A) %any operation you like
geotiffwrite("output_image.tif",O,R);
This gives the error:
Error using geotiffwrite
The input, R, is a map.rasterref.MapCellsReference object indicating that you are working in a projected coordinate system. If so, then specify a projected coordinate system by setting the appropriate values for the 'CoordRefSysCode' or 'GeoKeyDirectoryTag' optional parameters.
But the input image includes the Coordinate Reference System Code (which is EPSG:32632), and the geotiffinfo function confirms that, as I have among other values: PCS: WGS 84 / UTM Zone 32N, which is the same as EPSG:32632.
So, do we have two Matlab functions incompatible each other? How am I supposed to automatically save the result without manually input 'CoordRefSysCode',32632 to the geotiffwrite function?
Thanks

Respuesta aceptada

Kevin Holly
Kevin Holly el 28 de Sept. de 2022
Can you try this below?
[A,R] = readgeoraster('input_image.tif');
O = A*2; %any operation you like
info = geotiffinfo('input_image.tif');
key = info.GeoTIFFTags.GeoKeyDirectoryTag;
geotiffwrite("output_image.tif",O,R,'GeoKeyDirectoryTag',key);
  1 comentario
Massimo Zanetti
Massimo Zanetti el 29 de Sept. de 2022
Thank you Kevin, this works fine, of course. The same would be using 'CoordRefSysCode',info.GeoTIFFCodes.PCS
I find it strange that readgeoraster function is not able to handle it on its own. It is indeed supposed to read georeferenced data but it cannot resolve projections. Working with georeferenced images, having them projected is the most common situation. This probably requires a fix.
Thanks again,
Massimo

Iniciar sesión para comentar.

Más respuestas (1)

Yan Tong
Yan Tong el 16 de Ag. de 2023
You can try this!
[A,R] = readgeoraster(infilename);
info = geotiffinfo('input_image.tif');
geoTags = info.GeoTIFFTags.GeoKeyDirectoryTag;
tiffTags = struct('TileLength',1024,'TileWidth',1024);
geotiffwrite(outfilename,your_outputtiff,R,'TiffType','bigtiff', ...
'GeoKeyDirectoryTag',geoTags, ...
'TiffTags',tiffTags)

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by