# Path2D

Path2D用来声明路径,用来在canvas中根据需要创建可以保留并重用的路径, 此路径会被CanvasRenderingContext2D对象使用

# Path2D 兼容性

Web 微信小程序 Android iOS
4.0 - 4.25 4.25

# Path2D 的方法

# closePath(): void

闭合路径,将最后一个点与起点连接起来。如果图形已经封闭,或者只有一个点,那么此方法不会产生任何效果。

# closePath 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25

# moveTo(x: number, y: number): void

将一个新的路径的起始点移动到 (x,y) 坐标

# moveTo 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
x number - - 点的X轴坐标
y number - - 点的Y轴坐标

# lineTo(x: number, y: number): void

将路径的最后一个点连接到 (x,y) 坐标

# lineTo 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
x number - - 线终点的X轴坐标
y number - - 线终点的Y轴坐标

# bezierCurveTo(cp1x: number, cp1y: number, cp2x: number, cp2y: number, x: number, y: number): void

创建三次方贝塞尔曲线路径

# bezierCurveTo 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
cp1x number - - 第一个贝塞尔控制点的 x 坐标
cp1y number - - 第一个贝塞尔控制点的 y 坐标
cp2x number - - 第二个贝塞尔控制点的 x 坐标
cp2y number - - 第二个贝塞尔控制点的 y 坐标
x number - - 结束点的 x 坐标
y number - - 结束点的 y 坐标

# quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): void

创建二次贝塞尔曲线路径

# quadraticCurveTo 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
cpx number - - 贝塞尔控制点的 x 坐标
cpy number - - 贝塞尔控制点的 y 坐标
x number - - 结束点的 x 坐标
y number - - 结束点的 y 坐标

# arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise: boolean): void

绘制一段弧线

# arc 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
x number - - 圆弧中心(圆心)的 x 轴坐标
y number - - 圆弧中心(圆心)的 y 轴坐标
radius number - - 圆弧的半径
startAngle number - - 圆弧的起始点,x 轴方向开始计算,单位为弧度
endAngle number - - 圆弧的终点,单位为弧度
anticlockwise boolean true - 圆弧绘制方向,true:逆时针绘制,false:顺时针绘制。

# arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): void

根据控制点和半径绘制圆弧路径,使用当前的描点 (前一个 moveTo 或 lineTo 等函数的止点)。根据当前描点与给定的控制点 1 连接的直线,和控制点 1 与控制点 2 连接的直线,作为使用指定半径的圆的切线,画出两条切线之间的弧线路径

# arcTo 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
x1 number - - 第一个控制点的 x 轴坐标
y1 number - - 第一个控制点的 y 轴坐标
x2 number - - 第二个控制点的 x 轴坐标
y2 number - - 第二个控制点的 y 轴坐标
radius number - - 圆弧的半径

# ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise: boolean): void

添加椭圆路径。椭圆的圆心在(x,y)位置,半径分别是radiusX 和 radiusY,按照anticlockwise(默认顺时针)指定的方向,从 startAngle 开始绘制,到 endAngle 结束

# ellipse 兼容性
Web 微信小程序 Android iOS
4.0 - x x
# 参数
名称 类型 必填 默认值 兼容性 描述
x number - - 椭圆圆心的 x 轴(水平)坐标
y number - - 椭圆圆心的 y 轴(垂直)坐标
radiusX number - - 椭圆长轴的半径。必须为非负数
radiusY number - - 椭圆短轴的半径。必须为非负数。
rotation number - - 椭圆的旋转角度,以弧度表示。
startAngle number - - 椭圆弧的起始偏心角,从正 x 轴沿顺时针测量,用弧度表示。
endAngle number - - 椭圆弧的结束偏心角,从正 x 轴沿顺时针测量,用弧度表示。
anticlockwise boolean - - 一个可选的布尔值,如果为 true,则逆时针绘制椭圆弧。默认值为 false(顺时针)。

# rect(x: number, y: number, width: number, height: number): void

创建一个矩形路径

# rect 兼容性
Web 微信小程序 Android iOS
4.0 - 4.25 4.25
# 参数
名称 类型 必填 默认值 兼容性 描述
x number - - 矩形路径起点的 x 轴坐标
y number - - 矩形路径起点的 y 轴坐标
width number - - 矩形路径的宽度
height number - - 矩形路径的高度