invert color

This commit is contained in:
2024-07-07 13:51:40 +02:00
parent 05316561f2
commit 0d7e950503

View File

@@ -1,9 +1,15 @@
use image;
use image::GenericImageView;
use crate::libs::args;
use colored::Colorize;
use image;
use image::GenericImageView;
fn grayscale_ascii(img: &image::DynamicImage, width: u32, height: u32, invert: bool, pixel_size: usize) -> String {
fn grayscale_ascii(
img: &image::DynamicImage,
width: u32,
height: u32,
invert: bool,
pixel_size: usize,
) -> String {
let mut ascii_img = String::new();
for y in 0..height {
@@ -34,22 +40,36 @@ fn grayscale_ascii(img: &image::DynamicImage, width: u32, height: u32, invert: b
ascii_img
}
fn colorful_ascii(img: &image::DynamicImage, width: u32, height: u32, pixel_size: usize) -> String {
fn colorful_ascii(
img: &image::DynamicImage,
width: u32,
height: u32,
invert: bool,
pixel_size: usize,
) -> String {
let mut ascii_img = String::new();
for y in 0..height {
for x in 0..width {
let pixel = img.get_pixel(x, y);
let red = pixel[0];
let green = pixel[1];
let blue = pixel[2];
let mut red = pixel[0];
let mut green = pixel[1];
let mut blue = pixel[2];
let pixel_iterator: Vec<u16> = vec![red.into(), green.into(), blue.into()];
let darkest_color: &u16 = pixel_iterator.iter().min().unwrap();
let brightest_color: &u16 = pixel_iterator.iter().max().unwrap();
let brightness = ((darkest_color + brightest_color) / 2) as u8;
let mut brightness = ((darkest_color + brightest_color) / 2) as u8;
if invert {
red = 255 - red;
green = 255 - green;
blue = 255 - blue;
brightness = 255 - brightness;
}
let mut char_pixel = select_char(&brightness).repeat(pixel_size);
@@ -92,7 +112,7 @@ pub fn to_ascii(img: &image::DynamicImage, args: &args::Args) -> String {
let (width, height) = img.dimensions();
if args.colorful {
return colorful_ascii(img, width, height, args.pixel);
return colorful_ascii(img, width, height, args.invert, args.pixel);
}
grayscale_ascii(img, width, height, args.invert, args.pixel)