Unity3D Ui shader 로 효과 추가
// Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)'
Shader "UI/Unlit/Flowlight"
{
Properties
{
[PerRendererData] _MainTex("Sprite Texture", 2D) = "white" {}
_Color("Tint", Color) = (1, 1, 1, 1)
[MaterialToggle] _OffSet("OffSet", float) = 0
[MaterialToggle] PixelSnap("Pixel snap", float) = 0
/* Flowlight */
_FlowlightMaskTex("Mask Texture", 2D) = "white" {}
_FlowlightTex("Add Move Texture", 2D) = "white" {}
_FlowlightColor("Flowlight Color", Color) = (0, 0, 0, 1)
_Power("Power", float) = 1
_SpeedX("SpeedX", float) = 1
_SpeedY("SpeedY", float) = 0
/* --------- */
/* UI */
_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
/* -- */
}
SubShader
{
Tags
{
"Queue" = "Transparent"
"IgnoreProjector" = "True"
"RenderType" = "Transparent"
"PreviewType" = "Plane"
"CanUseSpriteAtlas" = "True"
}
Cull Off
Lighting Off
ZWrite Off
Blend One OneMinusSrcAlpha
/* UI */
Stencil
{
Ref[_Stencil]
Comp[_StencilComp]
Pass[_StencilOp]
ReadMask[_StencilReadMask]
WriteMask[_StencilWriteMask]
}
/* -- */
Pass
{
CGPROGRAM
#pragma vertex vert
#pragma fragment frag
#pragma multi_compile _ PIXELSNAP_ON
#include "UnityCG.cginc"
struct appdata_t
{
float4 vertex : POSITION;
float4 color : COLOR;
float2 texcoord : TEXCOORD0;
};
struct v2f
{
float4 vertex : SV_POSITION;
fixed4 color : COLOR;
half2 texcoord : TEXCOORD0;
/* Flowlight */
half2 texflowlight : TEXCOORD1;
/* --------- */
};
fixed4 _Color;
/* Flowlight */
fixed4 _FlowlightColor;
float _Power;
sampler2D _FlowlightTex;
fixed4 _FlowlightTex_ST;
sampler2D _FlowlightMaskTex;
fixed4 _FlowlightMaskTex_ST;
fixed _SpeedX;
fixed _SpeedY;
fixed x = 0;
float _OffSet;
/* --------- */
v2f vert(appdata_t IN)
{
v2f OUT;
OUT.vertex = UnityObjectToClipPos(IN.vertex);
OUT.texcoord = IN.texcoord;
/* Flowlight */
OUT.texflowlight = TRANSFORM_TEX(IN.texcoord, _FlowlightTex);
OUT.texflowlight.x += _Time * _SpeedX;
OUT.texflowlight.y += _Time * _SpeedY;
OUT.color = IN.color * _Color;
#ifdef PIXELSNAP_ON
OUT.vertex = UnityPixelSnap(OUT.vertex);
#endif
return OUT;
}
sampler2D _MainTex;
fixed4 frag(v2f IN) : SV_Target
{
fixed4 c = tex2D(_MainTex, IN.texcoord)*IN.color;
fixed4 cmask = tex2D(_FlowlightMaskTex, IN.texcoord);
if (cmask.a != 0)
{
/* Flowlight */
fixed4 cadd = tex2D(_FlowlightTex, IN.texflowlight) * _Power;
cadd.rgb *= c.rgb;
c.rgb += cadd.rgb;
}
c.rgb *= c.a;
/* --------- */
return c;
}
ENDCG
}
}
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Unity 공부 일지~블렌드 셰이프 조작 방법 그 ①게임을 만들고 싶다 ~라고 생각하고 마지막 날부터 Unity를 만지기 시작했습니다 HITOMI2236입니다. 이번 블렌드 셰이프에 대해 조사했으므로 여기에 기록하려고 합니다. 개인용 메모입니다만, 만약 같은 곳에서 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.