u3d无锯齿遮罩shader-可用于ugui

简介: 图片.png图片.png// 遮罩shaderShader "Custom/CircleMask" { Properties{ _MainTex("MainTex", 2D) = "white" ...
img_cc74c83db76e86932bb1f54b63a4389c.png
图片.png

img_af15bb53f71cba7f7e1b6b25f801124a.png
图片.png
// 遮罩shader

Shader "Custom/CircleMask" {
    Properties{
        _MainTex("MainTex", 2D) = "white" {}
    _MaskTex("MaskTex", 2D) = "white" {}
    [HideInInspector]_Cutoff("Alpha cutoff", Range(0,1)) = 0.5

        //MASK SUPPORT ADD
        _StencilComp("Stencil Comparison", Float) = 8
        _Stencil("Stencil ID", Float) = 0
        _StencilOp("Stencil Operation", Float) = 0
        _StencilWriteMask("Stencil Write Mask", Float) = 255
        _StencilReadMask("Stencil Read Mask", Float) = 255
        _ColorMask("Color Mask", Float) = 15
        //MASK SUPPORT END
    }
        SubShader{
        Tags{
        "IgnoreProjector" = "True"
        "Queue" = "Transparent"
        "RenderType" = "Transparent"
    }
        //MASK SUPPORT ADD
        Stencil
    {
        Ref[_Stencil]
        Comp[_StencilComp]
        Pass[_StencilOp]
        ReadMask[_StencilReadMask]
        WriteMask[_StencilWriteMask]
    }
        ColorMask[_ColorMask]
        //MASK SUPPORT END
        Pass{
        Name "FORWARD"
        Tags{
        "LightMode" = "ForwardBase"
    }
        Blend SrcAlpha OneMinusSrcAlpha
        ZWrite Off

        CGPROGRAM
#pragma vertex vert
#pragma fragment frag
#define UNITY_PASS_FORWARDBASE
#include "UnityCG.cginc"
#pragma multi_compile_fwdbase
#pragma only_renderers d3d9 d3d11 glcore gles
#pragma target 3.0
        uniform sampler2D _MainTex; uniform float4 _MainTex_ST;
    uniform sampler2D _MaskTex; uniform float4 _MaskTex_ST;
    struct VertexInput {
        float4 vertex : POSITION;
        float2 texcoord0 : TEXCOORD0;
    };
    struct VertexOutput {
        float4 pos : SV_POSITION;
        float2 uv0 : TEXCOORD0;
    };
    VertexOutput vert(VertexInput v) {
        VertexOutput o = (VertexOutput)0;
        o.uv0 = v.texcoord0;
        o.pos = UnityObjectToClipPos(v.vertex);
        return o;
    }
    float4 frag(VertexOutput i) : COLOR{
        ////// Lighting:
        float4 _MainTex_var = tex2D(_MainTex,TRANSFORM_TEX(i.uv0, _MainTex));
        float3 finalColor = _MainTex_var.rgb;
        float4 _MaskTex_var = tex2D(_MaskTex,TRANSFORM_TEX(i.uv0, _MaskTex));
        return fixed4(finalColor,_MaskTex_var.a);
    }
        ENDCG
    }
    }
        FallBack "Diffuse"
}
相关文章
|
图形学
浅谈Unity之ShaderGraph-等高线和高程渐变设色
ShaderGraph实现等高线和高程渐变设色
|
4月前
|
存储 编解码 算法
第5章-着色基础-5.4-锯齿和抗锯齿
第5章-着色基础-5.4-锯齿和抗锯齿
34 1
|
6月前
|
图形学
【实现100个unity特效】shader实现3D物品闪光和描边效果
【实现100个unity特效】shader实现3D物品闪光和描边效果
95 0
|
前端开发
自定义View 绘制 ,范围裁切,几何变换
自定义View 绘制 ,范围裁切,几何变换
自定义View 绘制 ,范围裁切,几何变换
|
前端开发 JavaScript
canvas中的拖拽、缩放、旋转 (上) —— 数学知识准备
canvas中的拖拽、缩放、旋转 (上) —— 数学知识准备
913 0
canvas中的拖拽、缩放、旋转 (上) —— 数学知识准备
使用手势对UIImageView进行缩放、旋转和移动
使用手势对UIImageView进行缩放、旋转和移动
104 0
|
前端开发 数据可视化
threejs 贴图动画总结
threejs 贴图动画总结
threejs 贴图动画总结
ShaderJoy —— 用 Shader 绘制爱心❤烟花【GLSL】
*ShaderJoy —— Shader 特效乐趣无穷*
439 0
简单的笔刷效果【OpenGL】
简单的笔刷效果【OpenGL】
207 0
简单的笔刷效果【OpenGL】
3D立方体图片切换动画
在线演示 本地下载
1013 1