iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >HTML5 Canvas怎么绘制文本及图片
  • 404
分享到

HTML5 Canvas怎么绘制文本及图片

2024-04-02 19:04:59 404人浏览 薄情痞子
摘要

这篇文章主要讲解了“HTML5 canvas怎么绘制文本及图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“html5 Canvas怎么绘制文本及图片”吧!

这篇文章主要讲解了“HTML5 canvas怎么绘制文本及图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“html5 Canvas怎么绘制文本及图片”吧!

绘制文本

在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.         ctx.drawImage(img, 0, 0, 332, 190, 10, 10, 332, 190);                

  17.     };   

  18. }   

  19. </script>  

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

感谢各位的阅读,以上就是“HTML5 Canvas怎么绘制文本及图片”的内容了,经过本文的学习后,相信大家对HTML5 Canvas怎么绘制文本及图片这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: HTML5 Canvas怎么绘制文本及图片

本文链接: https://www.lsjlt.com/news/77672.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • HTML5 Canvas怎么绘制文本及图片
    这篇文章主要讲解了“HTML5 Canvas怎么绘制文本及图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML5 Canvas怎么绘制文本及图片”吧!...
    99+
    2024-04-02
  • HTML5中Canvas怎么绘制图片
    这篇文章给大家分享的是有关HTML5中Canvas怎么绘制图片的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。获取Image对象,new出来定义Image对象的src属性,参数:图片路径定义Image对象的onlo...
    99+
    2023-06-09
  • HTML5怎么在canvas中绘制文本
    这篇文章主要介绍“HTML5怎么在canvas中绘制文本”,在日常操作中,相信很多人在HTML5怎么在canvas中绘制文本问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”HT...
    99+
    2024-04-02
  • html5怎么使用canvas绘制一张图片
    本篇内容主要讲解“html5怎么使用canvas绘制一张图片”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么使用canvas绘制一张图片”吧!<...
    99+
    2024-04-02
  • HTML5 Canvas如何绘制文本
    这篇文章主要介绍HTML5 Canvas如何绘制文本,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!   HTML5 Canvas 绘制文本   HTML5 Canvas 可以使用...
    99+
    2024-04-02
  • html5 canvas如何绘图文本换行
    小编给大家分享一下html5 canvas如何绘图文本换行,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!怎么解决canvas...
    99+
    2024-04-02
  • 怎么用HTML5的Canvas API绘制图形
    本篇内容介绍了“怎么用HTML5的Canvas API绘制图形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • HTML5 Canvas如何绘制图像
    这篇文章给大家分享的是有关HTML5 Canvas如何绘制图像的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 canvas可以引入图像,它可以用于图片合成或者制作背景等。只要是...
    99+
    2024-04-02
  • 怎么调用HTML5的Canvas API绘制图形
    这篇文章主要讲解了“怎么调用HTML5的Canvas API绘制图形”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么调用HTML5的Canvas API绘...
    99+
    2024-04-02
  • 如何使用html5 Canvas绘制基本的图形
    这篇文章主要介绍“如何使用html5 Canvas绘制基本的图形”,在日常操作中,相信很多人在如何使用html5 Canvas绘制基本的图形问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2024-04-02
  • Android绘制文本与图片及动效详解
    目录绘制文本绘制图片绘制路径逐帧动画补间动画绘制文本 绘制类 借助 Canvas 类进行绘制 通过重写View.onDraw 方法来进行旁白描绘 package com.mingri...
    99+
    2022-12-17
    Android绘制文本 Android绘制图片 Android绘制动效
  • 怎么在html5中使用canvas绘制文本自动换行
    怎么在html5中使用canvas绘制文本自动换行?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一个150*100的canvas画布,加个边框明显边界<canvas&nb...
    99+
    2023-06-09
  • 怎么用HTML5的canvas来绘图
    本文小编为大家详细介绍“怎么用HTML5的canvas来绘图”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用HTML5的canvas来绘图”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学...
    99+
    2024-04-02
  • HTML5怎么在canvas中绘制矩形附效果图
    这篇文章主要讲解了“HTML5怎么在canvas中绘制矩形附效果图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“HTML5怎么在canvas中绘制矩形附效果...
    99+
    2024-04-02
  • html5中怎么使用canvas绘制文字特效
    这篇文章主要介绍“html5中怎么使用canvas绘制文字特效”,在日常操作中,相信很多人在html5中怎么使用canvas绘制文字特效问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • html5中怎么用Canvas绘制椭圆
    本篇内容主要讲解“html5中怎么用Canvas绘制椭圆”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5中怎么用Canvas绘制椭圆”吧! 概述 H...
    99+
    2024-04-02
  • HTML5中怎么用canvas绘制曲线
    本文小编为大家详细介绍“HTML5中怎么用canvas绘制曲线”,内容详细,步骤清晰,细节处理妥当,希望这篇“HTML5中怎么用canvas绘制曲线”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • HTML5中怎么用canvas绘制线条
    本篇内容介绍了“HTML5中怎么用canvas绘制线条”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! &...
    99+
    2024-04-02
  • 怎么在HTML5中canvas进行绘图
    怎么在HTML5中canvas进行绘图?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。<canvas></canvas>是HTML5中新增...
    99+
    2023-06-09
  • 怎么在html5中利用Canvas绘图
    怎么在html5中利用Canvas绘图?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是CanvasCanvas 是H5的一部分,允许脚本语言动态渲染图像。Canva...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作