From 695f4ff1396468d90e31b868d47e513266e583c3 Mon Sep 17 00:00:00 2001 From: FabianLars Date: Tue, 17 Sep 2024 14:48:31 +0200 Subject: [PATCH] feat(cli): Add transparent padding to macos icon --- crates/tauri-cli/src/icon.rs | 35 ++++++++++++++++++++++++++++++----- 1 file changed, 30 insertions(+), 5 deletions(-) diff --git a/crates/tauri-cli/src/icon.rs b/crates/tauri-cli/src/icon.rs index e14f078e8f7f..1c5aeaff674c 100644 --- a/crates/tauri-cli/src/icon.rs +++ b/crates/tauri-cli/src/icon.rs @@ -58,6 +58,9 @@ pub struct Options { /// The background color of the iOS icon - string as defined in the W3C's CSS Color Module Level 4 . #[clap(long, default_value = "#fff")] ios_color: String, + + #[clap(long)] + no_macos_padding: bool, } enum Source { @@ -155,7 +158,7 @@ pub fn command(options: Options) -> Result<()> { if png_icon_sizes.is_empty() { appx(&source, &out_dir).context("Failed to generate appx icons")?; - icns(&source, &out_dir).context("Failed to generate .icns file")?; + icns(&source, &out_dir, !options.no_macos_padding).context("Failed to generate .icns file")?; ico(&source, &out_dir).context("Failed to generate .ico file")?; png(&source, &out_dir, ios_color).context("Failed to generate png icons")?; @@ -196,20 +199,42 @@ fn appx(source: &Source, out_dir: &Path) -> Result<()> { } // Main target: macOS -fn icns(source: &Source, out_dir: &Path) -> Result<()> { +fn icns(source: &Source, out_dir: &Path, padding: bool) -> Result<()> { log::info!(action = "ICNS"; "Creating icon.icns"); let entries: HashMap = serde_json::from_slice(include_bytes!("helpers/icns.json")).unwrap(); let mut family = IconFamily::new(); + let padding_percent = 100.0 / 1024.0; for (name, entry) in entries { - let size = entry.size; + let inner_size = if padding { + entry.size - (entry.size as f64 * padding_percent).round() as u32 + } else { + entry.size + }; let mut buf = Vec::new(); - let image = source.resize_exact(size)?; + let icon = source.resize_exact(inner_size)?; + + let image = { + if padding { + let mut image = + ImageBuffer::from_fn(entry.size, entry.size, |_, _| image::Rgba([0, 0, 0, 0])); + + image::imageops::overlay( + &mut image, + &icon, + ((entry.size - inner_size) / 2) as i64, + ((entry.size - inner_size) / 2) as i64, + ); + DynamicImage::from(image) + } else { + icon + } + }; - write_png(image.as_bytes(), &mut buf, size)?; + write_png(image.as_bytes(), &mut buf, entry.size)?; let image = icns::Image::read_png(&buf[..])?;