1.0.0-preview.8
# [1.0.0-preview.8](https://github.com/mob-sakai/SoftMaskForUGUI/compare/v1.0.0-preview.7...v1.0.0-preview.8) (2020-09-08) ### Features * if the 'UIMask' sprite is specified as the source image, it is suggested to use another image ([ea904db](pull/122/headea904dbe3a
)), closes [#82](https://github.com/mob-sakai/SoftMaskForUGUI/issues/82) * option to disable softening completely ([dedd847](dedd847fd0
)), closes [#98](https://github.com/mob-sakai/SoftMaskForUGUI/issues/98) * use the stencil buffer outside the scene view canvas for editing ([dbab85c](dbab85c0f0
)), closes [#100](https://github.com/mob-sakai/SoftMaskForUGUI/issues/100)
parent
1479064931
commit
58eeefc698
|
@ -1,3 +1,12 @@
|
|||
# [1.0.0-preview.8](https://github.com/mob-sakai/SoftMaskForUGUI/compare/v1.0.0-preview.7...v1.0.0-preview.8) (2020-09-08)
|
||||
|
||||
|
||||
### Features
|
||||
|
||||
* if the 'UIMask' sprite is specified as the source image, it is suggested to use another image ([ea904db](https://github.com/mob-sakai/SoftMaskForUGUI/commit/ea904dbe3afd9f18eab0d449bd08bf78375fd53d)), closes [#82](https://github.com/mob-sakai/SoftMaskForUGUI/issues/82)
|
||||
* option to disable softening completely ([dedd847](https://github.com/mob-sakai/SoftMaskForUGUI/commit/dedd847fd0c5faa5094a08293600cbb8aa4b6456)), closes [#98](https://github.com/mob-sakai/SoftMaskForUGUI/issues/98)
|
||||
* use the stencil buffer outside the scene view canvas for editing ([dbab85c](https://github.com/mob-sakai/SoftMaskForUGUI/commit/dbab85c0f0bd8a58b8ab09306bed351ad1cf6375)), closes [#100](https://github.com/mob-sakai/SoftMaskForUGUI/issues/100)
|
||||
|
||||
# [1.0.0-preview.7](https://github.com/mob-sakai/SoftMaskForUGUI/compare/v1.0.0-preview.6...v1.0.0-preview.7) (2020-08-17)
|
||||
|
||||
|
||||
|
|
|
@ -58,6 +58,22 @@ namespace Coffee.UISoftMask
|
|||
GUILayout.EndHorizontal();
|
||||
}
|
||||
|
||||
var currentImage = current.graphic as Image;
|
||||
if (currentImage && IsMaskUI(currentImage.sprite))
|
||||
{
|
||||
GUILayout.BeginHorizontal();
|
||||
EditorGUILayout.HelpBox("SoftMask does not recommend to use 'UIMask' sprite as a source image.\n(It contains only small alpha pixels.)\nDo you want to use 'UISprite' instead?", MessageType.Warning);
|
||||
GUILayout.BeginVertical();
|
||||
|
||||
if (GUILayout.Button("Fix"))
|
||||
{
|
||||
currentImage.sprite = AssetDatabase.GetBuiltinExtraResource<Sprite>("UI/Skin/UISprite.psd");
|
||||
}
|
||||
|
||||
GUILayout.EndVertical();
|
||||
GUILayout.EndHorizontal();
|
||||
}
|
||||
|
||||
// Preview buffer.
|
||||
GUILayout.BeginVertical(EditorStyles.helpBox);
|
||||
if (s_Preview != (s_Preview = EditorGUILayout.ToggleLeft("Preview Soft Mask Buffer", s_Preview)))
|
||||
|
@ -76,6 +92,13 @@ namespace Coffee.UISoftMask
|
|||
GUILayout.EndVertical();
|
||||
}
|
||||
|
||||
private static bool IsMaskUI(Object obj)
|
||||
{
|
||||
return obj
|
||||
&& obj.name == "UIMask"
|
||||
&& AssetDatabase.GetAssetPath(obj) == "Resources/unity_builtin_extra";
|
||||
}
|
||||
|
||||
|
||||
//%%%% Context menu for editor %%%%
|
||||
[MenuItem("CONTEXT/Mask/Convert To SoftMask", true)]
|
||||
|
|
|
@ -72,7 +72,7 @@ namespace Coffee.UISoftMask
|
|||
[SerializeField, Tooltip("The desampling rate for soft mask buffer.")]
|
||||
private DesamplingRate m_DesamplingRate = DesamplingRate.x1;
|
||||
|
||||
[SerializeField, Range(0.01f, 1), Tooltip("The value used by the soft mask to select the area of influence defined over the soft mask's graphic.")]
|
||||
[SerializeField, Range(0, 1), Tooltip("The value used by the soft mask to select the area of influence defined over the soft mask's graphic.")]
|
||||
private float m_Softness = 1;
|
||||
|
||||
[SerializeField, Range(0f, 1f), Tooltip("The transparency of the whole masked graphic.")]
|
||||
|
|
|
@ -38,7 +38,7 @@ namespace Coffee.UISoftMask
|
|||
private int m_MaskInteraction = kVisibleInside;
|
||||
|
||||
[SerializeField, Tooltip("Use stencil to mask.")]
|
||||
private bool m_UseStencil;
|
||||
private bool m_UseStencil = true;
|
||||
|
||||
[SerializeField, Tooltip("Use soft-masked raycast target.\n\nNote: This option is expensive.")]
|
||||
private bool m_RaycastFilter;
|
||||
|
|
|
@ -23,7 +23,8 @@ Shader "Hidden/SoftMask" {
|
|||
|
||||
fixed4 frag (v2f_img i) : SV_Target
|
||||
{
|
||||
return saturate(tex2D(_MainTex, i.uv).a/_Softness) * _Alpha;
|
||||
half softness = max(_Softness, 0.0001f);
|
||||
return saturate(tex2D(_MainTex, i.uv).a/softness) * _Alpha;
|
||||
}
|
||||
ENDCG
|
||||
}
|
||||
|
|
|
@ -37,11 +37,10 @@ float SoftMaskInternal(float4 clipPos)
|
|||
#endif
|
||||
|
||||
fixed4 mask = tex2D(_SoftMaskTex, view);
|
||||
half4 alpha = saturate(lerp(fixed4(1, 1, 1, 1), lerp(mask, 1 - mask, _MaskInteraction - 1), _MaskInteraction))
|
||||
half4 alpha = saturate(lerp(fixed4(1, 1, 1, 1), lerp(mask, 1 - mask, _MaskInteraction - 1), _MaskInteraction));
|
||||
#if SOFTMASK_EDITOR
|
||||
* step(0, view.x) * step(view.x, 1) * step(0, view.y) * step(view.y, 1)
|
||||
alpha = lerp(fixed4(1, 1, 1, 1), alpha, step(0, view.x) * step(view.x, 1) * step(0, view.y) * step(view.y, 1));
|
||||
#endif
|
||||
;
|
||||
|
||||
return alpha.x * alpha.y * alpha.z * alpha.w;
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
"name": "com.coffee.softmask-for-ugui",
|
||||
"displayName": "UI Soft Mask",
|
||||
"description": "UI Soft Mask is a smooth masking component for Unity UI (uGUI) elements.\nBy using SoftMask instead of the default Mask component, you can beautifully represent the rounded edges of UI elements.",
|
||||
"version": "1.0.0-preview.7",
|
||||
"version": "1.0.0-preview.8",
|
||||
"unity": "2017.1",
|
||||
"license": "MIT",
|
||||
"repository": {
|
||||
|
|
Loading…
Reference in New Issue