Canvas详细使用方法(二)
创始人
2024-06-02 04:59:02
0

线型 Line styles

lineCap: 属性的值决定了线段端点显示的样子。它可以为下面的三种的其中之一:

  • butt 截断,默认是 butt。
  • round 圆形
  • square 正方形
    lineJoin: 属性的值决定了图形中线段连接处所显示的样子。它可以是这三种之一:
  • round 圆形
  • bevel 斜角
  • miter 斜槽规,默认是 miter。

在这里插入图片描述



Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述



Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述

绘制文本

canvas 提供了两种方法来渲染文本

  • fillText(text, x, y [, maxWidth])
    • 在 (x,y) 位置,填充指定的文本
    • 绘制的最大宽度(可选)。
  • strokeText(text, x, y [, maxWidth])
    • 在 (x,y) 位置,绘制文本边框
    • 绘制的最大宽度(可选)。
      文本的样式(需在绘制文本前调用)
  • font = value: 当前绘制文本的样式。这个字符串使用和 CSS font 属性相同的语法。默认的字体是:10px sans-serif
  • textAlign = value:文本对齐选项。可选的值包括:start, end, left, right or center. 默认值是 start
  • textBaseline = value:基线对齐选项。可选的值包括:top, hanging, middle, alphabetic, ideographic, bottom。
    • 默认值是 alphabetic


Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述

绘制图片

绘制图片,可以使用 drawImage 方法将它渲染到 canvas 里。drawImage 方法有三种形态:

  • drawImage(image, x, y)
    • 其中 image 是 image 或者 canvas 对象,x 和 y 是其在目标 canvas 里的起始坐标
  • drawImage(image, x, y, width, height)
    • 这个方法多了 2 个参数:width 和 height,这两个参数用来控制 当向 canvas 画入时应该缩放的大小
  • drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight)
    • 第一个参数和其它的是相同的,都是一个图像或者另一个 canvas 的引用。前 4 个是定义图像源的切片位置和大小,后 4 个则是定义切片的目标显示位置和大小

图片的来源,canvas 的 API 可以使用下面这些类型中的一种作为图片的源

  • HTMLImageElement:这些图片是由Image()函数构造出来的,或者任何的< img >元素
  • HTMLVideoElement:用一个 HTML 的 < video >元素作为你的图片源,可以从视频中抓取当前帧作为一个图像。
  • HTMLCanvasElement:可以使用另一个 < canvas > 元素作为你的图片源。

在这里插入图片描述



Document

你的浏览器不兼容Canvas,请升级您的浏览器!


Canvas绘画状态-保存和恢复

Canvas绘画状态

  • 是当前绘画时所产生的样式和变形的一个快照。
  • Canvas在绘画时,会产生相应的绘画状态,其实我们是可以将某些绘画的状态存储在栈中来为以后复用。
  • Canvas 绘画状态的可以调用 save 和 restore 方法是用来保存和恢复,这两个方法都没有参数,并且它们是成对存在的
    保存和恢复(Canvas)绘画状态
  • save():保存画布 (canvas) 的所有绘画状态
  • restore():恢复画布 (canvas) 的所有绘画状态
    Canvas绘画状态包括:
  • 当前应用的变形(即移动,旋转和缩放)
  • 以及这些属性:strokeStyle, fillStyle, globalAlpha, lineWidth, lineCap, lineJoin, miterLimit,shadowOffsetX, shadowOffsetY, shadowBlur, shadowColor, font, textAlign, textBaseline …
  • 当前的裁切路径(clipping path)


Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述

变形 Transform

