canvas 下载二维码和图片加水印的方法


Posted in HTML / CSS onMarch 21, 2018

昨天介绍了一个生成二维码的插件QRCode.js,它是借助HTML5 Canvas绘制而成。所以,今天的主角就是canvas啦–canvas的实际应用。

一、下载二维码(查看如何生成二维码

HTMLCanvasElement提供了toDataURL方法,该方法返回一个包含被类型参数规定图像表现格式的data URI。通过该方法我们就可以生成二维码图片并下载了。示例如下:

/*html*/
<div id="qrcode">div>
<a href="javascript:;" download="二维码" id="down">下载二维码</a>

/*js*/
var canvas = document.getElementsByTagName('canvas')[0];
var downImg = document.getElementById('down')
img.href = document.getElementsByTagName('canvas')[0].toDataURL('image/png')

二、图片加水印

利用canvas的fillText和drawImage方法可以轻松实现给图片加水印。示例如下:

/*html*/
<canvas id="canvas"></canvas>

/*js*/
var img = new Image();   // 创建img元素
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext('2d');
img.src = 'myImage.png';

img.onload = function(){
    ctx.drawImage(img, 0, 0);
    ctx.font="30px yahei";   //设置水印文字
    ctx.fillText("大前端", 1100, 260)
}

今天暂时写到这里,欢迎分享关于canvas的其他应用。希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
a标签的css样式四个状态
Mar 09 HTML / CSS
CSS3中动画属性transform、transition和animation属性的区别
Sep 25 HTML / CSS
利用CSS3的checked伪类实现OL的隐藏显示的方法
Dec 18 HTML / CSS
CSS3 Flex 弹性布局实例代码详解
Nov 01 HTML / CSS
纯CSS3实现移动端展开和收起效果的示例代码
Apr 26 HTML / CSS
HTML5 progress和meter控件_动力节点Java学院整理
Jul 06 HTML / CSS
HTML5+JS实现俄罗斯方块原理及具体步骤
Nov 29 HTML / CSS
Html5原创俄罗斯方块(基于canvas)
Jan 07 HTML / CSS
移动端Html5中百度地图的点击事件
Jan 31 HTML / CSS
HTML5超文本标记语言的实现方法
Sep 24 HTML / CSS
sass 常用备忘案例详解
Sep 15 HTML / CSS
快速创建 HTML5 Canvas 电信网络拓扑图的示例代码
Mar 21 #HTML / CSS
html5调用app分享功能示例(WebViewJavascriptBridge)
Mar 21 #HTML / CSS
浅谈html5与APP混合开发遇到的问题总结
Mar 20 #HTML / CSS
在canvas上实现元素图片镜像翻转动画效果的方法
Mar 20 #HTML / CSS
HTML5 新表单类型示例代码
Mar 20 #HTML / CSS
浅谈基于Canvas的手绘风格图形库Rough.js
Mar 19 #HTML / CSS
基于HTML5 WebGL的3D机房的示例
Mar 16 #HTML / CSS
You might like
小偷PHP+Html+缓存
2006/12/20 PHP
php 来访国内外IP判断代码并实现页面跳转
2009/12/18 PHP
Zend的AutoLoad机制介绍
2012/09/27 PHP
解析mysql中UNIX_TIMESTAMP()函数与php中time()函数的区别
2013/06/24 PHP
使用PHP编写发红包程序
2015/07/22 PHP
表单元素与非表单元素刷新区别详细解析
2013/11/06 Javascript
jquery 删除cookie失效的解决方法
2013/11/12 Javascript
Javascript中call的两种用法实例
2013/12/13 Javascript
node.js中的Socket.IO使用实例
2014/11/04 Javascript
javascript实现类似超链接的效果
2014/12/26 Javascript
JS选中checkbox后获取table内一行TD所有数据的方法
2015/07/01 Javascript
详解JavaScript中数组的相关知识
2015/07/29 Javascript
jquery实现仿新浪微博评论滚动效果
2015/08/06 Javascript
如何使用jquery easyui创建标签组件
2015/11/18 Javascript
JavaScript中iframe实现局部刷新的几种方法汇总
2016/01/06 Javascript
JS实现CheckBox复选框全选、不选或全不选功能
2020/07/28 Javascript
浅谈MVC+EF easyui dataGrid 动态加载分页表格
2016/11/10 Javascript
vue-dialog的弹出层组件
2020/05/25 Javascript
微信小程序之获取当前位置经纬度以及地图显示详解
2017/05/09 Javascript
创建简单的node服务器实例(分享)
2017/06/23 Javascript
React-native桥接Android原生开发详解
2018/01/17 Javascript
p5.js入门教程之键盘交互
2018/03/19 Javascript
JS闭包原理与应用经典示例
2018/12/20 Javascript
Node.js系列之安装配置与基本使用(1)
2019/08/30 Javascript
unittest+coverage单元测试代码覆盖操作实例详解
2018/04/04 Python
Python 字符串与二进制串的相互转换示例
2018/07/23 Python
python读取有密码的zip压缩文件实例
2019/02/08 Python
windows10环境下用anaconda和VScode配置的图文教程
2020/03/30 Python
高中语文教学反思
2014/01/16 职场文书
2014党员整改措施思想汇报
2014/10/07 职场文书
设立有限责任公司出资协议书
2014/11/01 职场文书
自荐信格式模板
2015/03/27 职场文书
学历证明范文
2015/06/16 职场文书
授权协议书范本(3篇)
2019/10/15 职场文书
慰问信(范文3篇)
2019/10/23 职场文书
最新最全的手机号验证正则表达式
2022/02/24 Javascript