From 2e463a7891c1ecc271cb17321e73fb0f31fe935a Mon Sep 17 00:00:00 2001 From: Wei Ji <23487320+weiji14@users.noreply.github.com> Date: Sun, 10 Mar 2024 17:19:17 +1300 Subject: [PATCH] :art: Initial CogReader struct with decoder field (#7) Defining a Cloud-Optimized GeoTIFF Reader struct with a decoder field containing an instance of tiff::decoder::Decoder with an unlimited decoding buffer size by default. Marking the struct as private for now until more method implementations are done. --- src/io/geotiff.rs | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/src/io/geotiff.rs b/src/io/geotiff.rs index c2eedfd..f266c5e 100644 --- a/src/io/geotiff.rs +++ b/src/io/geotiff.rs @@ -1,20 +1,35 @@ use std::io::{Read, Seek}; use ndarray::Array2; -use tiff::decoder::{DecodingResult, Limits}; -use tiff::{TiffError, TiffFormatError}; +use tiff::decoder::{Decoder, DecodingResult, Limits}; +use tiff::{TiffFormatError, TiffResult}; + +/// Cloud-optimized GeoTIFF reader +struct CogReader { + decoder: Decoder, +} + +impl CogReader { + /// Create a new GeoTIFF decoder that decodes from a stream buffer + fn new(stream: R) -> TiffResult { + // Open TIFF stream with decoder + let mut decoder = Decoder::new(stream)?; + decoder = decoder.with_limits(Limits::unlimited()); + + Ok(Self { decoder }) + } +} /// Synchronously read a GeoTIFF file into an [`ndarray::Array`] -pub fn read_geotiff(stream: R) -> Result, TiffError> { +pub fn read_geotiff(stream: R) -> TiffResult> { // Open TIFF stream with decoder - let mut decoder = tiff::decoder::Decoder::new(stream)?; - decoder = decoder.with_limits(Limits::unlimited()); + let mut reader = CogReader::new(stream)?; // Get image dimensions - let (width, height): (u32, u32) = decoder.dimensions()?; + let (width, height): (u32, u32) = reader.decoder.dimensions()?; // Get image pixel data - let DecodingResult::F32(img_data) = decoder.read_image()? else { + let DecodingResult::F32(img_data) = reader.decoder.read_image()? else { panic!("Cannot read band data") };