From 463c21d25a03f21545f3f6291b7b3f1ec2bbf0b2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Julius=20H=C3=A4rtl?= Date: Sun, 1 Sep 2024 11:44:44 +0200 Subject: [PATCH] fix: Properly calculate intermediate icon for touch icon generation MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Julius Härtl --- apps/theming/lib/IconBuilder.php | 29 ++++++++++++----------------- 1 file changed, 12 insertions(+), 17 deletions(-) diff --git a/apps/theming/lib/IconBuilder.php b/apps/theming/lib/IconBuilder.php index 844146724a51f..e7e83a0b4c04b 100644 --- a/apps/theming/lib/IconBuilder.php +++ b/apps/theming/lib/IconBuilder.php @@ -124,9 +124,10 @@ public function renderAppIcon($app, $size) { $color = $this->themingDefaults->getColorPrimary(); // generate background image with rounded corners + $cornerRadius = 0.2 * $size; $background = '' . - '' . - '' . + '' . + '' . ''; // resize svg magic as this seems broken in Imagemagick if ($mime === 'image/svg+xml' || substr($appIconContent, 0, 4) === 'setBackgroundColor(new ImagickPixel('transparent')); + $tmp->setResolution(72, 72); $tmp->readImageBlob($svg); $x = $tmp->getImageWidth(); $y = $tmp->getImageHeight(); - $res = $tmp->getImageResolution(); $tmp->destroy(); - if ($x > $y) { - $max = $x; - } else { - $max = $y; - } - // convert svg to resized image $appIconFile = new Imagick(); - $resX = (int)(512 * $res['x'] / $max * 2.53); - $resY = (int)(512 * $res['y'] / $max * 2.53); + $resX = (int)(72 * $size / $x); + $resY = (int)(72 * $size / $y); $appIconFile->setResolution($resX, $resY); $appIconFile->setBackgroundColor(new ImagickPixel('transparent')); $appIconFile->readImageBlob($svg); @@ -166,22 +162,21 @@ public function renderAppIcon($app, $size) { ) { $appIconFile->negateImage(false); } - $appIconFile->scaleImage(512, 512, true); } else { $appIconFile = new Imagick(); $appIconFile->setBackgroundColor(new ImagickPixel('transparent')); $appIconFile->readImageBlob($appIconContent); - $appIconFile->scaleImage(512, 512, true); } // offset for icon positioning - $border_w = (int)($appIconFile->getImageWidth() * 0.05); - $border_h = (int)($appIconFile->getImageHeight() * 0.05); + $padding = 0.15; + $border_w = (int)($appIconFile->getImageWidth() * $padding); + $border_h = (int)($appIconFile->getImageHeight() * $padding); $innerWidth = ($appIconFile->getImageWidth() - $border_w * 2); $innerHeight = ($appIconFile->getImageHeight() - $border_h * 2); $appIconFile->adaptiveResizeImage($innerWidth, $innerHeight); // center icon - $offset_w = (int)(512 / 2 - $innerWidth / 2); - $offset_h = (int)(512 / 2 - $innerHeight / 2); + $offset_w = (int)($size / 2 - $innerWidth / 2); + $offset_h = (int)($size / 2 - $innerHeight / 2); $finalIconFile = new Imagick(); $finalIconFile->setBackgroundColor(new ImagickPixel('transparent'));