php实现svg转化png格式的⽅法分析本⽂实例讲述了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 = ElementsByTagName('svg');
svg = svg[0];
svg.innerHTML = '<rect width="100%" height="100%" fill="#ffffff"></rect>' + svg.innerHTML;
var svgData = new XMLSerializer().serializeToString( svg );
var img = ateElement( "img" );jquery在线图片
img.setAttribute( "src", "data:image/svg+xml;base64," + btoa( unescape(encodeURIComponent(svgData)) ) );
var canvas = ateElement( "canvas" );
canvas.width = img.width;
canvas.height = img.height;
var ctx = Context( "2d" ); //取得画布的2d绘图上下⽂
ctx.drawImage( img, 0, 0 );
var base64Src = DataURL( "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在线编码解码⼯具供⼤家使⽤:
更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家PHP程序设计有所帮助。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论