700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > HTML5 Canvas绘制文本及图片的基础教程技巧

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

时间:2020-12-04 04:40:37

相关推荐

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

web前端|H5教程

HTML5,Canvas,文本,图片

web前端-H5教程

绘制文本

江湖外卖2.0源码,vscode跨借鉴,ubuntu安装类型 空,tomcat 简化,sqlite 时间大于,动态云服务器,gif显示插件,前端游戏框架unit,网络爬虫 json,执行php,seo网站制作教程,作品集展示的网站源码,网页 按钮代码,ext6 应用程序模板,京东html5页面,美萍商业进销存管理系统破解版,飞天侠淘宝客程序lzw

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

有什么下载资源的网站源码,ubuntu获取源代码,tomcat8 系统配置,飞鸟爬虫的意思,php入门教程100例学习,江西seo品牌lzw

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

spring4.1源码下载,vscode计算机二级考吗,ubuntu 源详解,tomcat发布应用的方式,nodejs爬虫如何,前端要学php吗,seo推广平台哪家比较好lzw

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

JavaScript Code复制内容到剪贴板

HTML5 Canvas绘制文本文字入门示例

您的浏览器不支持canvas标签。

//获取Canvas对象(画布) var canvas = document.getElementById(“myCanvas”); //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误 if(canvas.getContext){ //获取对应的CanvasRenderingContext2D对象(画笔) var ctx = canvas.getContext(“2d”);

//设置字体样式 ctx.font = “30px Courier New”; //设置字体填充颜色 ctx.fillStyle = “blue”; //从坐标点(50,50)开始绘制文字 ctx.fillText(“CodePlayer+中文测试”, 50, 50); }

对应的显示效果如下:

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

JavaScript Code复制内容到剪贴板

//获取Canvas对象(画布) var canvas = document.getElementById(“myCanvas”); //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误 if(canvas.getContext){ //获取对应的CanvasRenderingContext2D对象(画笔) var ctx = canvas.getContext(“2d”);

//设置字体样式 ctx.font = “30px Courier New”; //设置字体颜色 ctx.strokeStyle = “blue”; //从坐标点(50,50)开始绘制文字 ctx.strokeText(“CodePlayer+中文测试”, 50, 50); }

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

绘制图片

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

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

XML/HTML Code复制内容到剪贴板

drawImage(mixed image, int x, int y)

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

XML/HTML Code复制内容到剪贴板

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复制内容到剪贴板

HTML5 Canvas绘制图像入门示例

您的浏览器不支持canvas标签。

//获取Canvas对象(画布) var canvas = document.getElementById(“myCanvas”); //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误 if(canvas.getContext){ //获取对应的CanvasRenderingContext2D对象(画笔) var ctx = canvas.getContext(“2d”);

//创建新的图片对象 var img = new Image(); //指定图片的URL img.src = “/image/google_logo.jpg”; //浏览器加载图片完毕后再绘制图片 img.onload = function(){//以Canvas画布上的坐标(10,10)为起始点,绘制图像ctx.drawImage(img, 10, 10); }; }

对应的显示效果如下:

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

JavaScript Code复制内容到剪贴板

//获取Canvas对象(画布) var canvas = document.getElementById(“myCanvas”); //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误 if(canvas.getContext){ //获取对应的CanvasRenderingContext2D对象(画笔) var ctx = canvas.getContext(“2d”);

//创建新的图片对象 var img = new Image(); //指定图片的URL img.src = “/image/google_logo.jpg”; //浏览器加载图片完毕后再绘制图片 img.onload = function(){//以Canvas画布上的坐标(10,10)为起始点,绘制图像//图像的宽度和高度分别缩放到350px和100pxctx.drawImage(img, 10, 10, 350, 100); }; }

我们将Google的logo图像进行缩放后,此时就可以在canvas中看到整个图像了:

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

JavaScript Code复制内容到剪贴板

//获取Canvas对象(画布) var canvas = document.getElementById(“myCanvas”); //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误 if(canvas.getContext){ //获取对应的CanvasRenderingContext2D对象(画笔) var ctx = canvas.getContext(“2d”);

//创建新的图片对象 var img = new Image(); //指定图片的URL img.src = “/image/google_logo.jpg”; //浏览器加载图片完毕后再绘制图片 img.onload = function(){/** 将图像左侧的”Goo”部分(即以坐标(0,0)为左上角坐标、宽度为332px、高度为190px的部分图像)* 绘制到canvas中以坐标(10,10)为左上角、宽度为332px、高度为190px的矩形区域** canvas绘制图像的目标区域的宽度和高度与截取的部分图像尺寸保持一致,* 就表示不进行缩放,以原始尺寸截取部分图像*/ ctx.drawImage(img, 0, 0, 332, 190, 10, 10, 332, 190); }; }

此时,我们就可以看到canvas中显示的”Goo”局部图像了:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。