Mask(遮罩)组件参考

Mask 用于规定子节点可渲染的范围,默认带有 Mask 组件的节点会使用该节点的约束框(也就是 属性检查器 中 Node 组件的 ContentSize 规定的范围)创建一个矩形渲染遮罩,该节点的所有子节点都会依据这个遮罩进行裁剪,遮罩范围外的将不会渲染。

mask

点击 属性检查器 下面的 添加组件 按钮,然后从 UI 中选择 Mask,即可添加 Mask 组件到节点上。注意该组件不能添加到有其他渲染组件(如 SpriteLabel 等)的节点上。

遮罩的组件接口请参考 Mask API

关于使用可以参考 test-cases-3d 里的 mask 相关。

Mask 属性

属性功能说明
Type遮罩类型。包括 RECTELLIPSEGRAPHICS_STENCILIMAGE_STENCIL 四种类型。
Segments椭圆遮罩的曲线细分数,只在遮罩类型设为 ELLIPSE 时生效
Inverted反向遮罩
SpriteFrame图片遮罩所使用图片

Type

RECT 矩形遮罩

mask

ELLIPSE 椭圆遮罩

mask

可以在运行时通过代码设置

  1. const mask = this.getComponent(Mask);
  2. mask.type = Mask.Type.ELLIPSE;
  3. mask.segments = 32;

GRAPHICS_STENCIL 自定义图形遮罩

mask

可以在运行时通过代码设置

  1. const mask = this.getComponent(Mask);
  2. mask.type = Mask.Type.GRAPHICS_STENCIL;
  3. const g = mask.graphics;
  4. g.lineWidth = 10;
  5. g.fillColor.fromHEX('#ff0000');
  6. g.moveTo(-40, 0);
  7. g.lineTo(0, -80);
  8. g.lineTo(40, 0);
  9. g.lineTo(0, 80);
  10. g.close();
  11. g.stroke();
  12. g.fill();

IMAGE_STENCIL 自定义图片遮罩

mask

可以在运行时通过代码设置

  1. const mask = this.getComponent(Mask);
  2. mask.type = Mask.Type.IMAGE_STENCIL;
  3. mask.spriteFrame = this.spriteFrame;
  4. mask.alphaThreshold = 0.1;

注意

  1. 节点添加了 Mask 组件之后,所有在该节点下的子节点,在渲染的时候都会受 Mask 影响。

  2. GRAPHICS_STENCIL 类型在这里没有做任何引擎需要的事,只是放开了对 graphics 操控,用户可以使用 mask 组件里的 graphics 属性来绘制自定义图形,但是节点的点击事件还是根据节点的尺寸来计算。

  3. IMAGE_STENCIL 类型默认需要一个图片资源,如果没有设置的话,相当于没有遮罩。

  4. 在当前版本以及之前版本上,由于底层渲染架构原因,Mask 在编辑器下的所有子节点的渲染内容都看不见。

    解决方法:在编辑器下调整 Mask 节点的 layer 为 default 即可,不会影响运行时数据。