HTML5 Canvas绘制文本及图片的基础教程


Posted in HTML / CSS onMarch 14, 2016

绘制文本

在HTML5中,我们还可以在Canvas「画布」上绘制我们所需的文本文字,其中所涉及到的CanvasRenderingContext2D对象的主要属性和方法如下:

属性或方法 基本描述
font 设置绘制文字所使用的字体,例如20px 宋体,默认值为10px sans-serif。该属性的用法与css font属性一致,例如italic bold 14px/30px Arial,宋体
fillStyle 用于设置画笔填充路径内部的颜色、渐变和模式。该属性的值可以是一个表示CSS颜色值的字符串。如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象
strokeStyle 用于设置画笔绘制路径的颜色、渐变和模式。该属性的值可以是一个表示CSS颜色值的字符串。如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象
fillText(string text, int x, int y[, int maxWidth]) 从指定坐标点位置开始绘制填充的文本文字。参数maxWidth是可选的,如果文本内容宽度超过该参数设置,则会自动按比例缩小字体以适应宽度。与本方法对应的样式设置属性为fillStyle。
strokeText(string text, int x, int y[, int maxWidth]) 从指定坐标点位置开始绘制非填充的文本文字(文字内部是空心的)。参数maxWidth是可选的,如果文本内容宽度超过该参数设置,则会自动按比例缩小字体以适应宽度。该方法与fillText()用法一致,不过strokeText()绘制的文字内部是非填充(空心)的,fillText()绘制的文字是内部填充(实心)的。与本方法对应的样式设置属性为strokeStyle。

从上面的API描述信息中我们可以得知,在Canvas中可以使用两种方式来绘制文本文字:一种是使用fillText()+fillStyle来绘制填充(实心)的文字;一种是使用strokeText()+strokeStyle绘制非填充(空心)的文字。

下面,我们先来看看如何使用canvas绘制实心文字,具体html代码如下:

JavaScript Code复制内容到剪贴板
  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4. <meta charset="UTF-8">   
  5. <title>HTML5 Canvas绘制文本文字入门示例</title>   
  6. </head>   
  7. <body>   
  8.   
  9. <!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->   
  10. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   
  11. 您的浏览器不支持canvas标签。   
  12. </canvas>   
  13.   
  14. <script type="text/javascript">   
  15. //获取Canvas对象(画布)   
  16. var canvas = document.getElementById("myCanvas");   
  17. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  18. if(canvas.getContext){     
  19.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  20.     var ctx = canvas.getContext("2d");   
  21.        
  22.     //设置字体样式   
  23.     ctx.font = "30px Courier New";   
  24.     //设置字体填充颜色   
  25.     ctx.fillStyle = "blue";   
  26.     //从坐标点(50,50)开始绘制文字   
  27.     ctx.fillText("CodePlayer+中文测试", 50, 50);   
  28. }   
  29. </script>   
  30. </body>   
  31. </html>  

对应的显示效果如下:
HTML5 Canvas绘制文本及图片的基础教程

接着,我们使其他环境条件均保持不变,再次使用strokeText()+strokeStyle方式来绘制上述示例中的文字,对应的JavaScript代码如下:

JavaScript Code复制内容到剪贴板
  1. <script type="text/javascript">   
  2. //获取Canvas对象(画布)   
  3. var canvas = document.getElementById("myCanvas");   
  4. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  5. if(canvas.getContext){     
  6.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  7.     var ctx = canvas.getContext("2d");   
  8.        
  9.     //设置字体样式   
  10.     ctx.font = "30px Courier New";   
  11.     //设置字体颜色   
  12.     ctx.strokeStyle = "blue";   
  13.     //从坐标点(50,50)开始绘制文字   
  14.     ctx.strokeText("CodePlayer+中文测试", 50, 50);   
  15. }   
  16. </script>  

我们再次使用浏览器访问页面,将会看到如下显示效果(效果图片中的"CodePlayer"字样其实也是空心的,只是由于字体较小导致两侧看起来重叠在了一起):
HTML5 Canvas绘制文本及图片的基础教程

绘制图片
在html5中,除了利用canvas绘制矢量图形之外,我们还可以在canvas「画布」上绘制现有的图像文件。

首先,我们来看看使用canvas绘制图像文件需要用到CanvasRenderingContext2D对象的哪些主要属性和方法:

XML/HTML Code复制内容到剪贴板
  1. drawImage(mixed image, int x, int y)  

以canvas上指定的坐标点开始,按照图像的原始尺寸大小绘制整个图像。这里的image可以是Image对象,也可以是Canvas对象(下同)。

XML/HTML Code复制内容到剪贴板
  1. drawImage(mixed image, int x, int y, int width, int height)  