Canvas和CSS3一样也是支持变形,形变是一种更强大的方法,可以将坐标原点移动到另一点、形变可以对网格进行旋转和缩放
Canvas的形变有4种方法实现:

  • translate(x, y):用来移动 canvas 和它的原点到一个不同的位置。
    • x 是左右偏移量,y 是上下偏移量(无需要单位),如右图所示。
  • rotate(angle):用于以原点为中心旋转 canvas,即沿着z轴旋转。
    • angle是旋转的弧度,是顺时针方向,以弧度为单位
  • scale(x, y):用来增减图形在 canvas 中像素数目,对图形进行缩小或放大。
    • x 为水平缩放因子,y 为垂直缩放因子。如果比 1 小,会缩小图形,如果比 1 大会放大图形。默认值为 1,也支持负数。
  • transform(a, b, c, d, e, f): 允许对变形矩阵直接修改。这个方法是将当前的变形矩阵乘上一个基于自身参数的矩阵。
    注意事项:
  • 在做变形之前先调用 save 方法保存状态是一个良好的习惯。
  • 大多数情况下,调用 restore 方法比手动恢复原先的状态要简单得多。
  • 如果在一个循环中做位移但没有保存和恢复canvas状态,很可能到最后会发现有些东西不见了,因为它很可能已超出canvas画布以外了。
  • 形变需要在绘制图形前调用。
    在这里插入图片描述

移动-translate

translate方法,它用来移动 canvas 和它的原点到一个不同的位置。

  • translate(x, y)
    • x 是左右偏移量,y 是上下偏移量(无需单位)。
      移动 canvas 原点的好处
  • 如不使用 translate方法,那么所有矩形默认都将被绘制在相同的(0,0)坐标原点。
  • translate方法可让我们任意放置图形,而不需要手工一个个调整坐标值
    移动矩形案例
  • 第一步:先保存一下canvas当前的状态
  • 第二步:在绘制图形前translate移动画布
  • 第三步:开始绘制图形,并填充颜色

在这里插入图片描述



Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述

旋转-rotate

rotate方法,它用于以原点为中心旋转 canvas,即沿着 z轴 旋转。

  • rotate(angle)
    • 只接受一个参数:旋转的角度 (angle),它是顺时针方向,以弧度为单位的值。
    • 角度与弧度的 JS 表达式:弧度=( Math.PI / 180 ) * 角度 ,即 1角度 = Math.PI/180 个弧度
    • 比如:旋转90°:Math.PI / 2; 旋转180°:Math.PI ; 旋转360°:Math.PI * 2; 旋转-90°:-Math.PI / 2;
    • 旋转的中心点始终是 canvas 的原坐标点,如果要改变它,我们需要用到 translate方法。
      旋转案例
  • 第一步:先保存一下Canvas当前的状态,并确定旋转原点
  • 第二步:在绘制图形前旋转画布(坐标系会跟着旋转了)
  • 第三步:开始绘制图形,并填充颜色
    在这里插入图片描述
    在这里插入图片描述


Document

你的浏览器不兼容Canvas,请升级您的浏览器!


在这里插入图片描述

缩放-scale

**scale方法可以缩放画布。**可用它来增减图形在 canvas 中的像素数目,对图形进行缩小或者放大

  • scale(x, y)
    • x 为水平缩放因子,y 为垂直缩放因子,也支持负数。
    • 如果比 1 小,会缩小图形,如果比 1 大会放大图形。默认值为 1。
      注意事项
  • 画布初始情况下,是以左上角坐标为原点。如果参数为负实数,相当于以 x 或 y 轴作为对称轴镜像反转。
    • 例如,使用translate(0, canvas.height); scale(1,-1); 以 y 轴作为对称轴镜像反转。
  • 默认情况下,canvas 的 1 个单位为 1 个像素。如果我们设置缩放因子是 0.5,1 个单位就变成对应 0.5 个像素,这样绘制出
    来的形状就会是原先的一半。同理,设置为 2.0 时,1 个单位就对应变成了 2 像素,绘制的结果就是图形放大了 2 倍。
    缩放案例实战
  • 第一步:先保存一下Canvas当前的状态,并确定缩放原点
  • 第二步:在绘制图形前缩放画布
  • 第三步:开始绘制图形,并填充颜色

在这里插入图片描述


Document你的浏览器不兼容Canvas,请升级您的浏览器!

