Mask Component Reference

Mask is used to specify the range which clip the render results of the children. A node with a Mask component will use a bounding box (which is specified by the contentSize of the UITransform component in the Inspector) to create a rectangular rendered mask. All child nodes of this node will only appear inside the mask’s boundary.

mask

Select a node in the Hierarchy panel, then click the Add Component button at the bottom of the Inspector panel and select Mask from UI -> Render. Then you can add the Mask component to the node.

After adding a Mask component, a Graphics component will be automatically added on the same node. Please do not delete the graphics component. When the Type property is SPRITE_STENCIL,the graphics component will be removed, and a new sprite component will be added. Please also do not delete the sprite component because it provides the shape information for the stencil.

Note: the Mask component cannot be added to a node with other renderer components such as Sprite, Label, etc.

To use Mask, please refer to the Mask API documentation and the Mask scene of the test-cases-3d project.

Mask Properties

PropertyFunction Explanation
TypeMask type, including RECT, ELLIPSE, GRAPHICS_STENCIL, SPRITE_STENCIL.
SegmentsThe segments for ellipse mask, which takes effect only when the Mask type is set to ELLIPSE.
InvertedThe Reverse mask.

Type

RECT

mask

ELLIPSE

mask

It can also be set by code at runtime. Example:

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

GRAPHICS_STENCIL

mask

It can also be set by code at runtime. Example:

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

SPRITE_STENCIL

mask

It can also be set by code at runtime. Example:

  1. const mask = this.getComponent(Mask);
  2. mask.type = Mask.Type.SPRITE_STENCIL;
  3. const sprite = this.getComponent(Sprite);
  4. sprite.spriteFrame = this.stencilSprite;
  5. mask.alphaThreshold = 0.1;

Notes:

  1. After adding the Mask component to a node, all nodes in the sub tree of this node will be affected by Mask during rendering.
  2. The GRAPHICS_STENCIL simply provides the graphics component, which developers can use graphics property in the mask component to draw custom graphics. But the node click events are still calculated based on the size of the node.
  3. The SPRITE_STENCIL type requires a picture resource by default. If it is not set, it is equivalent to no mask.