Ui XML Mask - funovus/editor-wiki GitHub Wiki
Table of Contents
- [Ui XML Reference\Mask](#ui-xml-referencemask)
|
Ui XML Reference\Mask
Creates a mask, combine with Stencil Masks to show only part of children UI frames. By default, this frame type attempts to fill its parent size unless given explicit dimensions. This frame uses a child frame to actually provide the tinting and masking. This child frame should be created after any Stencil Mask frames, otherwise the stencil mask will not function.
<Mask>
<!-- Button has a child stencil mask that will 'cut through' the masking frame's effect -->
<Button height="200" width="200" xmlns:bind="https://platform.wildsky.dev/xml/ui/bind">
<Frame padding="-20">
<StencilMask id="mask_stencil" backgroundImage="shape_square_32x32" matchParentWidth="true" matchParentHeight="true" />
</Frame>
</Button>
<!-- Frame that actually creates the masking effect -->
<Frame id="mask" active="true" width="9000" height="9000" backgroundImageColor="r: 0, g: 0, b: 0, a: 0.45" />
</Mask>
This xml script produces the following UI:
The stencil mask, given a negative padding, is slightly larger than it's parent button. As the button changes size in response to being clicked on, the stencil mask matches its size and thus the stenciled portion adjusts smoothly.
The masking frame's tinting shape can be influenced by setting a black and white background image. This background image will determine the shape of the mask. If the background image is not a 9-sliced image, the image may be very pixilated. Setting a 9-sliced image as the background will function as normally expected, including the usage of backgroundImagePixelsPerUnitMultiplier:
<Frame id="mask" active="true" matchParentHeight="true" matchParentWidth="true" backgroundImageColor="r: 0, g: 0, b: 0, a: 0.45" backgroundImagePixelsPerUnitMultiplier="0.1" backgroundImage="shape_round_12" />
Shows only part of children UI frames