我的编程空间,编程开发者的网络收藏夹
学习永远不晚

canvas使用注意点有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

canvas使用注意点有哪些

这篇文章将为大家详细讲解有关canvas使用注意点有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

1、canvas中文教程https://developer.mozilla.org/zh-CN/docs/Canvas_tutorial
2、canvas默认宽高是300、150,为避免异常,最好使用显示属性添加而不通过css来添加宽高
3、在canvas标签内部添加不支持canvas标签的浏览器的说明
4、通过下面的js代码也能判断浏览器是否支持canvas

代码如下:

var canvas = document.getElementById('tutorial'); 
if (canvas.getContext){ 
var ctx = canvas.getContext('2d'); 
// drawing code here 
} else { 
// canvas-unsupported code here 
}

5、canvas只支持一种基本形状的绘制,即矩形,但是其它图形都可以通过canvas路径来绘制
6、绘制矩形有四个函数:rect、fillRect、strokeRect和clearRect
7、beginPath的作用用来开始一个新的路径层,如果不加就表示在原来路径层上绘制,下面两段代码效果是完全不一样的,第一段代码显示两条红线,第二段代码显示一条黑线和一条红线

代码如下:

var ctx = document.getElementById('cvs').getContext('2d'); 
ctx.beginPath(); 
ctx.moveTo(100.5,20.5); 
ctx.lineTo(200.5,20.5); 
ctx.stroke(); 
ctx.moveTo(100.5,40.5); 
ctx.lineTo(200.5,40.5) 
ctx.strokeStyle = '#f00'; 
ctx.stroke();

代码如下:

var ctx = document.getElementById('cvs').getContext('2d'); 
ctx.beginPath(); 
ctx.moveTo(100.5,20.5); 
ctx.lineTo(200.5,20.5); 
ctx.stroke(); 
ctx.beginPath(); 
ctx.moveTo(100.5,40.5); 
ctx.lineTo(200.5,40.5) 
ctx.strokeStyle = '#f00'; 
ctx.stroke();

