纯JS实现将DIV中的内容转化为PNG图片
来源:互联网 发布:网络游戏编程设计专业 编辑:程序博客网 时间:2024/05/21 16:54
效果图:
SVG格式图片经过一系列转换变成PNG格式的图片并下载
HTML代码:
<style>
.JBS {
background-image: linear-gradient(-225deg,#4076FF 0%,#DE4AFF 100%,#61D2FF 100%);
width: 100%;
height: 200px
}
</style>
<h2>Input Div:</h2>
<div id="div" class="JBS"></div>
<h2>Output Image:</h2>
JavaScript代码 :
<script>
//1.将div转成svg
var data = "data:image/svg+xml," +
"<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'>" +
"<foreignObject width='100%' height='100%'>" +
"<div xmlns='http://www.w3.org/1999/xhtml' style='background-image: linear-gradient(-225deg,#4076FF 0%,#DE4AFF 100%,#61D2FF 100%);width:100%;height:200px'> </div>" +
"</foreignObject>" +
"</svg>";
var img = new Image();
img.src = data;
document.getElementsByTagName('body')[0].appendChild(img);
//2.svg转成canvas
var canvas = document.createElement('canvas'); //准备空画布
canvas.width = img.width;
canvas.height = img.height;
var context = canvas.getContext('2d'); //取得画布的2d绘图上下文
context.drawImage(img, 0, 0);
var a = document.createElement('a');
a.href = canvas.toDataURL('image/png'); //将画布内的信息导出为png图片数据
a.download = "MapByMathArtSys"; //设定下载名称
//3. 图片导出为 png 格式
var type = 'png';
var imgData = canvas.toDataURL(type);
/**
* 获取mimeType
* @param {String} type the old mime-type
* @return the new mime-type
*/
var _fixType = function (type) {
type = type.toLowerCase().replace(/jpg/i, 'jpeg');
var r = type.match(/png|jpeg|bmp|gif/)[0];
return 'image/' + r;
};
// 加工image data,替换mime type
imgData = imgData.replace(_fixType(type), 'image/octet-stream');
/**
* 在本地进行文件保存
* @param {String} data 要保存到本地的图片数据
* @param {String} filename 文件名
*/
var saveFile = function (data, filename) {
var save_link = document.createElementNS('http://www.w3.org/1999/xhtml', 'a');
save_link.href = data;
save_link.download = filename;
var event = document.createEvent('MouseEvents');
event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
save_link.dispatchEvent(event);
};
// 下载后的图片名
var filename = 'LoveCrystal_' + (new Date()).getTime() + '.' + type;
// download
saveFile(imgData, filename);
</script>
- 纯JS实现将DIV中的内容转化为PNG图片
- 将UIWebView内容保存为png图片
- Java实现pdf转化为png图片
- 将文件中的内容转化为数组
- js将图片转化为二进制流
- 如何将Qt窗口的内容转化为图片?
- 将js/css脚本放到png图片中的实践。
- 将js/css脚本放到png图片中的实践。
- 如何将iPhone程序中的png图片转换为可读的png图片(Windows版本)
- JAVA 将数据库中的内容转化为HTML
- Android WebP图片转化为png
- 纯js实现div内图片自适应大小----神器版!
- 纯win32实现PNG图片透明窗体
- JS如何导出Div的内容为图片
- JS如何导出Div的内容为图片
- JS如何导出Div的内容为图片
- ios 图片拼接 图片缩放 将webView上面的内容转化为图片 归纳整理
- ios 图片拼接 图片缩放 将webView上面的内容转化为图片 归纳整理
- thinkphp5-循环插入百万条数据
- leetcode_672. Bulb Switcher II ? 待解决
- MyBatis和Hibernate的优缺点对比
- 函数
- hdu 6214(2017 Qingdao Online:最小割边数)
- 纯JS实现将DIV中的内容转化为PNG图片
- Mac 配置cocos2d-x 安卓环境
- php获取当前域名
- 【Java基础12_2】String类
- Jquery点击按钮弹出alert
- deeplearing.ai week3 学习笔记
- spring注解与xml同时使用:bean命名问题及冲突
- 617. Merge Two Binary Trees(合并二叉树)
- 基于Qt的收银点餐系统之UI的基本实现(一)