diff --git a/Packages/src/README.md b/Packages/src/README.md index e0ef3e0..5e6adc7 100644 --- a/Packages/src/README.md +++ b/Packages/src/README.md @@ -1,125 +1,384 @@ -# logo SoftMaskForUGUI v2 +# logo SoftMaskForUGUI v2 [![](https://img.shields.io/npm/v/com.coffee.softmask-for-ugui?label=openupm®istry_uri=https://package.openupm.com)](https://openupm.com/packages/com.coffee.softmask-for-ugui/) [![](https://img.shields.io/github/v/release/mob-sakai/SoftMaskForUGUI?include_prereleases)](https://github.com/mob-sakai/SoftMaskForUGUI/releases) [![](https://img.shields.io/github/release-date/mob-sakai/SoftMaskForUGUI.svg)](https://github.com/mob-sakai/SoftMaskForUGUI/releases) ![](https://img.shields.io/badge/Unity-2019.4+-57b9d3.svg?style=flat&logo=unity) +![](https://img.shields.io/badge/uGUI_2.0_Ready-57b9d3.svg?style=flat) +![](https://img.shields.io/badge/UPR%2FHDPR_Ready-57b9d3.svg?style=flat) +![](https://img.shields.io/badge/VR_Ready-57b9d3.svg?style=flat) [![](https://img.shields.io/github/license/mob-sakai/SoftMaskForUGUI.svg)](https://github.com/mob-sakai/SoftMaskForUGUI/blob/main/LICENSE.txt) -[![](https://mob-sakai.github.io/DocFxForUnity/CodeCoverage/badge_linecoverage.svg)](https://mob-sakai.github.io/TestPkgDev/CodeCoverage/) [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-orange.svg)](http://makeapullrequest.com) [![](https://img.shields.io/github/watchers/mob-sakai/SoftMaskForUGUI.svg?style=social&label=Watch)](https://github.com/mob-sakai/SoftMaskForUGUI/subscription) [![](https://img.shields.io/twitter/follow/mob_sakai.svg?label=Follow&style=social)](https://twitter.com/intent/follow?screen_name=mob_sakai) -<< [📝 Description](#-description) | [🎮 Demo](#-demo) | [⚙ Installation](#-installation) | [🚀 Usage](#-usage) | [🤝 Contributing](#-contributing) >> - -## 📝 Description - - - -This package provides a soft masking for Unity UI (uGUI). - -#### Features - -* SoftMask is compatible with Mask. -* You can adjust the visible part. -![](https://user-images.githubusercontent.com/12690315/48661087-01ca9f00-eab0-11e8-8878-772a1ed1fb7b.gif) -* Text, Image, RawImage can be used as a masking. -* Support multiple-sprites and SpriteAtlas. -* Support up to 4 nested soft masks. -![](https://user-images.githubusercontent.com/12690315/48708326-a0d4cf80-ec45-11e8-83b8-f55d29138db7.png) -* Support scroll view. -![](https://user-images.githubusercontent.com/12690315/48708527-2b1d3380-ec46-11e8-9adf-9d33498f0353.png) -* Support inversed soft mask. -![](https://user-images.githubusercontent.com/12690315/48708328-a0d4cf80-ec45-11e8-9945-e877faabc968.png) -* Support overlay, camera space and world space. -![](https://user-images.githubusercontent.com/12690315/48708329-a0d4cf80-ec45-11e8-8328-16b697f981ec.png) -* (Option) Raycast is filtered only for the visible part. -![](https://user-images.githubusercontent.com/12690315/48708330-a16d6600-ec45-11e8-94bf-afecd1bd9a39.png) -* Contain soft maskable UI shader. -* Support soft masks in your custom shaders by adding just 3 lines. For details, please see [Development Note](#support-soft-masks-with-your-custom-shaders). -* Adjust soft mask buffer size to improve performance. -* Convert existing Mask to SoftMask from context menu. -![](https://user-images.githubusercontent.com/12690315/48659018-902e2900-ea8e-11e8-9b6e-224365cdde7f.png) -* Render the soft mask buffer only when needed to improve performance. -* Add a SoftMaskable component to the child UI elements of SoftMask from the inspector. -![](https://user-images.githubusercontent.com/12690315/50284153-76bc3a80-049b-11e9-8c55-719af897960a.png) -* Preview soft mask buffer in inspector. -![](https://user-images.githubusercontent.com/12690315/50284151-7459e080-049b-11e9-9cd3-24fb476766dc.png) -* Make multiple holes on one background by 'Parts of parent' option. -![](https://user-images.githubusercontent.com/12690315/54102470-f5c26e80-440b-11e9-89d1-899aa4dca00d.png) -* [Support TextMeshPro](#support-textmeshpro) +<< [📝 Description](#-description----omit-in-toc---) | [📌 Key Features](#-key-features) | [🎮 Demo](#-demo) | [⚙️ Installation](#-installation) | [🔄 Upgrading from v1 to v2](#-upgrading-from-v1-to-v2) | [🚀 Usage](#-usage) | [🤝 Contributing](#-contributing) >> + +## 📝 Description + +Enhance Unity UI (uGUI) with advanced soft-masking features to create more visually appealing effects! + + + +- [📌 Key Features](#-key-features) +- [🎮 Demo](#-demo) +- [⚙️ Installation](#-installation) + - [Install via OpenUPM](#install-via-openupm) + - [Install via UPM (with Package Manager UI)](#install-via-upm-with-package-manager-ui) + - [Install via UPM (Manually)](#install-via-upm-manually) + - [Install as Embedded Package](#install-as-embedded-package) +- [🔄 Upgrading from v1 to v2](#-upgrading-from-v1-to-v2) +- [🚀 Usage](#-usage) + - [Getting Started](#getting-started) + - [Comparison of Masking Mode](#comparison-of-masking-mode) + - [RectMask2D vs SoftMask](#rectmask2d-vs-softmask) + - [Component: SoftMask](#component-softmask) + - [Component: MaskingShape](#component-maskingshape) + - [Component: RectTransformFitter](#component-recttransformfitter) + - [Project Settings](#project-settings) + - [Usage with Scripts](#usage-with-scripts) + - [Usage with TextMeshPro](#usage-with-textmeshpro) + - [Usage with Your Custom Shaders](#usage-with-your-custom-shaders) + - [⚠️ Limitations](#-limitations) +- [🤝 Contributing](#-contributing) + - [Issues](#issues) + - [Pull Requests](#pull-requests) + - [Support](#support) +- [License](#license) +- [Author](#author) +- [See Also](#see-also) + +