8、如果不需要路径闭合,closePath可以不用,如果使用了fill则路径则会自动闭合,不需要再使用closePath了
9、只要有足够的耐性是完全可以利用贝塞尔曲线绘制任何图形的
10、二次方曲线在火狐下存在bug,因此可以利用三次方曲线代替二次方曲线使用
11、图像(如 PNG,GIF,JPEG等)都可以引入到 canvas 中,而且其它的 canvas 元素也可以作为图像的来源
12、下面是基本的canvas图片绘制代码,其中 image 是 image 或者 canvas 对象,x 和 y 是其在目标 canvas 里的起始坐标
drawImage(image, x, y)
下面一段代码表示缩放图片,width和height表示缩放的尺寸
drawImage(image, x, y, width, height)
下面一段代码表示剪切图片,第一个参数和其它的是相同的,都是一个图像或者另一个 canvas 的引用。其它8个参数中分别表示图片中裁减的起始x坐标,图片中裁减的起始y坐标,裁减区域宽度,裁减区域高度,所画位置x坐标,所画位置y坐标,所画图形宽度,所画图形高度,裁剪区域的尺寸是可以和所画图形的尺寸不一样的,此时会缩放到所画图片的尺寸
drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight)
13、strokeStyle 是用于设置图形轮廓的颜色,而 fillStyle 用于设置填充颜色。color 可以是表示 CSS 颜色值的字符串,渐变对象或者图案对象。默认情况下,线条和填充颜色都是黑色(CSS 颜色值 #000000)。
14、图像透明度可以用globalAlpha = transparency value或者rgba颜色值来表示
15、lineWidth 属性设置当前绘线的粗细,为解决1px线宽bug问题,采用+0.5的方式来解决
16、lineCap 属性最左边的线用了默认的 butt 。可以注意到它是与辅助线齐平的。中间的是 round 的效果,端点处加上了半径为一半线宽的半圆。右边的是 square 的效果,端点处加上了等宽且高度为一半线宽的方块
17、lineJoin 属性这里我同样用三条折线来做例子,分别设置不同的 lineJoin 值。最上面一条是 round 的效果,边角处被磨圆了,圆的半径等于线宽。中间和最下面一条分别是 bevel 和 miter 的效果。当值是 miter 的时候,线段会在连接处外侧延伸直至交于一点,延伸效果受到下面将要介绍的 miterLimit 属性的制约
18、save 和 restore 方法是用来保存和恢复 canvas 状态的,都没有参数。Canvas 的状态就是当前画面应用的所有样式和变形的一个快照。Canvas 状态是以堆(stack)的方式保存的,每一次调用 save 方法,当前的状态就会被推入堆中保存起来。每一次调用 restore 方法,上一个保存的状态就从堆中弹出,所有设定都恢复。
19、transform(1, 0, 0, 1, 0, 0)参数分别表示水平方向缩放、水平方向旋转(顺时针)、垂直方向旋转(逆时针)、垂直方向缩放、水平方向偏移量、垂直方向偏移量
  setTransform(1, 0, 0, 1, 0, 0)表示重置前一个变换矩阵然后构建新的矩阵,参数作用同上
  rotate(angle),(一个半径等于1弧度,2πr/r=弧度即360=2π,即1=π/180)
20、动画其实就是不断清空画板(clearRect()),然后重绘

关于canvas使用注意点有哪些就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

canvas使用注意点有哪些

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

下载Word文档

猜你喜欢

使用spring的restTemplate注意点有哪些

这篇文章将为大家详细讲解有关使用spring的restTemplate注意点有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用spring的restTemplate注意点spring的restTem
2023-06-25

使用Visual Studio 2010 RC注意要点有哪些

这篇文章给大家分享的是有关使用Visual Studio 2010 RC注意要点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在使用Visual Studio 2010 RC版本时,发现了一个小问题,需要引
2023-06-17

canvas有哪些特点

canvas特点有简单易用、强大的绘图功能、高性能、跨平台兼容性、可扩展性、动画效果、可以处理大数据量等。详细介绍:1、简单易用,Canvas提供了简单易用的API,使开发者能够轻松地创建和操作图形;2、强大的绘图功能,Canvas支持绘制
2023-08-17

Servlet的init注意点有哪些

本篇内容主要讲解“Servlet的init注意点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Servlet的init注意点有哪些”吧!在Servlet的GenericServleta类中
2023-06-04

python参数调用的注意点有哪些

这篇文章给大家分享的是有关python参数调用的注意点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、数量定义时必须一致这个大家都比较好理解,定义和调用时参数数量不一样肯定会报错,但是,不要小看这个错误,
2023-06-15

python调用函数的注意点有哪些

今天小编给大家分享一下python调用函数的注意点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、当函数有多个参数时
2023-06-30

react中JSX的注意点有哪些

今天小编给大家分享一下react中JSX的注意点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1 JSX 是一个表达式
2023-06-29

innodb使用的注意事项有哪些

使用InnoDB引擎时,有一些注意事项需要注意:1. 适当设置InnoDB缓冲池大小:InnoDB使用缓冲池来缓存数据和索引,因此设置适当的缓冲池大小对性能至关重要。一般来说,建议将缓冲池设置为物理内存的70-80%。2. 合理设置Inno
2023-09-15

使用FlexSDK4时注意事项有哪些

这篇文章将为大家详细讲解有关使用FlexSDK4时注意事项有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用FlexSDK4注意事项TWaverFlex是支持SDK4的,FlexSDK4新增了Spa
2023-06-17

Arrays.sort()使用的注意事项有哪些

这篇文章主要讲解了“Arrays.sort()使用的注意事项有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Arrays.sort()使用的注意事项有哪些”吧!Arrays.sort()
2023-06-30

html和css基础注意点有哪些

html和css基础注意点有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1 减少无意义标签的使用 简单的举个例子:对于这个顶部的结构,错误:通栏>版心>左边+(
2023-06-08

Linux shell使用注意事项有哪些

本篇内容介绍了“Linux shell使用注意事项有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!shell是系统的用户界面,提供了用户
2023-06-27

ADO.NET调用使用注意事项有哪些

这篇文章将为大家详细讲解有关ADO.NET调用使用注意事项有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。ADO.NET调用大家可以试一下本文的示例,然后,根据自己的理解来酌情运用。Using Ent
2023-06-17

java请求方式使用要注意哪些点

在使用Java进行请求发送时,需要注意以下几个点:1. 请求方法:根据需求选择合适的请求方法,常见的请求方法有GET、POST、PUT、DELETE等。GET方法用于获取资源,POST方法用于创建资源,PUT方法用于更新资源,DELETE方
2023-08-25

编程热搜

目录