本文实例讲述了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格式

2)png格式

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

base64编码解码工具:

在线图片转换base64工具:

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

base64在线编码解码 gb2312版: