CanvasRenderingContext2D:fill() 方法
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Canvas 2D API 的 CanvasRenderingContext2D.fill()
方法用于根据当前的 fillStyle
,填充当前或给定的路径。
语法
js
fill()
fill(path)
fill(fillRule)
fill(path, fillRule)
参数
返回值
无(undefined
)。
示例
填充矩形
该示例使用 fill()
方法填充矩形。
HTML
html
<canvas id="canvas"></canvas>
JavaScript
js
const canvas = document.getElementById("canvas");
const ctx = canvas.getContext("2d");
ctx.rect(10, 10, 150, 100);
ctx.fill();
结果
指定路径和填充规则
该示例将一些相交的线条保存到一个 Path2D
对象中。然后使用 fill()
方法将对象渲染到画布上。通过使用 "evenodd"
规则,在对象中心留下一个未填充的孔;默认情况下(使用 "nonzero"
规则),这个孔也会被填充。
HTML
html
<canvas id="canvas"></canvas>
JavaScript
js
const canvas = document.getElementById("canvas");
const ctx = canvas.getContext("2d");
// 创建路径
let region = new Path2D();
region.moveTo(30, 90);
region.lineTo(110, 20);
region.lineTo(240, 130);
region.lineTo(60, 130);
region.lineTo(190, 20);
region.lineTo(270, 90);
region.closePath();
// 填充路径
ctx.fillStyle = "green";
ctx.fill(region, "evenodd");
结果
规范
Specification |
---|
HTML # dom-context-2d-fill-dev |
浏览器兼容性
BCD tables only load in the browser