<< 📝 Description | 📌 Key Features | 🎮 Demo | ⚙ Installation | 🔄 Upgrading from v4 to v5 | 🚀 Usage | 🤝 Contributing >>
"Decorate your UI, simply and powerfully."
UIEffect is an open-source package that allows you to intuitively apply rich Unity UI effects directly from the Inspector or via code.
Combine various filters, such as grayscale, blur, and dissolve, to decorate your UI with a unique visual style!
- 📌 Key Features
- 🎮 Demo
- ⚙ Installation
- 🔄 Upgrading from v4 to v5
- 🚀 Usage
- 🤝 Contributing
- License
- Author
- See Also
- UIEffect is out-of-the-box!: Easily apply effects by adjusting parameters directly in the inspector.
- Rich effect combinations: Decorate your UI with a variety of effects, such as grayscale, blur, and dissolve, by combining multiple filters and parameters.
- Efficient shader builds: Only the shader variants in use are built, resulting in shorter build times.
- URP/HDRP/VR support: Compatible with URP, HDRP, and VR environments.
- Runtime and editor presets: Presets are available both at runtime and in the editor.
- TextMeshPro support: Supports TextMeshPro, including
<font>
and<sprite>
tags. - UIEffectReplica Component: Duplicate effects and apply them to multiple UI elements at once.
- UIEffectTweener Component: A simple tweener component to play, stop, pause, and resume effects.
- AnimationClip support: Allows control of effect animations using
AnimationClips
. - v4 compatible components (optional): For easy upgrading with minimal changes, compatible v4 components are available optionally.
This package requires Unity 2020.3 or later.
- This package is available on OpenUPM package registry.
- This is the preferred method of installation, as you can easily receive updates as they're released.
- If you have openupm-cli installed, then run the following command in your project's directory:
openupm add com.coffee.ui-effect
- To update the package, use Package Manager UI (
Window > Package Manager
) or run the following command with@{version}
:openupm add [email protected]
- 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/UIEffect.git?path=Packages/src
- To update the package, change suffix
#{version}
to the target version.- e.g.
https://github.com/mob-sakai/UIEffect.git?path=Packages/src#5.0.0
- e.g.
-
Open the
Packages/manifest.json
file in your project. Then add this package somewhere in thedependencies
block:{ "dependencies": { "com.coffee.ui-effect": "https://github.com/mob-sakai/UIEffect.git?path=Packages/src", ... } }
-
To update the package, change suffix
#{version}
to the target version.- e.g.
"com.coffee.ui-effect": "https://github.com/mob-sakai/UIEffect.git?path=Packages/src#5.0.0",
- e.g.
- Download the
Source code (zip)
file from Releases and extract it. - Move the
<extracted_dir>/Packages/src
directory into your project'sPackages
directory.
- You can rename the
src
directory if needed. - If you intend to fix bugs or add features, installing it as an embedded package is recommended.
- To update the package, re-download it and replace the existing contents.
- You can rename the
Additional resources can be imported to extend functionality.
If upgrading from UIEffect v4 to v5, note the following breaking changes:
-
If you are installing via git URL, add
?path=Packages/src
. The default branch is changedupm
tomain
.// v4 "com.coffee.ui-effect": "https://github.com/mob-sakai/UIEffect.git", "com.coffee.ui-effect": "https://github.com/mob-sakai/UIEffect.git#upm", // v5 "com.coffee.ui-effect": "https://github.com/mob-sakai/UIEffect.git?path=Packages/src",
-
Import the
v4 Compatible Components
sample from the Package Manager window.
-
All v4 components are obsolete.
- v4
UIEffect
component is nowUIEffectV4
component. Change the reference in the code. - The
effectArea
property in some components are not supported in v5. UIShadow
,UIGradient
,UIFlip
components are not supported in v5.- v4 components can be converted to v5
UIEffect
component by selectingConvert To UIEffect
from the context menu.
-
Add a
UIEffect
component to a UI element (Image, RawImage, Text, TextMeshProUGUI, etc...) from theAdd Component
in the inspector orComponent > UI > UIEffect
menu.
-
Enjoy!
The UIEffect
component applies visual effects to UI elements, allowing various effects to be achieved by combining multiple filters.
- Tone Filter:
None
,Grayscale
,Sepia
,Nega
,Retro
,Posterize
- Tone Intensity: 0.0 (no effect) - 1.0 (full effect).
- Color Filter:
None
,Multiply
,Additive
,Subtractive
,Replace
,Multiply Luminance
,Multiply Additive
,Hsv Modifier
,Contrast
- Color Intensity: 0.0 (no effect) - 1.0 (full effect).
- Color Glow: Set the color to glow.
- Sampling Filter:
None
,Blur Fast
,Blur Medium
,Blur Detail
,Pixelation
,Rgb Shift
,Edge Luminescence
,Edge Alpha
- Sampling Intensity: 0.0 (no effect) - 1.0 (full effect).
- Transition Filter:
None
,Fade
,Cutoff
,Dissolve
,Shiny
,Mask
,Melt
,Burn
- Transition Rate: 0.0 (no effect) - 1.0 (full effect).
- Transition Tex: The texture used for the transition filter.- Transition Width: The width where the transition color is applied.
- Transition Softness: The softness of the boundary for the transition color.
- Transition Color Filter: Specifies the transition color.
- Transition Color: The color of the transition.
- Transition Color Glow: Set the transition color to glow.
- Target Mode:
None
,Hue
,Luminance
- Restricts the effect application area based on hue or luminance.
- Target Range: The range of target hue or luminance.
- Target Softness: The softness of the target boundary.
- Blend Type:
Alpha Blend
,Multiply
,Additive
,Soft Additive
,Multiply Additive
,Custom
Custom
blend type can be set using theSrcBlend
andDstBlend
properties.
- Shadow Mode:
None
,Shadow
,Shadow3
,Outline
,Outline8
,Mirror
- Shadow Distance: Distance of the shadow or outline.
- Shadow Iteration: Number of times the shadow or outline is applied.
- Shadow Color Filter: Specifies the shadow color.
- Shadow Color: The color of the shadow.
- Shadow Color Glow: Set the shadow color to glow.
- Shadow Fade: Alpha value of the shadow or outline.
- Shadow Blur Intensity: Intensity of the shadow or outline blur.
- Mirror Reflection: Distance of the mirrored image.
- Mirror Offset: Offset for the mirrored image.
- Mirror Scale: Scale of the mirrored image.
- Gradation Mode:
None
,Horizontal Gradient
,Horizontal
,Vertical Gradient
,Vertical
,Radial Fast
,Radial Detail
,Diagonal To Right Bottom
,Diagonal To Right Top
,Diagonal To Left Bottom
,Angle
,Angle Gradient
- Gradation Gradient: The gradient of the gradation.
- Gradation Color 1: The first color of the gradation.
- Gradation Color 2: The second color of the gradation.
- Gradation Offset: The offset of the gradation range.
- Gradation Scale: The scale of the gradation range.
- Gradation Rotation: The rotation of the gradation range.
Tip
Horizontal Gradient
and Vertical Gradient
divide the mesh horizontally or vertically and apply a gradient.
This is very fast but only supports Full Rect.
Angle Gradient
divides the mesh at the specified angle and applies a gradient.
It can be applied to meshes other than Full Rect because it applies the gradient according to the original mesh shape.
Gradation Gradient
has two modes, Blend
and Fixed
.
- Sampling Scale: The referencing scale during sampling.
- Larger values are suitable for high-resolution textures.
- Allow To Modify Mesh Shape: If enabled, the mesh shape can be modified.
The UIEffectTweener
component animates the effect, enabling easy control over effect animations without the need for an AnimationClip
.
- Culling Mask:
Tone
,Color
,Sampling
,Transition
- Direction:
Forward (0.0 -> 1.0)
,Reverse (1.0 -> 0.0)
- Curve: The curve of the animation.
- Delay: The delay time before starting the animation.
- Duration: The duration of the animation.
- Interval: The interval time between the animation.
- Play On Enable:
None
,Forward
,Reverse
,Keep Direction
- Play the animation automatically when the component is enabled.
- If
None
is selected, the animation will not play automatically. You can play it using thePlay
,PlayForward
orPlayReverse
method.
- Wrap Mode:
Once
,Loop
,PingPongOnce
,PingPongLoop
- Update Mode:
Normal
,UnscaledTime
,Manual
- On Complete: A event that is triggered when the animation is completed.
You can preview the animation using the seek bar and play button.
The UIEffectReplica
component applies visual effects to UI elements by replicating the settings of another UIEffect
component. This allows the same effect to be applied across multiple UI elements simultaneously.
- Target: The target
UIEffect
component to replicate. - Use Target Transform: Use the target's transform for some effects.
- Sampling Scale: Override the sampling scale.
- Allow To Modify Mesh Shape: If enabled, the mesh shape can be modified.
To use UIEffect with TextMeshPro, you need to import additional resources.
When a shader included in the samples is requested, an import dialog will automatically appear.
Click the Import
button.
Alternatively, you can manually import the resources by following these steps:
-
First, you must import TMP Essential Resources before using.
-
Open the
Package Manager
window and select theUI Effect
package in the package list and click theTextMeshPro Support > Import
button.
⚠️ If you are usingUnity 2023.2/6000.0+
orTextMeshPro 3.2/4.0+
, click theTextMeshPro Support (Unity 6) > Import
button instead.
-
The assets will be imported under
Assets/Samples/UI Effect/{version}
. -
Add the
UIEffect
component to a TextMeshProUGUI element and adjust the effect settings. The<font>
and<sprite>
tags are also supported.
Tip
TextMeshPro Support
may change with updates to the UIEffect package.
If issues occur, try importing it again.
You can create and use presets for UIEffect
components.
- In the
UIEffect
component inspector, click "Save As" button to save the current settings as an editor preset. - Click "Load" button to apply an editor preset.
- In the Project Settings, you can register saved editor presets as runtime presets.
- Runtime presets can be loaded using the
UIEffect.LoadPreset(presetName)
method.
Tip
Editor presets are saved in the UIEffectPresets
directory.
You can also create subdirectories to customize the preset menu.
You can control the effect settings and animations via code.
var effect = graphic.AddComponent<UIEffect>();
// Apply a preset
effect.LoadPreset("Dissolve");
// Set the effect parameters
effect.transitionWidth = 0.1f;
effect.transitionColor = Color.red;
// Add a tweener
var tweener = graphic.AddComponent<UIEffectTweener>();
tweener.cullingMask = UICullingMask.Tone;
tweener.wrapMode = UIWrapMode.PingPongLoop;
// Warm up the shader variant collection.
UIEffectProjectSettings.shaderVariantCollection.WarmUp();
You can adjust the project-wide settings for UIEffect. (Edit > Project Settings > UI > UIEffect
)
- Transform Sensitivity:
Low
,Medium
,High
- Set the sensitivity of the transformation when
Use Target Transform
is enabled inUIEffectReplica
component.
- Set the sensitivity of the transformation when
- Runtime Presets: A list of presets that can be loaded at runtime. Load them using
UIEffect.LoadPreset(presetName)
method.
- Use HDR Color Picker: If enabled, the HDR color picker will be used in the inspector.
- Optional Shaders (UIEffect): A list of shaders that will be prioritized when a ui-effect shader is
requested.
- If the shader is included in the list, that shader will be used.
- If it is not in the list, the following shaders will be used in order:
- If the shader name contains
(UIEffect)
, that shader will be used. - If
Hidden/<shader_name> (UIEffect)
exists, that shader will be used. - As a fallback,
UI/Default (UIEffect)
will be used.
- If the shader name contains
- Registered Variants: A list of shader variants available at runtime. Use "-" button to remove unused variants,
reducing build time and file size.
- By default, the used ui-effect shaders will be included in the build. You can remove them if you don't need.
- Unregistered Variants: A list of shader variants that are not registered. Use "+" button to add variants.
- Error On Unregistered Variant: If enabled, an error will be displayed when an unregistered shader variant is used.
- The shader variant will be automatically added to the
Unregistered Variants
list.
- The shader variant will be automatically added to the
Here are the limitations of UIEffect:
- Shader variants used at runtime must be registered in the Project Settings.
- When using UIEffect with TextMeshProUGUI,
SamplingFilter.BlurMedium
andSamplingFilter.BlurDetail
are not supported due to performance considerations.- These will automatically fall back to
SamplingFilter.BlurFast
.
- These will automatically fall back to
- UIEffect supports default UI components (
Image
,RawImage
,Text
) andTextMeshProUGUI
.- If you want to use UIEffect with other components, create a issue or pull request.
Issues are incredibly valuable to this project:
- Ideas provide a valuable source of contributions that others can make.
- Problems help identify areas where this project needs improvement.
- Questions indicate where contributors can enhance the user experience.
Pull requests offer a fantastic way to contribute your ideas to this repository.
Please refer to CONTRIBUTING.md
and use develop branch for development.
This is an open-source project developed during my spare time.
If you appreciate it, consider supporting me.
Your support allows me to dedicate more time to development. 😊
- MIT
- © UTJ/UCL