+ +## 📌 Key Features + +- **Compatibility with Mask**: SoftMask is fully compatible with the existing `Mask` component. + You can convert an existing `Mask` to `SoftMask` from the context menu. + ![](https://github.com/user-attachments/assets/cf1d4545-d7a2-4b88-96d4-82f9a149cf69) +- **Adjustable Visible Part**: You can freely adjust the visible part of the mask. + ![](https://github.com/user-attachments/assets/171bb9e9-5392-4c60-9e61-e76a7576b421) +- **Versatile Masking Options**: `Text`, `Image`, `RawImage` can be used as a masking graphic. +- **Support for Multiple Sprites and SpriteAtlas**: `SoftMask` supports multiple sprites and `SpriteAtlas`. +- **Nested Soft Masks**: `SoftMask` supports up to 4 nested soft masks. + +- **ScrollRect Support**: `SoftMask` supports `ScrollRect` component. +- **All Render Mode Support**: `SoftMask` supports overlay, camera space, and world space. +- **Soft-Maskable UI Shader Included**: The package includes a soft-maskable UI shader for `UI/Dafault`. +- **Custom Shader Support**: You can make your custom shaders soft-maskable with little modification. For details, please see [soft-maskable shader](#usage-with-your-custom-shaders). +- **Performance/Quality Adjustment**: You can adjust the soft mask buffer size to improve performance or quality. + +- **Efficient Rendering**: The soft mask buffer will be updated only when needed to improve performance. +- **SoftMaskable Component**: `SoftMaskable` component will be added automatically at runtime as needed. +- **Soft Mask Buffer Preview**: You can preview the soft mask buffer in the inspector. + +- **Anti-Alias Masking Mode**: If you don't need semi-transparent masks, you can use the more performant "Anti-Aliasing Masking Mode". + ![](https://github.com/user-attachments/assets/490fd9d8-aa0d-45e2-a094-311236850ca2) +- **Masking Shape**: You can add or remove mask region using `MaskingShape` component. + ![](https://github.com/user-attachments/assets/4a568aba-99f6-46c5-98d9-30eb673c9026) +- **Inverse Masking**: Use `MaskingShape` component to inverse masking. You can implement effects such as iris out. + ![](https://github.com/user-attachments/assets/fb0581c0-84a7-4c12-a1d1-af28ed0da9b4) +- **Ray-cast Filtering**: Ray-casts are filtered only for the visible part. + This feature is useful for preventing clicks on masked parts during tutorials. + ![](https://github.com/user-attachments/assets/430735c7-7b85-46e8-bbf4-ab1fe70aa19a) +- **Stereo Support**: Soft masking for VR. + +- **TextMeshProUGUI Support**: Support `TextMeshProUGUI` by importing additional shaders. + It also supports TextMeshPro v3.2/4.0 (pre-release) and uGUI 2.0 (Unity 2023.2+/6.0+). + For details, please see [Support TextMeshPro](#usage-with-textmeshpro). + +- **Better Editor Experience**: In the Scene view, objects outside the screen are displayed as stencil masks, allowing for more intuitive editing. + ![](https://github.com/user-attachments/assets/e8349fe7-b3a8-471f-a5a7-1ee00c431561) +- **Automatic Shader Include and Stripping**: SoftMaskable shaders are automatically included at build time, and unused shader variants are removed. + ![](https://github.com/user-attachments/assets/0671b44e-6e0c-41d4-a92a-c3c56b8e8611)

