欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

php 实现svg转化png格式的方法分析

程序员文章站 2022-07-22 13:06:00
本文实例讲述了php 实现svg转化png格式的方法。分享给大家供大家参考,具体如下: svg转png实现 1.php imagick扩展插件 a.研究imagick插件方法...

本文实例讲述了php 实现svg转化png格式的方法。分享给大家供大家参考,具体如下:

svg转png实现

1.php imagick扩展插件

a.研究imagick插件方法

$im = new imagick($upload_path . $file_name);
$svg = file_get_contents($upload_path . $file_name);
$svg = '<?xml version="1.0" encoding="utf-8" standalone="no"?>'.$svg;
$im->readimageblob($svg);
// png settings
$im->setimageformat("png24");
$srcimage = $im->getimagegeometry(); //获取源图片宽和高
$im->resizeimage($srcimage['width'], $srcimage['height'], imagick::filter_lanczos, 1, false);
$im->writeimage($upload_path.'/'.$topng_name.'.png');
$im->clear();
$im->destroy();

b.遇到的问题

svg图片可以成功转化为png格式图片,但png图片存在问题:

1)线段丢失;

2)字体不展示;

3)svg文件中style标签样式不能解析;

2.弃用imagick插件,改为svg转canvas转png

a.svg转canvas

function drawinlinesvg($svg, callback) {
  var svg = $svg;
  var parser = new domparser();
  var doc = parser.parsefromstring(svg, "text/xml");
  svg = doc.getelementsbytagname('svg');
  svg = svg[0];
  svg.innerhtml = '<rect width="100%" height="100%" fill="#ffffff"></rect>' + svg.innerhtml;
  var svgdata = new xmlserializer().serializetostring( svg );
  var img = document.createelement( "img" );
  img.setattribute( "src", "data:image/svg+xml;base64," + btoa( unescape(encodeuricomponent(svgdata)) ) );
  img.onload = function () {
    var canvas = document.createelement( "canvas" );
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getcontext( "2d" ); //取得画布的2d绘图上下文
    ctx.drawimage( img, 0, 0 );
    canvas.todataurl( "image/png" );
    var base64src = canvas.todataurl( "image/png" );
    callback && callback(base64src); // 调用回掉函数
  };
 return;
}

b.canvas转png(base64src转化为png)

/* base64格式编码转换为图片并保存对应文件夹 */
function base64_image_content($base64_image_content,$path, $file_name = ''){
  //匹配出图片的格式
  if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
    if(!file_exists($path)){
      // 路径不存在
     return false;
    }
    $new_file = $path . $file_name;
    if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){
      return '/'.$new_file;
    }else{
      return false;
    }
  }else{
    return false;
  }
}

c.效果示例

1)svg格式

php 实现svg转化png格式的方法分析

2)png格式

php 实现svg转化png格式的方法分析

ps:这里再为大家提供几款比较实用的base64在线编码解码工具供大家使用:

base64编码解码工具:

在线图片转换base64工具:

base64在线编码解码 utf-8版:

base64在线编码解码 gb2312版: