Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
sharkAndshark committed Nov 28, 2024
1 parent a2e4ba2 commit eb5ed75
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 26 deletions.
59 changes: 33 additions & 26 deletions martin/src/cog/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ use regex::Regex;
use std::collections::HashMap;
use std::fs::File;
use std::path::Path;
use std::vec;
use std::{fmt::Debug, path::PathBuf};
use std::{u8, vec};

use std::io::BufWriter;
use tiff::decoder::{Decoder, DecodingResult};
Expand Down Expand Up @@ -129,7 +129,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::U8(vec), tiff::ColorType::RGB(_)) => to_png(
Expand All @@ -141,7 +141,7 @@ impl Source for CogSource {
data_width,
data_height,
3,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::U8(vec), tiff::ColorType::RGBA(_)) => to_png(
Expand All @@ -153,7 +153,7 @@ impl Source for CogSource {
data_width,
data_height,
4,
false,
(false, u8::MAX),
&self.path,
),
(DecodingResult::U16(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -165,7 +165,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u16::MAX),
&self.path,
),
(DecodingResult::U16(vec), tiff::ColorType::RGB(_)) => to_png(
Expand All @@ -177,7 +177,7 @@ impl Source for CogSource {
data_width,
data_height,
3,
true,
(true, u16::MAX),
&self.path,
),
(DecodingResult::U16(vec), tiff::ColorType::RGBA(_)) => to_png(
Expand All @@ -189,7 +189,7 @@ impl Source for CogSource {
data_width,
data_height,
4,
false,
(false, u16::MAX),
&self.path,
),
(DecodingResult::U32(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -208,7 +208,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::F32(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -227,7 +227,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::F64(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -246,7 +246,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::I8(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -265,7 +265,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::I16(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -284,7 +284,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(DecodingResult::I32(vec), tiff::ColorType::Gray(_)) => to_png(
Expand All @@ -303,7 +303,7 @@ impl Source for CogSource {
data_width,
data_height,
1,
true,
(true, u8::MAX),
&self.path,
),
(_, _) => Err(CogError::NotSupportedColorTypeAndBitDepth(
Expand All @@ -329,7 +329,7 @@ where
vec.iter()
.enumerate()
.map(|(i, &value)| {
let sample_index = (i % samples_count as usize);
let sample_index = i % samples_count as usize;
let min = min_values
.get(sample_index)
.copied()
Expand All @@ -354,7 +354,7 @@ fn to_png<T: Copy + NoUninit + From<u8>>(
data_width: u32,
data_height: u32,
components_count: u32,
need_extra_alpha: bool,
extra_alpha_info: (bool, T),
path: &Path,
) -> Result<Vec<u8>, CogError> {
let is_padded = data_width != tile_width;
Expand All @@ -370,23 +370,27 @@ fn to_png<T: Copy + NoUninit + From<u8>>(

let no_data = T::from(0);

let data: Vec<T> = if let (false, false) = (is_padded, need_extra_alpha) {
let data: Vec<T> = if let (false, false) = (is_padded, extra_alpha_info.0) {
vec
} else {
let components_count_of_result = if need_extra_alpha {
let components_count_for_result = if extra_alpha_info.0 {
components_count + 1
} else {
components_count
};
let mut result =
vec![no_data; (tile_width * tile_height * (components_count_of_result)) as usize];
vec![no_data; (tile_width * tile_height * (components_count_for_result)) as usize];
for row in 0..data_height {
for col in 0..data_width {
let idx = row * data_width * components_count + col * components_count;
let arr_idx = row * tile_width * components_count + col * components_count;
let idx_of_chunk = row * data_width * components_count + col * components_count;
let idx_of_result = row * tile_width * components_count_for_result
+ col * components_count_for_result;
for component_idx in 0..components_count {
result[(arr_idx + component_idx) as usize] =
vec[(idx + component_idx) as usize];
result[(idx_of_result + component_idx) as usize] =
vec[(idx_of_chunk + component_idx) as usize];
}
if extra_alpha_info.0 {
result[(idx_of_result + components_count) as usize] = extra_alpha_info.1;
}
}
}
Expand Down Expand Up @@ -608,7 +612,7 @@ fn get_images_ifd(decoder: &mut Decoder<File>) -> Vec<usize> {

#[cfg(test)]
mod tests {
use std::path::PathBuf;
use std::{fs::File, io::Write, path::PathBuf};

use martin_tile_utils::{TileCoord, TileInfo};
use tilejson::tilejson;
Expand All @@ -619,8 +623,7 @@ mod tests {

#[actix_rt::test]
async fn can_get_tile() -> () {
let path =
PathBuf::from("/home/zettakit/repos/martin/tests/fixtures/cog/tiled_cog_chengdu.tif");
let path = PathBuf::from("../tests/fixtures/cog/output1.tif");
let meta = get_meta(&path).unwrap();
let source = super::CogSource {
id: "test".to_string(),
Expand All @@ -633,8 +636,12 @@ mod tests {
},
};
let query = None;
let _tile = source.get_tile(TileCoord { z: 2, x: 1, y: 1 }, query).await;
let _tile = source.get_tile(TileCoord { z: 0, x: 0, y: 0 }, query).await;
let _bytes = _tile.unwrap();
//write this bytes to a "result.png" file

let mut file = File::create("result.png").unwrap();
file.write_all(&_bytes).unwrap();

todo!()
}
Expand Down
Binary file not shown.

0 comments on commit eb5ed75

Please sign in to comment.