## 🎮 Demo -[WebGL Demo](http://mob-sakai.github.io/SoftMaskForUGUI/Demo/) +[WebGL Demo](http://mob-sakai.github.io/SoftMaskForUGUI/DemoV2/)

-## ⚙ Installation +## ⚙️ Installation _This package requires **Unity 2019.4 or later**._ -#### Install via OpenUPM +### Install via OpenUPM + +- This package is available on [OpenUPM](https://openupm.com) package registry. +- This is the preferred method of installation, as you can easily receive updates as they're released. +- If you have [openupm-cli](https://github.com/openupm/openupm-cli) installed, then run the following command in your project's directory: + ``` + openupm add com.coffee.softmask-for-ugui + ``` +- To update the package, use Package Manager UI (`Window > Package Manager`) or run the following command with `@{version}`: + ``` + openupm add com.coffee.softmask-for-ugui@2.0.0 + ``` + +### Install via UPM (with Package Manager UI) + +- Click `Window > Package Manager` to open Package Manager UI. +- Click `+ > Add package from git URL...` and input the repository URL: `https://github.com/mob-sakai/SoftMaskForUGUI.git` + ![](https://github.com/user-attachments/assets/f88f47ad-c606-44bd-9e86-ee3f72eac548) +- To update the package, change suffix `#{version}` to the target version. + - e.g. `https://github.com/mob-sakai/SoftMaskForUGUI.git#2.0.0` + +### Install via UPM (Manually) + +- Open the `Packages/manifest.json` file in your project. Then add this package somewhere in the `dependencies` block: + ```json + { + "dependencies": { + "com.coffee.softmask-for-ugui": "https://github.com/mob-sakai/SoftMaskForUGUI.git", + ... + } + } + ``` + +- To update the package, change suffix `#{version}` to the target version. + - e.g. `"com.coffee.softmask-for-ugui": "https://github.com/mob-sakai/SoftMaskForUGUI.git#2.0.0",` + +### Install as Embedded Package + +1. Download a source code zip file from [Releases](https://github.com/mob-sakai/SoftMaskForUGUI/releases) and extract it. +2. Place it in your project's `Packages` directory. + ![](https://github.com/user-attachments/assets/af639cfa-d0b4-4370-acb9-3fe4db451f47) +- If you want to fix bugs or add features, install it as an embedded package. +- To update the package, you need to re-download it and replace the contents. -This package is available on [OpenUPM](https://openupm.com) package registry. -This is the preferred method of installation, as you can easily receive updates as they're released. +