以canvas上指定的坐标点开始,以指定的大小(width和height)绘制整个图像,图像将根据指定的尺寸自动进行相应的缩放。
drawImage(mixed image, int imageX, int imageY, int imageWidth, int imageHeight, int canvasX, int canvasY, int canvasWidth, int canvasHeight)
将指定图像的局部图像(以(imageX, imageY)为左上角、宽度为imageWidth、高度为imageHeight的矩形部分)绘制到canvas中以(canvasX,canvasY)为左上角坐标、宽度为canvasWidth、高度为canvasHeight的矩形区域中
是的,你没有看错。要在canvas中绘制图像,我们可以使用一个名为drawImage()的方法,不过该方法具有三种不同的变体,每个方法变体允许接收的参数不仅数量不同,连参数的含义也不尽相同。

在这里,我们对上述三个变体分别举例说明。

首先,我们使用drawImage()的第一个变体在canvas上绘制Google的logo图片(原始尺寸为550 x 190)。

JavaScript Code复制内容到剪贴板
  1. <!DOCTYPE html>   
  2. <html>   
  3. <head>   
  4. <meta charset="UTF-8">   
  5. <title>HTML5 Canvas绘制图像入门示例</title>   
  6. </head>   
  7. <body>   
  8.   
  9. <!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->   
  10. <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   
  11. 您的浏览器不支持canvas标签。   
  12. </canvas>   
  13.   
  14. <script type="text/javascript">   
  15. //获取Canvas对象(画布)   
  16. var canvas = document.getElementById("myCanvas");   
  17. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  18. if(canvas.getContext){     
  19.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  20.     var ctx = canvas.getContext("2d");   
  21.        
  22.     //创建新的图片对象   
  23.     var img = new Image();   
  24.     //指定图片的URL   
  25.     img.src = "http://www.365mini.com/image/google_logo.png";   
  26.     //浏览器加载图片完毕后再绘制图片   
  27.     img.onload = function(){   
  28.         //以Canvas画布上的坐标(10,10)为起始点,绘制图像   
  29.         ctx.drawImage(img, 10, 10);                
  30.     };   
  31. }   
  32. </script>   
  33. </body>   
  34. </html>  

对应的显示效果如下:
HTML5 Canvas绘制文本及图片的基础教程

由于Google的Logo图像过大,超过了canvas的尺寸范围,因此只能显示出图像的一部分。此时,我们使用第2个变体将Google的logo图像缩小到指定的宽度和高度,并绘制到canvas中。

JavaScript Code复制内容到剪贴板
  1. <script type="text/javascript">   
  2. //获取Canvas对象(画布)   
  3. var canvas = document.getElementById("myCanvas");   
  4. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  5. if(canvas.getContext){     
  6.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  7.     var ctx = canvas.getContext("2d");   
  8.        
  9.     //创建新的图片对象   
  10.     var img = new Image();   
  11.     //指定图片的URL   
  12.     img.src = "http://www.365mini.com/image/google_logo.png";   
  13.     //浏览器加载图片完毕后再绘制图片   
  14.     img.onload = function(){   
  15.         //以Canvas画布上的坐标(10,10)为起始点,绘制图像   
  16.         //图像的宽度和高度分别缩放到350px和100px   
  17.         ctx.drawImage(img, 10, 10, 350, 100);                
  18.     };   
  19. }   
  20. </script>  

我们将Google的logo图像进行缩放后,此时就可以在canvas中看到整个图像了:
HTML5 Canvas绘制文本及图片的基础教程

最后,我们使用第三个方法变体将Google logo中的"Goo"部分图像绘制到canvas中("Goo"部分的图像大小可以使用Photoshop等工具测量得出,这里直接使用测量后的结果)。

JavaScript Code复制内容到剪贴板
  1. <script type="text/javascript">   
  2. //获取Canvas对象(画布)   
  3. var canvas = document.getElementById("myCanvas");   
  4. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  5. if(canvas.getContext){     
  6.     //获取对应的CanvasRenderingContext2D对象(画笔)   
  7.     var ctx = canvas.getContext("2d");   
  8.        
  9.     //创建新的图片对象   
  10.     var img = new Image();   
  11.     //指定图片的URL   
  12.     img.src = "http://www.365mini.com/image/google_logo.png";   
  13.     //浏览器加载图片完毕后再绘制图片   
  14.     img.onload = function(){   
  15.         /*  
  16.          * 将图像左侧的"Goo"部分(即以坐标(0,0)为左上角坐标、宽度为332px、高度为190px的部分图像)  
  17.          * 绘制到canvas中以坐标(10,10)为左上角、宽度为332px、高度为190px的矩形区域  
  18.          *  
  19.          * canvas绘制图像的目标区域的宽度和高度与截取的部分图像尺寸保持一致,  
  20.          * 就表示不进行缩放,以原始尺寸截取部分图像  
  21.          */           
  22.         ctx.drawImage(img, 0, 0, 332, 190, 10, 10, 332, 190);                
  23.     };   
  24. }   
  25. </script>  

