html5中svg canvas和图片之间相互转化思路代码


Posted in HTML / CSS onJanuary 24, 2014

最近有个需求,需要把网页部分内容做正文,并把原网页转成pdf作为附件,发送邮件给boss。由于我们这是报表类型的网站,在html5中控件开发无非就是canvas或者是svg,这里我们有几个控件是用svg,而svg在FoxMail邮件正文中无法正常显示,于是考虑将svg转成canvas显示,但是后来发现canvas也无法正常显示,最后不得已,只能将canvas标签再一次转成图片格式,终于解决了这个问题。下面就简单介绍一下实现过程。如下是一个svg标签

复制代码
代码如下:

<div id="svgContainer">
<svg id="svg"></svg>
</div>

首先需要获取svg标签以及内容:

var svgHtml = svgContainer.innerHTML();

将svg转成canvas需要用到google的一个插件canvg,可以上官网下载,也可以直接远程引用进来

接下来就是调用该插件的canvg(canvasId,svgHtml)方法来转成canvas,这个方法第一个参数就是canvas标签的id,第二个自然就是svg标签内容了,就这样,svg转成了canvas

然后就是将canvas转成图片了,这个更加简单了

var imgSrc = document.getElementById(canvasId).toDataUrl("image/png");//这其实是将canvas转成了图片,并返回图片的所有内容数据,如下即可显示图片:

复制代码
代码如下:

<img src=imgSrc />

这就是从svg->canvas->image的实现方法了,这个还是很有用的,因为不同的浏览器对svg和canvas的支持不同,这样的话,至少我们的控件总有方式能够正确显示,即使我们最后只能使用图片。
HTML / CSS 相关文章推荐
image-set实现Retina屏幕下图片显示详细介绍
Dec 24 HTML / CSS
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
Jan 07 HTML / CSS
利用css3实现的简单的鼠标悬停按钮
Nov 04 HTML / CSS
css3实现超炫风车特效
Nov 12 HTML / CSS
用CSS3打造HTML5的Logo(实现代码)
Jun 16 HTML / CSS
Bootstrap 学习分享
Nov 12 HTML / CSS
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
Jan 09 HTML / CSS
关于HTML5语义标签的实践(blog页面)
Jul 12 HTML / CSS
HTML块级标签汇总(小篇)
Jul 13 HTML / CSS
html5中canvas图表实现柱状图的示例
Nov 13 HTML / CSS
H5页面适配iPhoneX(就是那么简单)
Dec 02 HTML / CSS
网站性能延迟加载图像的五种技巧(小结)
Aug 13 HTML / CSS
HTML5 canvas画图并保存成图片的jcanvas插件
Jan 17 #HTML / CSS
Html5无刷新修改browser Url的方法
Jan 15 #HTML / CSS
html特殊符号示例 html特殊字符编码对照表
Jan 14 #HTML / CSS
html5使用canvas实现跟随光标跳动的火焰效果
Jan 07 #HTML / CSS
编写html5时调试发现脚本php等网页js、css等失效
Dec 31 #HTML / CSS
html5基础标签(html5视频标签 html5新标签用法)
Dec 30 #HTML / CSS
html5的canvas实现3d雪花飘舞效果
Dec 27 #HTML / CSS
You might like
Windows2003 下 MySQL 数据库每天自动备份
2006/12/21 PHP
PHP实现股票趋势图和柱形图
2015/02/07 PHP
基础的WordPress插件制作教程
2015/11/24 PHP
PHP设计模式之单例模式原理与实现方法分析
2018/04/25 PHP
PHP实现将上传图片自动缩放到指定分辨率,并保持清晰度封装类示例
2019/06/17 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
jquery png 透明解决方案(推荐)
2010/08/21 Javascript
javascript工具库代码
2012/03/29 Javascript
javascript 保存文件到本地实现方法
2012/11/29 Javascript
extjs中form与grid交互数据(record)的方法
2013/08/29 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
2013/11/23 Javascript
Jjcarousellite 实现图片列表滚动的简单实例
2013/11/29 Javascript
js 处理数组重复元素示例代码
2013/12/27 Javascript
如何实现textarea里的不同文本显示不同颜色
2014/01/20 Javascript
javascript实现日期格式转换
2014/12/16 Javascript
jquery 设置style:display的方法
2015/01/29 Javascript
js实现鼠标悬浮给图片加边框的方法
2015/01/30 Javascript
js实现简洁的TAB滑动门效果代码
2015/09/06 Javascript
Javascript在IE和Firefox浏览器常见兼容性问题总结
2016/08/03 Javascript
Ajax基础知识详解
2017/02/17 Javascript
微信小程序 es6-promise.js封装请求与处理异步进程
2017/06/12 Javascript
Angular 1.x个人使用的经验小结
2017/07/19 Javascript
详解react-native WebView 返回处理(非回调方法可解决)
2018/02/27 Javascript
解决Vue-cli npm run build生产环境打包,本地不能打开的问题
2018/09/20 Javascript
nodejs中实现用户注册路由功能
2019/05/20 NodeJs
[02:09]抵达西雅图!中国军团加油!
2014/07/07 DOTA
python下载文件记录黑名单的实现代码
2017/10/24 Python
Python实现利用163邮箱远程关电脑脚本
2018/02/22 Python
Windows下Python3.6安装第三方模块的方法
2018/11/22 Python
美国购买肉、鸭、家禽、鹅肝和熟食网站:D’Artagnan
2018/11/13 全球购物
德国旅行、体验和活动的预订平台:Watado
2019/12/04 全球购物
中软Java笔试题
2012/11/11 面试题
2019年c语言经典面试题目
2016/08/17 面试题
2014年信访维稳工作总结
2014/12/08 职场文书
行政复议答复书
2015/07/01 职场文书
Python面向对象编程之类的概念
2021/11/01 Python