我尝试使用 meyfa/php-svg PHP 库将 SVG 图像转换为 PNG。
这是代码
<?php
require __DIR__ . '/vendor/autoload.php';
use SVG\SVG;
$image = SVG::fromFile('new.svg');
$doc = $image->getDocument();
$rasterImage = $image->toRasterImage(1024,1024);
imagepng($rasterImage,'output.png');
?>
svg 文件:https://drive.google.com/file/d/1jDNOzoU9aG2sDj-No_v-psjMiQ1wVPEA/view?usp=sharing
<?xml version="1.0" encoding="utf-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Layer_1" x="0px"
y="0px" viewBox="0 0 320.8 417.7" xml:space="preserve" style="enable-background: new 0 0 320.8 417.7" width="1024"
height="720">
<style type="text/css">
<![CDATA[
@import url('https://online-qr-generator.com/themes/altum/assets/fonts/style.css?family=GT-Walsheim-Pro');
.st1 {
font-family: 'GT-Walsheim-Pro';
}
.st2 {
font-size: 42px;
}
.black-area {
fill: #000000;
}
.white-area {
fill: #ffffff;
}
.text-color {
fill: #FFF;
}
]]>
</style>
<g>
<path class="black-area"
d="M320.8,14.9C320.8,4,317.2,0,306.9,0H13.6C4.6,0,2.3,1.9,0,10.5v396.3c0.5,5.7,2.8,9.9,9,11h302.4c3.6-1,7-2.3,8.3-6.3 c0.9-2.9,1.2-5.9,1.1-8.8v-49.3C320.8,240.5,320.8,127.7,320.8,14.9z M307.5,303.6c0,4.1-0.9,5.1-5.1,5.1 c-94.8-0.1-189.7-0.1-284.5,0c-4.1,0-5.1-0.9-5.1-5.1c0.2-47.5,0.1-94.9,0.1-142.4c0-47.6,0.1-95.3-0.1-142.9 c0-4.1,0.9-5.1,5.1-5.1c94.8,0.1,189.7,0.1,284.5,0c4.1,0,5.1,0.9,5.1,5.1C307.4,113.5,307.4,208.5,307.5,303.6z" />
<path class="white-area"
d="M307.5,303.6c0,4.1-0.9,5.1-5.1,5.1c-94.8-0.1-189.7-0.1-284.5,0c-4.1,0-5.1-0.9-5.1-5.1 c0.2-47.5,0.1-94.9,0.1-142.4c0-47.6,0.1-95.3-0.1-142.9c0-4.1,0.9-5.1,5.1-5.1c94.8,0.1,189.7,0.1,284.5,0c4.1,0,5.1,0.9,5.1,5.1 C307.4,113.5,307.4,208.5,307.5,303.6z" />
<text x="55" y="0" transform="matrix(1 0 0 1 105.65 380.0901)" class="st1 st2 text-color"
style="text-anchor: middle">Scan me!</text>
</g>
<g>
<defs>
<linearGradient id="linear">
<stop offset="30%" style="stop-color: GLC1;" />
<stop offset="70%" style="stop-color: GLC2;" />
</linearGradient>
</defs>
<defs>
<radialGradient id="radial">
<stop offset="10%" style="stop-color: GRC1" />
<stop offset="90%" style="stop-color: GRC2" />
</radialGradient>
</defs>
<defs>
<linearGradient id="linear-b">
<stop offset="30%" style="stop-color: GLCB1;" />
<stop offset="70%" style="stop-color: GLCB2;" />
</linearGradient>
</defs>
<defs>
<radialGradient id="radial-b">
<stop offset="10%" style="stop-color: GRCB1" />
<stop offset="90%" style="stop-color: GRCB2" />
</radialGradient>
</defs>
</g>
<image
xlink:href=""
x="35" y="30" width="250" height="250" />
</svg>
如何将 svg 图像转换为具有正确尺寸的 png?
您可以尝试choowx/rasterize-svg和chillerlan/php-qrcode。样本:
注意事项: 图像转换模块使用sharp,需要nodejs。 Sharp lib 依赖于 libvips,您可以直接使用 [php-vips](https://github.com/libvips/php-vips]。使用 php-vips 的示例代码:
require __DIR__ . '/vendor/autoload.php';
use Jcupitt\Vips;
try {
// Load the SVG file
// You can specify the desired dimensions using the 'dpi' option
$image = Vips\Image::newFromFile("input.svg", [
"dpi" => 300 // Adjust DPI as needed for desired resolution
]);
// Save as PNG
$image->writeToFile("output.png");
} catch (Exception $e) {
echo "Error: " . $e->getMessage() . "\n";
}