此时,我们就可以看到canvas中显示的"Goo"局部图像了:
HTML5 Canvas绘制文本及图片的基础教程

HTML / CSS 相关文章推荐
html5 css3 动态气泡按钮实例演示
Dec 02 HTML / CSS
css3实现input输入框颜色渐变发光效果代码
Apr 02 HTML / CSS
CSS3 仿微信聊天小气泡实例代码
Apr 05 HTML / CSS
HTML5+CSS3 实现灵动的动画 TAB 切换效果(DEMO)
Sep 15 HTML / CSS
HTML5组件Canvas实现图像灰度化(步骤+实例效果)
Apr 22 HTML / CSS
HTML5 canvas画图并保存成图片的jcanvas插件
Jan 17 HTML / CSS
HTML5本地存储localStorage、sessionStorage基本用法、遍历操作、异常处理等
May 08 HTML / CSS
详解HTML5 录音的踩坑之旅
Dec 26 HTML / CSS
使用canvas生成含有微信头像的邀请海报没有微信头像问题
Oct 29 HTML / CSS
canvas版人体时钟的实现示例
Jan 29 HTML / CSS
CSS 使用 resize 实现图片拖拽切换预览功能(强大功能)
Aug 23 HTML / CSS
使用HBuilder制作一个简单的HTML5网页
Jul 07 HTML / CSS
用HTML5 Canvas API中的clearRect()方法实现橡皮擦功能
Mar 15 #HTML / CSS
网页中的电话号码如何实现一键直呼效果_附示例
Mar 15 #HTML / CSS
HTML5使用Audio标签实现歌词同步的效果
Mar 17 #HTML / CSS
HTML5仿手机微信聊天界面
Mar 18 #HTML / CSS
HTML5 Canvas实现文本对齐的方法总结
Mar 24 #HTML / CSS
使用HTML5 Canvas API中的clip()方法裁剪区域图像
Mar 25 #HTML / CSS
HTML5 Canvas API中drawImage()方法的使用实例
Mar 25 #HTML / CSS
You might like
php站内搜索并高亮显示关键字的实现代码
2011/12/29 PHP
使用PHPExcel操作Excel用法实例分析
2015/03/26 PHP
PHP如何通过传引用的思想实现无限分类(代码简单)
2015/10/13 PHP
SSO单点登录的PHP实现方法(Laravel框架)
2016/03/23 PHP
thinkphp5框架API token身份验证功能示例
2019/05/21 PHP
IE6与IE7中,innerHTML获取param的区别
2009/03/15 Javascript
JavaScript(js)设置默认输入焦点(focus)
2012/12/28 Javascript
Jquery 模板数据绑定插件的使用方法详解
2013/07/08 Javascript
js获取input标签的输入值实现代码
2013/08/05 Javascript
Javascript仿PHP $_GET获取URL中的参数
2014/05/12 Javascript
JavaScript类型系统之基本数据类型与包装类型
2016/01/06 Javascript
js倒计时小实例(多次定时)
2016/12/08 Javascript
H5手机端多文件上传预览插件
2017/04/21 Javascript
几个你不知道的技巧助你写出更优雅的vue.js代码
2018/06/11 Javascript
vue移动端实现红包雨效果
2020/06/23 Javascript
[01:21:58]守擂赛DOTA2第一周决赛
2020/04/22 DOTA
深入理解Django的自定义过滤器
2017/10/17 Python
在Python中过滤Windows文件名中的非法字符方法
2019/06/10 Python
使用python将多个excel文件合并到同一个文件的方法
2019/07/09 Python
django rest framework serializers序列化实例
2020/05/13 Python
Python flask框架如何显示图像到web页面
2020/06/03 Python
Python爬虫实例——爬取美团美食数据
2020/07/15 Python
Python执行时间的几种计算方法
2020/07/31 Python
Python抖音快手代码舞(字符舞)的实现方法
2021/02/07 Python
css3中新增的样式使用示例附效果图
2014/08/19 HTML / CSS
美国领先的礼品卡网站:GiftCards.com
2016/11/02 全球购物
Notino匈牙利:购买香水和化妆品
2019/04/12 全球购物
欧舒丹俄罗斯官方网站:L’OCCITANE俄罗斯
2019/11/22 全球购物
什么是唯一索引
2015/07/05 面试题
什么是.net
2015/08/03 面试题
网站推广策划方案
2014/06/04 职场文书
售房协议书
2014/08/19 职场文书
2015年元旦主持词结束语
2014/12/14 职场文书
于丹论语心得观后感
2015/06/15 职场文书
2015年秋季运动会前导词
2015/07/20 职场文书
详解java如何集成swagger组件
2021/06/21 Java/Android