diff --git a/Assets/Editor/ExportPackage.cs b/Assets/Editor/ExportPackage.cs index 3d52b641..645cf944 100644 --- a/Assets/Editor/ExportPackage.cs +++ b/Assets/Editor/ExportPackage.cs @@ -45,6 +45,8 @@ static void Export() // Export package AssetDatabase.ExportPackage(kAssetPathes, kPackageName, ExportPackageOptions.Recurse | ExportPackageOptions.Default); UnityEngine.Debug.Log("Export successfully : " + kPackageName); + + System.IO.File.Copy("Assets/UIEffect/Readme.md", "Readme.md", true); } static void CreateMaterialVariant(Shader shader, ToneMode[] tones, ColorMode[] colors, BlurMode[] blurs) diff --git a/Assets/UIEffect/Editor/UIEffectEditor.cs b/Assets/UIEffect/Editor/UIEffectEditor.cs index b6db244f..c4d3a59f 100644 --- a/Assets/UIEffect/Editor/UIEffectEditor.cs +++ b/Assets/UIEffect/Editor/UIEffectEditor.cs @@ -217,9 +217,10 @@ public override void OnInspectorGUI() serializedObject.ApplyModifiedProperties(); #if UNITY_5_6_OR_NEWER - if((target as UIEffect).graphic) + var graphic = (target as UIEffect).graphic; + if(graphic) { - var canvas = (target as UIEffect).graphic.canvas; + var canvas = graphic.canvas; if( canvas && 0 == (canvas.additionalShaderChannels & AdditionalCanvasShaderChannels.TexCoord1)) { using (new GUILayout.HorizontalScope()) diff --git a/Assets/UIEffect/Readme.md b/Assets/UIEffect/Readme.md index f90df1f0..24366ac4 100644 --- a/Assets/UIEffect/Readme.md +++ b/Assets/UIEffect/Readme.md @@ -135,6 +135,11 @@ Please enable `TexCoord1` to use UIEffect.



## Release Notes +### ver.1.6.1 + +* Fixed: Cannot access protected member `UnityEngine.UI.BaseMeshEffect.graphic` in Unity5.6+. + + ### ver.1.6.0 * Changed: UIEffect inherit BaseMeshEffect. diff --git a/Assets/UIEffect/UIEffect.cs b/Assets/UIEffect/UIEffect.cs index 8d006536..28df9f2e 100644 --- a/Assets/UIEffect/UIEffect.cs +++ b/Assets/UIEffect/UIEffect.cs @@ -135,6 +135,11 @@ public enum BlurMode //################################ // Public or Serialize Members. //################################ + /// + /// Graphic affected by the UIEffect. + /// + new public Graphic graphic { get { return base.graphic; } } + /// /// Tone effect level between 0(no effect) and 1(complete effect). /// diff --git a/LICENSE.txt b/LICENSE.txt deleted file mode 120000 index 61ec2aa6..00000000 --- a/LICENSE.txt +++ /dev/null @@ -1 +0,0 @@ -./Assets/UIEffect/LICENSE.txt \ No newline at end of file diff --git a/LICENSE.txt b/LICENSE.txt new file mode 100644 index 00000000..a26d8fbe --- /dev/null +++ b/LICENSE.txt @@ -0,0 +1,7 @@ +Copyright 2017 mob-sakai + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/Readme.md b/Readme.md deleted file mode 120000 index 7cef7f09..00000000 --- a/Readme.md +++ /dev/null @@ -1 +0,0 @@ -./Assets/UIEffect/Readme.md \ No newline at end of file diff --git a/Readme.md b/Readme.md new file mode 100644 index 00000000..24366ac4 --- /dev/null +++ b/Readme.md @@ -0,0 +1,288 @@ +UIEffect +=== + +Easy to use effects for uGUI. + +![image](https://user-images.githubusercontent.com/12690315/35077815-5ff8094e-fc42-11e7-92dd-99916c9f9da7.png) + +[WebGL Demo](#demo) | [Download](https://github.com/mob-sakai/UIEffect/releases) | [Usage](#usage) | [Release Notes](#release-notes) + + +### Supports following effects! + +* Grayscale +* Sepia tone +* Nega tone +* Pixelation +* Hue shift +* Cutoff (alpha-based) +* Mono (alpha-based) +* Color override +* Color additive +* Color subtract +* Blur fast(3x4) +* Blur medium(6x4) +* Blur detail(6x8) +* Shadow with effect + * Shadow + * Shadow3 + * Outline + * Outline8 +* Gradient vertex color + * Horizontal + * Vertical + * Angle + * Diagonal + + +#### And, more features! + +* Control effect parameter with Animation +![image](https://user-images.githubusercontent.com/12690315/34617750-cf2c9464-f27f-11e7-8ee9-e6be3b209943.gif) +* Use for screen transition +![image](https://user-images.githubusercontent.com/12690315/34618554-71a32e40-f282-11e7-8b78-6948c50c6b58.gif) +* Multiple shadow effect to reduce rendering vertices +![image](https://user-images.githubusercontent.com/12690315/34552373-600fdab2-f164-11e7-8565-21c15af92a93.png) +* Capture image with effect, like post effect +![image](https://user-images.githubusercontent.com/12690315/34619147-868cb36a-f284-11e7-8122-b924ff09077f.gif) +* Dialog with captured image effect +![image](https://user-images.githubusercontent.com/12690315/34619468-97e3c134-f285-11e7-90b2-3a75bde13911.gif) +* Change vertex color as gradient, with rotation, offset, color correction +![image](https://user-images.githubusercontent.com/12690315/34931353-b1824df2-fa11-11e7-9dda-18aba10a8607.gif) +![image](https://user-images.githubusercontent.com/12690315/34930676-000c41d4-fa0e-11e7-825b-d5a1e757fea8.png) + + + +