在这里插入图片描述

相关内容

热门资讯

安卓系统用的华为应用,探索智能... 你知道吗?在安卓系统里,华为的应用可是个宝库呢!它们不仅功能强大,而且使用起来超级方便。今天,就让我...
安卓变ios系统魅蓝 你知道吗?最近有个朋友突然告诉我,他要把自己的安卓手机换成iOS系统,而且还是魅蓝品牌的!这可真是让...
幻书启世录安卓系统,安卓世界中... 亲爱的读者们,你是否曾在某个夜晚,被一本神奇的书所吸引,仿佛它拥有着穿越时空的力量?今天,我要带你走...
电脑安装安卓系统进不去,安卓系... 电脑安装安卓系统后竟然进不去,这可真是让人头疼的问题啊!你是不是也遇到了这种情况,心里直呼“怎么办怎...
用键盘切换控制安卓系统,畅享安... 你有没有想过,用键盘来控制你的安卓手机?是的,你没听错,就是那个我们每天敲敲打打的小玩意儿——键盘。...
小米安卓镜像系统在哪,小米安卓... 你有没有想过,你的小米手机里有一个隐藏的宝藏——安卓镜像系统?没错,就是那个可以让你的手机瞬间变身成...
安卓手机下载排班系统,高效排班... 你有没有想过,每天忙碌的工作中,有没有什么好帮手能帮你轻松管理时间呢?今天,就让我来给你介绍一个超级...
桌面组件如何弄安卓系统,桌面组... 亲爱的桌面爱好者们,你是否曾梦想过将安卓系统搬到你的电脑桌面上?想象那些流畅的动画、丰富的应用,还有...
安卓13系统介绍视频,新功能与... 亲爱的读者们,你是否对安卓13系统充满好奇?想要一探究竟,却又苦于没有足够的时间去研究?别担心,今天...
车机安卓7.1系统,功能升级与... 你有没有发现,现在的车机系统越来越智能了?尤其是那些搭载了安卓7.1系统的车机,简直就像是个贴心的智...
安卓系统下如何读pdf,And... 你有没有遇到过这种情况:手机里存了一大堆PDF文件,可是怎么也找不到一个能顺畅阅读的工具?别急,今天...
安卓系统全国通用的吗,畅享智能... 你有没有想过,为什么你的手机里装的是安卓系统呢?安卓系统,这个名字听起来是不是有点神秘?今天,就让我...
假苹果手机8安卓系统,颠覆传统... 你有没有想过,如果苹果手机突然变成了安卓系统,会是怎样的景象呢?想象那熟悉的苹果外观,却运行着安卓的...
安卓12.0系统vivo有吗,... 你有没有听说最近安卓系统又升级啦?没错,就是那个让手机焕然一新的安卓12.0系统!那么,咱们国内的手...
核心芯片和安卓系统,探索核心芯... 你知道吗?在科技的世界里,有一对“黄金搭档”正悄悄改变着我们的生活。他们就是——核心芯片和安卓系统。...
如何调安卓系统屏幕颜色,安卓系... 亲爱的手机控们,你是否曾觉得安卓系统的屏幕颜色不够个性,或者是因为长时间盯着屏幕而感到眼睛疲劳?别担...
旧台式电脑安装安卓系统,轻松安... 你那台旧台式电脑是不是已经服役多年,性能逐渐力不从心,却又不忍心让它退役呢?别急,今天就来教你怎么给...
美国要求关闭安卓系统,科技霸权... 美国要求关闭安卓系统:一场技术革新还是政治博弈?在数字化时代,智能手机已经成为我们生活中不可或缺的一...
安卓系统日记本 你有没有发现,手机里的安卓系统日记本,简直就是记录生活点滴的宝藏库呢?想象每天忙碌的生活中,有没有那...
安卓手机广告最少的系统,探索安... 你有没有发现,用安卓手机的时候,广告总是无处不在,让人烦得要命?不过别急,今天我要给你揭秘一个秘密—...