关闭

透明通道图纹理贴图渐变色效果

标签: fragmentunity shadervertex片段顶点着色器
368人阅读 评论(0) 收藏 举报
分类:




Shader "YouXiDao/AlphaSimple"
{
Properties
{
_MainTex ("Texture", 2D) = "white" {}
_Color("Main Color", Color) = (1, 1, 1, 1)
}
SubShader
{
Tags { //贴图带透明通道 ,半透明效果设置如下:
"Queue"= "Transparent" 
"RenderType"="Transparent" 
"IgnoreProjector" = "True"
}

Pass
{
Cull off
fog{Mode Off} //雾效关闭,半透明效果用Blend
Blend  SrcAlpha OneMinusSrcAlpha           //Blend选值为: SrcAlpha 和1-SrcAlpha  //也可测试为 DstColor SrcColor    //one one            
ZWrite Off

CGPROGRAM
#pragma vertex vert
#pragma fragment frag
// make fog work
//#pragma multi_compile_fog
#pragma multi_compile_instancing
#include "UnityCG.cginc"

sampler2D _MainTex;//变量使用前声明
float4 _Color;

struct appdata
{
float4 vertex : POSITION;//模型顶点坐标
float2 uv : TEXCOORD0;//模型纹理坐标
float3 normal:NORMAL;//模型法线
float4 color : COLOR;    //模型不带顶点颜色情况下为白色
};

struct v2f
{
float4 uv : TEXCOORD0;
//UNITY_FOG_COORDS(1)
float4 vertex : SV_POSITION;
float4 col :COLOR;
};

v2f vert (appdata v)
{
v2f o;
o.vertex =  mul(UNITY_MATRIX_MVP, v.vertex);//unity5.4版本之上  UnityObjectToClipPos(v.vertex)
o.uv = float4(v.uv.xy,0,0);//TRANSFORM_TEX(v.uv, _MainTex);
o.col = v.vertex +0.5;                      // 根据顶点坐标设置颜色(颜色设置小于0部分为0,大于1部分为1)。
//还可以根据法线设置颜色 o.col =  float4(v.normal *0.5 +0.5, 1.0);根据UV坐标设置颜色o.col =  float4(v.uv,0.0,1.0) B蓝色部分为0
return o;
}

fixed4 frag (v2f i) : SV_Target
{
// sample the texture
half4 col =  i.col * _Color * tex2D(_MainTex, i.uv) ;  //颜色结果为:顶点颜色X我们设置的颜色X纹理贴图颜色
// if(any(saturate(i.uv)-i.uv))//saturate:如果 x 小于 0 ,返回 0 ;如果 x 大于 1 ,返回 1 ;否则,返回 x
// col.b=0.5; //UV坐标0-1之外的部分蓝色为0.5// apply fog //any,非0为true,为false//UNITY_APPLY_FOG(i.fogCoord, col);
return col;
}
ENDCG
}
}
}



//Blend  SrcAlpha OneMinusSrcAlpha      注释掉之后不带透明效果


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:13239次
    • 积分:343
    • 等级:
    • 排名:千里之外
    • 原创:19篇
    • 转载:10篇
    • 译文:0篇
    • 评论:3条
    最新评论