+## Demo + +[WebGL Demo](https://developer.cloud.unity3d.com/share/WJTY06hfG7/webgl/) + +* Effect sample +* Transition +* Dialog window with blur background +* Included in unitypackage + + + + +



+## Usage + +1. Download UIEffect.unitypackage from [Releases](https://github.com/mob-sakai/UIEffect/releases) and install to your project. +1. Import the package into your Unity project. Select `Import Package > Custom Package` from the `Assets` menu. +1. Add `UIEffect` component to UI element (Image, RawImage, Text, etc...) from `Add Component` in inspector. +1. Choose effect type and adjust values in inspector. +![image](https://user-images.githubusercontent.com/12690315/34595809-3838dc54-f21e-11e7-858b-72821dca8b44.png) +1. Enjoy! + + +##### Requirement + +* Unity 5.3+ *(included Unity 2017.x)* +* No other SDK are required + + +



+## Development Note + +#### How does UIEffectCapturedImage work? + +![image](https://user-images.githubusercontent.com/12690315/34619147-868cb36a-f284-11e7-8122-b924ff09077f.gif) + +`UIEffectCapturedImage` is similar to post effect, but uses `CommandBuffer` to give effect only on the rendering result (= captured image) of a specific frame. +This effect is non-realtime, light-weight, less-camera, blit only once, but effective. + +* Camera for processing effect is unnecessary. +* Process effect only once after `UIEffectCapturedImage.Capture`. +* Using reduction buffer, keep used memory size small and keep rendering load are small. +* When GameObjects with motion are on the screen, a result texture may be stirred. +* You can overlay and display like as: [Screen] | [UIEffectCapturedImage] | [Dialog A] | [UIEffectCapturedImage] | [Dialog B]. +See also [Demo](#demo). + + +#### Why is UIEffect lightweight? + +* UIEffect pre-generates material from a combination of effects. This has the following benefits. + * Draw call batching If possible, draw calls will decrease. + * Since only the required material and shader variants are included in the build, the build size will be smaller. + + +#### How to control effect parameters for uGUI element WITHOUT MaterialPropertyBlock? + +* In general, you can use [MaterialPropertyBlock](https://docs.unity3d.com/ScriptReference/MaterialPropertyBlock.html) for renderers to control minor changes in the material without different batches. +* However, changing the [MaterialPropertyBlock](https://docs.unity3d.com/ScriptReference/MaterialPropertyBlock.html) of the uGUI element from the script will cause different batches and draw calls to increase. +* So UIEffect encodes multiple effect parameters to UV1 channel with [IMeshModifier](https://docs.unity3d.com/ScriptReference/UI.IMeshModifier.html). + * Pack four 6-bit [0-1] (64 steps) parameters into one float value. + * The parameters are low precision, but sufficient. + +| uv1 | 6-bit [0-1] | 6-bit [0-1] | 6-bit [0-1] | 6-bit [0-1] | +|-|-|-|-|-| +| x(32bit float) | Tone level | *Empty* | Blur level | *Empty* | +| y(32bit float) | Red channel | Green channel | Blue channel | Alpha channel | + + +#### Note: Unity 5.6+ + +In Unity 5.6+, Canvas supports **Additional Shader Channels**. +Please enable `TexCoord1` to use UIEffect. +![image](https://user-images.githubusercontent.com/12690315/28405830-f4f261e8-6d68-11e7-9faf-7e5442062f59.png) +![image](https://user-images.githubusercontent.com/12690315/34560894-191b6cda-f18b-11e7-9de2-9a9d13f72ccd.png) + + + + +



