agb/agb-image-converter/src/lib.rs

73 lines
1.8 KiB
Rust
Raw Normal View History

2021-04-20 09:40:07 +10:00
use std::path::PathBuf;
2021-04-20 08:15:03 +10:00
mod colour;
2021-04-20 09:40:07 +10:00
mod image_loader;
mod palette16;
use image_loader::Image;
2021-04-20 08:15:03 +10:00
pub use colour::Colour;
#[derive(Debug, Clone, Copy)]
pub enum TileSize {
Tile8,
Tile16,
}
2021-04-20 09:40:07 +10:00
impl TileSize {
fn to_size(&self) -> usize {
match &self {
TileSize::Tile8 => 8,
TileSize::Tile16 => 16,
}
}
}
2021-04-20 08:15:03 +10:00
pub struct ImageConverterConfig {
pub transparent_colour: Option<Colour>,
pub tile_size: TileSize,
2021-04-20 09:40:07 +10:00
pub input_image: PathBuf,
pub output_file: PathBuf,
}
pub fn convert_image(settings: &ImageConverterConfig) {
let image = Image::load_from_file(&settings.input_image);
let tile_size = settings.tile_size.to_size();
if image.width % tile_size != 0 || image.height % tile_size != 0 {
panic!("Image size not a multiple of tile size");
}
let optimiser = optimiser_for_image(&image, tile_size);
let optimisation_results = optimiser.optimise_palettes(settings.transparent_colour);
println!("{:?}", optimisation_results);
}
2021-04-20 09:40:07 +10:00
fn optimiser_for_image(image: &Image, tile_size: usize) -> palette16::Palette16Optimiser {
let tiles_x = image.width / tile_size;
let tiles_y = image.height / tile_size;
let mut palette_optimiser = palette16::Palette16Optimiser::new();
for y in 0..tiles_y {
for x in 0..tiles_x {
let mut palette = palette16::Palette16::new();
for j in 0..tile_size {
for i in 0..tile_size {
let colour = image.colour(x * tile_size + i, y * tile_size + j);
if !palette.add_colour(colour) {
panic!("Tile contains more than 16 colours");
}
}
}
palette_optimiser.add_palette(palette);
}
}
palette_optimiser
}