-If you have [openupm-cli](https://github.com/openupm/openupm-cli) installed, then run the following command in your project's directory: +## 🔄 Upgrading from v1 to v2 -``` -openupm add com.coffee.softmask-for-ugui -``` +If you are currently using SoftMaskForUGUI v1.x, the following breaking changes are included when upgrading to v2: -#### Install via UPM (using Git URL) +1. **API changes**: Some APIs are obsolete. + - `SoftMask.softness`: Use `SoftMask.softnessRange` instead. + - `SoftMask.partOfParent`: Use `MaskingShape` component instead. -Navigate to your project's Packages folder and open the `manifest.json` file. Then add this package somewhere in the `dependencies` block: +2. **`SoftMaskable` component**: `SoftMaskable` component is no longer required to be added explicitly. + It will be added automatically at runtime as needed. -```json -{ - "dependencies": { - "com.coffee.softmask-for-ugui": "https://github.com/mob-sakai/SoftMaskForUGUI.git", - ... - }, -} -``` +3. **`SoftMaskable` shader**: `SoftMask()` function has been updated with additional arguments. + ```shaderlab + // Before + color.a *= SoftMask(IN.vertex, IN.worldPosition); + // After + color.a *= SoftMask(IN.vertex, IN.worldPosition, color.a); + ``` -To update the package, change suffix `#{version}` to the target version. +
-* e.g. `"com.coffee.softmask-for-ugui": "https://github.com/mob-sakai/SoftMaskForUGUI.git#2.0.0",` +To apply these changes automatically, please follow the steps below: + +1. Click `Edit > Project Settings` to open the Project Settings window and select `UI > SoftMask` category. + +2. Click on "Upgrade All Assets V1 to V2" to modify the assets. + ![](https://github.com/user-attachments/assets/54415f0b-e952-4271-ac6c-545f675030e3) + +- ⚠️ If you select "Dry Run", you can check the changes before upgrading. + ![](https://github.com/user-attachments/assets/9e5a4d2a-e072-4074-8be4-e6dd48a537bc) + ![](https://github.com/user-attachments/assets/02d0add8-005b-4fe3-8e9a-480221feb503)

## 🚀 Usage -1. Add a `SoftMask` component instead of `Mask` component. +### Getting Started + +1. [Install the package](#-installation). + +2. Add a `SoftMask` component instead of `Mask` component. Or, convert an existing `Mask` component to `SoftMask` component from the context menu (`Convert To SoftMask`). - ![](https://user-images.githubusercontent.com/12690315/48659018-902e2900-ea8e-11e8-9b6e-224365cdde7f.png) -2. (Optional) By placing the `MaskingShape` component under `SoftMask`, you can add or remove the mask range. - ![](https://user-images.githubusercontent.com/12690315/48661087-01ca9f00-eab0-11e8-8878-772a1ed1fb7b.gif) -3. Enjoy! + ![](https://github.com/user-attachments/assets/80a8d642-2ba4-4845-8d73-e9844122811e) + +3. Adjust the soft mask parameters in the inspector. + ![](https://github.com/user-attachments/assets/171bb9e9-5392-4c60-9e61-e76a7576b421) + +4. (Optional) By placing the `MaskingShape` component under `SoftMask`, you can add or remove the masking region. + ![](https://github.com/user-attachments/assets/711313be-29f5-45af-846a-49cdc3094e59) + +5. Enjoy! + +

+ +### Comparison of Masking Mode + +![](https://github.com/user-attachments/assets/5215eb21-3c1c-47f3-bd3d-accc6538dd23) + +- **Soft Masking**: Smooth mask with semi-transparency. + Requires memory for `RenderTexture` and [soft-maskable shader](#usage-with-your-custom-shaders). +- **Anti-Aliasing**: Less jagged stencil mask. + It does not require `RenderTexture` or soft-maskable shader, and works faster. +- **Normal**: Same as `Mask` component's stencil mask. + +

+ +### RectMask2D vs SoftMask + +`RectMask2D` is a built-in component that supports soft masking. +`SoftMask` provides more advanced soft masking. + +![](https://github.com/user-attachments/assets/1651030f-6750-415b-8ae1-aa3323637ce1) + +- **RectMask2D**: + - uGUI built-in + - Very fast + - Supports only rectangular shapes + - Supports only one level of nesting + - Supports only limited rotation +- **SoftMask**: + - Advanced soft masking + - Supports any graphic shape + - Supports up to 4 levels of nesting soft-masking + - Supports fully rotation + +

+ +### Component: SoftMask + +![](https://github.com/user-attachments/assets/171bb9e9-5392-4c60-9e61-e76a7576b421) + +- **Masking Mode**: + - `SoftMasking`: + - Smooth mask with semi-transparency. + - Requires memory for `RenderTexture` and [soft-maskable shader](#usage-with-your-custom-shaders). + - Use RenderTexture as a soft mask buffer. + - The alpha of the masking graphic can be used. + - `AntiAliasing`: + - Less jagged stencil mask. + - It does not require `RenderTexture` or soft-maskable shader, and works faster. + - Suppress the jaggedness of the masking graphic. + - The masking graphic cannot be displayed. + - `Normal`: Same as Mask component's stencil mask. + ![](https://github.com/user-attachments/assets/5215eb21-3c1c-47f3-bd3d-accc6538dd23) +- **Show Mask Graphic**: + - Show the graphic that is associated with the Mask render area. +- **Alpha Hit Test**: + - The transparent part of the mask cannot be clicked. + - This can be achieved by enabling Read/Write enabled in the Texture Import Settings for the texture. + - ⚠️ Enable this only if necessary, as it will require more graphics memory and processing time. +- **Anti Aliasing Threshold** (AntiAliasing only): + - Threshold for anti-alias masking. + - The smaller this value, the less jagged it is. +- **Softness Range** (SoftMasking only): + - The minimum and maximum alpha values used for soft masking. + - The larger the gap between these values, the stronger the softness effect. +- **Down Sampling Rate** (SoftMasking only): + - The down sampling rate for soft mask buffer. + - The higher this value, the lower the quality of the soft masking, but the performance will improve. +- **Preview Soft Mask Buffer** (editor, SoftMasking only): + - Preview the soft mask buffer in the inspector. + +

+ +### Component: MaskingShape + +![](https://github.com/user-attachments/assets/4a568aba-99f6-46c5-98d9-30eb673c9026) + +- `MaskingShape` component allows you to add or remove the masking region. +- Placing `MaskingShape` component (with any `Graphic`) under `SoftMask` component. + ![](https://github.com/user-attachments/assets/8325d190-0102-4677-9687-5c9bad3f9398) +- You can use it not only with `SoftMask` component but also with `Mask` component. +- If the `MaskingMode` is `AntiAliasing` or `Normal`, or if you are using the `Mask` component, the `MaskingShape` component must be placed above the masked `Graphic` in the hierarchy. This is a limitation based on the stencil mask. +- The available features depend on the `Masking Mode`. + ![](https://github.com/user-attachments/assets/f9ba1d8a-594b-4488-acf3-bed8bad5eacc) + ![](https://github.com/user-attachments/assets/c120cbed-4ba9-4813-9a6f-59ad6c581856) + ![](https://github.com/user-attachments/assets/b944f863-e070-4069-a54b-409484e43a5a) +

-#### Usage with TextMeshPro +### Component: RectTransformFitter + +![](https://github.com/user-attachments/assets/98878d4f-91a5-48dc-b44c-6a2192f0c0fc) -Open the `Package Manager` window and select the `UI Soft Mask` package in the package list and click the `TextMeshPro Support > Import in project` button. +- `RectTransformFitter` component follows the target RectTransform. +- You can specify the properties to follow (position, rotation, scale, delta size) with `RectTransformFitter.targetProperties`. +- By combining it with the `MaskingShape` component, you can implement an effect that displays only the buttons during the tutorial. + +

-The assets will be imported into `Assets/Samples/UI Soft Mask/{version}/TextMeshPro Support`. +### Project Settings -**NOTE:** You must import [TMP Essential Resources](https://docs.unity3d.com/Packages/com.unity.textmeshpro@3.0/manual/index.html#installation) before using. If the shader error is not resolved, reimport the shader. +![](https://github.com/user-attachments/assets/9013169b-516a-4502-b069-86439a32b712) + +- Click `Edit > Project Settings` to open the Project Settings window and then select `UI > SoftMask` category. +- By default, the soft-maskable shaders will be included in the build, but you can remove it if you don't need it. + +

-#### Usage with your custom shaders +### Usage with Scripts + +```csharp +var softMask = gameObject.GetComponent(); +softMask.maskingMode = SoftMask.MaskingMode.SoftMasking; +softMask.downSamplingRate = SoftMask.DownSamplingRate.x2; +softMask.softnessRange = new MinMax01(0.5f, 0.75f); +``` + +

+ +### Usage with TextMeshPro + +1. First, you must import [TMP Essential Resources](https://docs.unity3d.com/Packages/com.unity.textmeshpro@3.0/manual/index.html#installation) before using. + ![](https://github.com/user-attachments/assets/aaaf6b5f-02a5-458c-a46a-162534d8e8c2) + +2. Open the `Package Manager` window and select the `UI Soft Mask` package in the package list and click the `TextMeshPro Support > Import` button. + ⚠️ If you are using `ugui 2.0 (=Unity 2023.2+/6.0+)` or `TextMeshPro 3.2+/4.0+`, click the `TextMeshPro Support (ugui 2.0) > Import` button instead. + ![](https://github.com/user-attachments/assets/6182396f-65db-489e-a5ea-e5e2d5b693a9) + +3. The assets will be imported under `Assets/Samples/UI Soft Mask/{version}`. + ![](https://github.com/user-attachments/assets/834be6c2-1cb8-4e6c-917b-d62c596ed68b) + +

+ +### Usage with Your Custom Shaders + +Here, let's make [UI/Additive](https://raw.githubusercontent.com/mob-sakai/SoftMaskForUGUI/develop/Assets/Demos/SoftMaskable%20Shader/UI-Additive.shader) custom shader soft-maskable. There are two ways to support SoftMask with custom shaders. + +- **Hybrid (recommended)**: Add soft-maskable variants to the existing shader. + Modify the shader as follows: + ```shaderlab + // Add the ` (SoftMaskable)` suffix to the shader name. + Shader "UI/Additive (SoftMaskable)" + + // Import "UISoftMask.cginc" and add shader variants for editor. + #include "Packages/com.coffee.softmask-for-ugui/Shaders/SoftMask.cginc" + #pragma multi_compile_local _ SOFTMASK_EDITOR // soft-maskable for editor + + // "SoftMask" function returns [0-1]. Multiply this by the final output. + color.a *= SoftMask(IN.vertex, IN.worldPosition, color.a); + ``` + - Result: [UI/Additive (SoftMaskable)](https://raw.githubusercontent.com/mob-sakai/SoftMaskForUGUI/develop/Assets/Demos/SoftMaskable%20Shader/UI-Additive-SoftMaskable.shader) +- **Separate**: Create a new shader with soft-maskable variants. + Use this way for built-in shaders that cannot be edited, like `UI/Default`. + Modify the shader as follows: + ```shaderlab + // Add the `Hidden/` prefix and ` (SoftMaskable)` suffix to the shader name. + Shader "Hidden/UI/Additive (SoftMaskable)" + + // Import "UISoftMask.cginc" and add shader variants for editor. + #include "Packages/com.coffee.softmask-for-ugui/Shaders/SoftMask.cginc" + #pragma multi_compile_local _ SOFTMASK_EDITOR + + // "SoftMask" function returns [0-1]. Multiply this by the final output. + color.a *= SoftMask(IN.vertex, IN.worldPosition, color.a); + ``` + - Result: [Hidden/UI/Additive (SoftMaskable)](https://raw.githubusercontent.com/mob-sakai/SoftMaskForUGUI/develop/Assets/Demos/SoftMaskable%20Shader/Hidden-UI-Additive-SoftMaskable.shader) + + ![](https://github.com/user-attachments/assets/e7856aee-89f2-435e-8613-1b7ff706916f) + +

-There are two ways to support soft masks with custom shaders. +### ⚠️ Limitations -NOTE: To support soft masks, you need to add the `(SoftMaskable)` suffix to the shader name. +The following are the limitations of SoftMaskForUGUI. -1. **Hybrid (recommended)**: Add a `SoftMaskable` variant to the existing shader. - This way requires minimal changes (add few lines). -2. **Separate**: Create a new shader with a `SoftMaskable` variant. - Use this way for built-in shaders that cannot be edited, like `UI/Default`. +- (Android) `RGB ETC1 (+ Split alpha channel)` texture format is not supported. + - Use a format that supports alpha, such as `RGBA ETC2`. + - Technically possible, but not supported because [ETC2 support rate is over 95%](https://developer.android.com/guide/playcore/asset-delivery/texture-compression).