+## Release Notes + +### ver.1.6.1 + +* Fixed: Cannot access protected member `UnityEngine.UI.BaseMeshEffect.graphic` in Unity5.6+. + + +### ver.1.6.0 + +* Changed: UIEffect inherit BaseMeshEffect. +* Fixed: Pixelization is incorrect. +* Changed: ShadowMode -> ShadowStyle. +* Changed: Blur level is range [0-1]. + + +### ver.1.5.1 + +* Fixed: An error occurs when no effect is specified for UICapturedImage. [#36](https://github.com/mob-sakai/UIEffect/issues/36) + + +### ver.1.5.0 + +* Feature: Add ToneMode `Hue Shift`. +![image](https://user-images.githubusercontent.com/12690315/34830409-18114e44-f727-11e7-849a-0d61a35f03ea.png) +* Feature: Add ShadowMode `Shadow3`. +![image](https://user-images.githubusercontent.com/12690315/34930812-cb87dc24-fa0e-11e7-90a7-0013e2ba55d1.png) +* Feature: Add `UIGradient` component to change vertex color as gradient. + * Gradient direction + * Horizontal + * Vertical + * Angle + * Diagonal + * Rotation and offset + * Text gradient style + * Rect + * Fit + * Split + * Color space + * Uninitialized + * Gammma + * Linear + * Ignore aspect ratio + ![image](https://user-images.githubusercontent.com/12690315/34930676-000c41d4-fa0e-11e7-825b-d5a1e757fea8.png) + + +### ver.1.4.4 + +* Fixed: Error has occur on edit prefab. [#27](https://github.com/mob-sakai/UIEffect/issues/27) + + +### ver.1.4.3 + +* Fixed: Color effect is incorrect. [#19](https://github.com/mob-sakai/UIEffect/issues/19) + + +### ver.1.4.2 + +* Fixed: Error has occur on after deserialize. [#16](https://github.com/mob-sakai/UIEffect/issues/16) + + +### ver.1.4.1 + +* Fixed: Demo link in `readme.md` is broken. + + +### ver.1.4.0 + +* Changed: ToneMode, ColorMode, BlurMode can be changed only in editor. +* Changed: Cutoff's level is reversed. +* Feature: Exclude unused shader variant from build. +* Add: Add many materials for shader variant, but exclude unused materials from build. +Build report of demo project is as following. + +| | ver.1.3.0 | ver.1.4.0 | +|--|-----------|-----------| +| UI-Effect.shader | All 112 variants, 170.7 kb | 21 variants, 31.4 kb | +| UI-EffectCapturedImage.shader | All 80 variants, 49.0 kb | 2 variants, 7.3 kb | +| Materials in build | Instantiate on play, 0 kb | 23 items, about 6.9 kb | +| Total | 219.7 kb | 45.6 kb | + + +### ver.1.3.0 + +* Feature: Capture image with effect, like post effect. +* Demo: Add transition blur button & dialog with captured image effect. +![image](https://user-images.githubusercontent.com/12690315/34619468-97e3c134-f285-11e7-90b2-3a75bde13911.gif) + + +### ver.1.2.0 + +* Fixed : Pixelaration shifts to the lower right. +* Fixed : Cutoff alpha is incorrect. +* Feature: Supports multiple shadow effect for reduce rendering vertices. +![image](https://user-images.githubusercontent.com/12690315/34552373-600fdab2-f164-11e7-8565-21c15af92a93.png) +* Feature: New blur effect mode : `Medium`. +* Feature: Fix button to enable TexCoord1 of Canvas.additionalShaderChannels to use UIEffect. +![image](https://user-images.githubusercontent.com/12690315/34560894-191b6cda-f18b-11e7-9de2-9a9d13f72ccd.png) +* Changed : UIEffect.color is obsolete, use UIEffect.effectColor instead. +* Changed: Blur range is [0-2]. +* Refactoring: Shader refactoring. +* Demo: Add transition button & multiple shadows. + + +### ver.1.1.0 + +* Feature: Add Pixelaration effect. +* Feature: Add Cutoff/Mono effect for patterned alpha images. It can be used for masks and transitions! +![image](https://user-images.githubusercontent.com/12690315/34618554-71a32e40-f282-11e7-8b78-6948c50c6b58.gif) + + +### ver.1.0.0 + +* Feature: Shader supports pre-processer macros (for example UNITY_VERTEX_OUTPUT_STEREO) for Unity 5.3.x, 5.4.x and 5.5.x. +* Feature: Supports changing value from animation. +* Feature: Supports Tone effect. + * grayscale + * sepia + * nega +* Feature: Supports Color effect. + * set + * add + * sub +* Feature: Supports Blur effect. + * fast + * detail +* Fix: Color effect will not be properly when it was rotated. +* Performance: Shader supports multi-compile for performance. +* Performance: Cache same effect materials to reduce draw calls. +* Improve: Supports mobile devices. +* Improve: Simplify component & inspector. + + + +



+## License + +* MIT +* © UTJ/UCL + + + +## Author + +[mob-sakai](https://github.com/mob-sakai) + + + +## See Also + +* GitHub Page : https://github.com/mob-sakai/UIEffect +* Releases : https://github.com/mob-sakai/UIEffect/releases +* Issue tracker : https://github.com/mob-sakai/UIEffect/issues +* Current Project : https://github.com/mob-sakai/UIEffect/projects/1 \ No newline at end of file diff --git a/UIEffect.unitypackage b/UIEffect.unitypackage index 6519d564..7389fa27 100644 Binary files a/UIEffect.unitypackage and b/UIEffect.unitypackage differ