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 ...
随机推荐
- excel System.Runtime.InteropServices.COMException (0x80010105): 服务器出现意外情况。 (异常来自 HRESULT:0x80010105 (RPC_E
System.Runtime.InteropServices.COMException (0x80010105): 服务器出现意外情况. (异常来自 HRESULT:0x80010105 (RPC_E ...
- 两个Activity之间共享数据、互相访问的另一种方式的实现
本帖最后由 勇敢的心_ 于 2010-9-29 11:51 编辑 本人从windows编程转过来学习Android开发,一直在想如果两个Activity之间能够像C#或delphi中的Form一样,可 ...
- python测试开发django-24.表单提交之get请求
前言 通常我们需要在html页面上输入框里面输入数据,比如登录的时候,输入账号和密码,点提交按钮. 从html把数据提交到服务端,服务端接收数据后判断提交的数据,然后做出对应的响应,这么一整个流程就是 ...
- Java中使用正则表达式获取网页中所有图片的路径
public static List<String> getImageSrc(String htmlCode) { List<String> imageSrcList = ne ...
- Leetcode刷题记录:计算复数乘法
题目要求 计算两个复数的乘积. 参考题解 这道题感觉很简单,主要是对复数的表达式进行解析,然后套用公式,输出结果就可以了. class Solution: def complexNumberMulti ...
- Asp.Net 获取物理路径
一.AppDomain 1.AppDomin获取当前前程序域目录 2.不需要请求上线文实例,例如在Global.ascx中访问等 //网站物理目录 AppDomain.CurrentDomain.Ba ...
- npm出错的解决方案
npm show grpc # 返回版本号 # 安装旧版本: npm install grpc@1.2.0
- redis 负载均衡 集群配置
redis 官网 http://redis.io/ 中文网站 http://redis.cn/ 谷歌代码的redis项目 https://code.google.com/p/redis/ http:/ ...
- go语言之进阶篇http客户端编程
1.http客户端编程 示例: http_server.go package main import ( "fmt" "net/http" ) //w, 给客户 ...
- Swift编程语言学习1.7——断言
断言 可选能够让你推断值是否存在,你能够在代码中优雅地处理值缺失的情况.然而,在某些情况下,假设值缺失或者值并不满足特定的条件,你的代码可能并不须要继续执行.这时.你能够在你的代码中触发一个断言(as ...