canvas转图片
| <script> | |
| var canvas, context2D, canvasimg, context2Dimg ,fontSize = 100; | |
| window.onload = function() { | |
| canvas =document.getElementById("canvas"); | |
| context2D = canvas.getContext("2d"); | |
| canvasimg =document.getElementById("canvasimg"); | |
| context2Dimg = canvasimg.getContext("2d"); | |
| context2D.font ="100px 黑体"; | |
| context2D.fillText("V", 0, fontSize); | |
| //添加range事件 | |
| document.getElementById("range").addEventListener("mouseup", function() { | |
| fontSize = this.value; | |
| context2D.font = this.value +"px 黑体"; | |
| context2D.clearRect(0, 0, canvas.width, canvas.height); | |
| context2D.fillText("V", 0, fontSize); | |
| }); | |
| } | |
| function go(){ | |
| var img = convertCanvasToImage(document.getElementById("canvas")); | |
| context2Dimg.clearRect(0, 0, canvas.width, canvas.height); | |
| context2Dimg.drawImage(img, 0, 0); | |
| //需要将Base64编码转换为Blob(一段二进制数据)对象 ,后才能生成文件下载 参考 http://javascript.ruanyifeng.com/htmlapi/file.html#toc0 | |
| var blob = new Blob([Base64Binary.decodeArrayBuffer(canvas.toDataURL("image/png").substring(22))]); //删除字符串前的提示信息 "data:image/png;base64," | |
| var a = document.createElement("a"); | |
| a.href = window.URL.createObjectURL(blob); | |
| a.download = "test.png"; | |
| a.textContent = "下载图片->"; | |
| document.body.appendChild(a); | |
| //a.click(); | |
| show(); | |
| } | |
| //将图片显示在网页中 | |
| function show(){ | |
| var img = convertCanvasToImage(document.getElementById("canvas")); | |
| document.body.appendChild(img); | |
| } | |
| //将canvas变成图片png | |
| function convertCanvasToImage(canvas) { | |
| var image = new Image(); | |
| image.style.border="1px solid blue"; | |
| image.src = canvas.toDataURL("image/png"); | |
| return image; | |
| } | |
| </script> | |
| <style> | |
| input[type=range]:before { content: attr(min); padding-right: 5px; } | |
| input[type=range]:after { content: attr(max); padding-left: 5px;} | |
| </style> | |
| </head> | |
| <body> | |
| <input id="range" type="range" name="range" min="100" max="500" step="100" value="100" /> | |
| <canvas id="canvas" style="border:1px solid red;" width=500 height=500></canvas> | |
| <button onclick="go();">canvas转图片,再加载到右边canvas中</button> | |
| <canvas id="canvasimg" style="border:1px solid red;" width=500 height=500></canvas> | |
| </body> | |
| <script> | |
| //base64转Blob 地址 https://github.com/danguer/blog-examples/blob/master/js/base64-binary.js |
canvas转图片的更多相关文章
- canvas学习笔记:canvas对图片的像素级处理--ImageData的应用
学习了canvas的基本绘图功能后,惊喜的发现canvas对图片数据也有相当强大的处理功能,能够从像素级别操作位图,当然[lte ie8]不支持. 主要的函数有三个: ctx.createImageD ...
- 快速解决Canvas.toDataURL 图片跨域的问题
出现Canvas.toDataURL 图片跨域问题怎么解决呢?下面小编就为大家带来一篇Canvas.toDataURL 图片跨域问题的快速解决方法.一起跟随小编过来看看吧 如题,在将页面的图片地址进行 ...
- 用canvas实现图片滤镜效果详解之灰度效果
前面展示了一些canvas实现图片滤镜效果的展示,并且给出了相应的算法,下面来介绍一下具体的实现方法. 前面介绍的特效中灰度效果最简单,就从这里开始介绍吧. 1.获取图像数据 img.src = ’h ...
- 使用canvas进行图片裁剪简单功能
1.html部分 使用一个input[type="file"]进行图片上传: canvas进行图片的裁剪展示 <div> <input type="fi ...
- 利用canvas 导出图片
1.使用canvas绘制图片,并将图片导出. 在本地直接访问静态网页时,无法使用toDataURL(),需要将网页发布后,canvas才能使用toDataURL获取画布上的内容.因为canvas不允许 ...
- canvas将图片转为base64
最简例子 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta ...
- [JavaScript] canvas 合成图片和文字
Canvas Canvas 是 HTML5 新增的组件,就像一个画板,用 js 这杆笔,在上面乱涂乱画 创建一个 canvas <canvas id="stockGraph" ...
- canvas和图片之间的互相装换
canvas和图片之间的互相装换 一.总结 一句话总结:一个是canvas的drawImage方法,一个是canvas的toDataURL方法 canvas drawImage() Image对象 c ...
- Canvas 实现图片合成并下载合成图片
现在经常会遇到那种带二维码的推广图片,如下图所示: 1是整张推广图的背景,2是二维码.这种图片的背景是保持不变的,里面的二维码是变化的.所以我们需要把二维码单独生成然后与背景合并. 我们可以通过can ...
随机推荐
- [转]有关Apache alias的一点问题
转自:http://www.thinkphp.cn/topic/11973.html Apache 的Alias 指令映射URL到文件系统的特定区域 一个简单的例子: Alias /mytest /w ...
- [转]用chrome模拟微信浏览器访问需要OAuth2.0网页授权的页面
FROM : http://blog.csdn.net/gavin_luo/article/details/40620217 现在很流行微信网页小游戏,用html5制作的小游戏移过来,可以放到微信浏览 ...
- jquery fullPage
FROM : http://www.dowebok.com/77.html 应用: http://txhd.163.com/
- idea 2018.1破解激活方法,有效期至2099年 idea 激活 破解
最近笔者测试了好多破解Idea的方法,最简单操作方法莫过于用license server激活,但是此类方法对最新的2017.3.2版已经无效了,亲测哦,如下图所示. 针对新版的IntelliJ ID ...
- C# 数组基础知识
数组的属性: 数组可以是一维.多维或交错的. 数值数组元素的默认值设置为零,而引用元素的默认值设置为 null. 交错数组是数组的数组,因此,它的元素是引用类型,初始化为 null. 数组的索引从零开 ...
- api重复引用导致的诡异问题排查
api重复引用导致的诡异问题排查 最近一个项目上线前开发环境.测试环境都能正常打包并运行.然而到了准生产环境和生产环境则报一些诡异的错误信息: [INFO] --------------------- ...
- Git SVN 版本控制 简介 总结 MD
Git 使用准备 主流的 Git 托管网站 GitLab,主流网站,私有仓库也完全免费,功能更强大,页面精美,操作方便 GitHub,最著名的免费Git托管网站,缺点是免费的不支持私有项目 OSChi ...
- vue-自定义组件传值
项目中,我们经常会遇到自定义组件传值的问题,方法很多种,但是原理很简单,下述文档总结实际项目中使用的传值方式. 父组件传递给子组件某一值,子组件内会修改该值,然后父组件需要获取新值 在 Vue 中 ...
- 使用新版SDK不想跳转微博客户端能否直接发送微博分享?
如题啊如题! 新版本中没有StatusesAPI?????
- JS滚轮事件onmousewheel
典型的应用时鼠标滚轮滚动控制图片或者文字的大小,例如此类的转动鼠标滚轮实现缩放等等交互效果中,会用到 Mousewheel 事件.在大多数浏览器(IE6, IE7, IE8, Opera 10+, S ...