精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

Unity3DShader如何實現流光效果-創新互聯

這篇文章主要為大家展示了Unity3D Shader如何實現流光效果,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

成都創新互聯是一家專業提供當涂企業網站建設,專注與成都網站制作、網站設計、H5建站、小程序制作等業務。10年已為當涂眾多企業、政府機構等服務。創新互聯專業的建站公司優惠進行中。

流光效果圖:

Unity3D Shader如何實現流光效果

演示工程:下載地址

//功能需求:模擬數據傳送效果,高亮色塊從模型上方移動到下方
//功能分析:這里采用UV動畫的方式來實現,利用Alpha貼圖控制流動的形狀
//  利用Alpha遮罩貼圖,控制模型中哪些地方需要進行流動

Shader "Custom/DataFlowEffect"
{
 Properties
 {
 _MainColor("Main Color",Color) = (1,1,1,1)
 _MainTex("Main Texture",2D) = "white"{}
 _Specular("Specular",Color) = (1,1,1,1)
 _Gloss("Gloss",Range(0,255)) = 20.0
 _FlowTex("Flow Tex (A)",2D) = "black"{}
 _FlowColor("Flow Color (RGBA)",Color)=(1,1,1,1)
 _FlowIdleTime("FlowInternal",Range(0,10))=1.0
 _FlowDuring("FlowDuring",Range(0,10))=1.0
 _FlowMaskTex("FlowMasking (A)",2D)="white"{}
 _FlowDirection("FlowDirection",Int)= 0
 _FlowBeginTime("Flow Begin Time",Float)=0
 }

 SubShader
 {
 Tags{"RenderType" = "Opaque" "Queue"="Geometry"}

 Pass
 {
  Tags{"LightMode"="ForwardBase"}
  Blend SrcAlpha OneMinusSrcAlpha

  CGPROGRAM

  #pragma vertex vert
  #pragma fragment frag

  #include "UnityCG.cginc"
  #include "Lighting.cginc"

  sampler2D _MainTex; //顏色貼圖
  half4 _MainTex_ST; //顏色UV 縮放和偏移
  fixed3 _MainColor; //漫反射顏色
  fixed3 _Specular; //高光顏色
  fixed _Gloss;  //高光度
  sampler2D _FlowTex; //數據流圖片
  fixed4 _FlowColor; //數據流顏色疊加
  half4 _FlowTex_ST; //數據流貼圖UV的縮放和偏移
  fixed _FlowIdleTime; //流動動畫間歇時間
  fixed _FlowDuring; //流動動畫播放時間
  sampler2D _FlowMaskTex; //流動遮罩
  fixed _FlowDirection; //流動方向
  float _FlowBeginTime; //流動效果開始的時間

  struct a2v
  {
  half4 pos: POSITION;
  half3 normal :NORMAL;
  half4 texcoord : TEXCOORD0;
  };

  struct v2f
  {
  half4 position : SV_POSITION;
  half2 uv : TEXCOORD0;
  half3 worldNormal : TEXCOORD1;
  half3 worldPos : TEXCOORD2;
  half2 flowUV : TEXCOORD3;
  };

  v2f vert(a2v i)
  {
  v2f v;
  v.position = UnityObjectToClipPos(i.pos);
  v.uv = i.texcoord * _MainTex_ST.xy + _MainTex_ST.zw;
  v.worldNormal = mul(unity_ObjectToWorld,i.normal);
  v.worldPos = mul(unity_ObjectToWorld,i.pos);
  v.flowUV = i.texcoord * _FlowTex_ST.xy + _FlowTex_ST.zw;
  return v;
  }

  //uv - vert的uv坐標
  //scale - 貼圖縮放
  //idleTime - 每次循環開始后多長時間,開始流動
  //loopTime - 單次流動時間
  fixed4 getFlowColor(half2 uv,int scale,fixed idleTime,fixed loopTime)
  {
  //當前運行時間
  half flowTime_ = _Time.y - _FlowBeginTime;

  //上一次循環開始,到本次循環開始的時間間隔
  half internal = idleTime + loopTime;

  //當前循環執行時間
  half curLoopTime = fmod(flowTime_,internal);

  //每次開始流動之前,有個停止間隔,檢測是否可以流動了
  if(curLoopTime > idleTime)
  {
   //已經流動時間
   half actionTime = curLoopTime - idleTime;

   //流動進度百分比
   half actionPercentage = actionTime / loopTime;

   half length = 1.0 / scale;

   //從下往上流動
   //計算方式:設:y = ax + b,其中y為下邊界值,x為流動進度
   //根據我們要求可以,x=0時y=-length;x=1時y=1;帶入解方程
   half bottomBorder = actionPercentage * (1+length) - length;
   half topBorder = bottomBorder + length;

   //從上往下流動
   //求解方法與上面類似
   if(_FlowDirection < 0)
   {
   topBorder = (-1-length) * actionPercentage + 1 + length;
   bottomBorder = topBorder - length;
   }

   if(uv.y < topBorder && uv.y > bottomBorder)
   {
   half y = (uv.y - bottomBorder) / length;
   return tex2D(_FlowTex,fixed2(uv.x,y)); 
   }
  }

  return fixed4(1,1,1,0);
  }

  fixed4 frag(v2f v):SV_Target
  {
  //計算漫反射系數
  fixed3 albedo = tex2D(_MainTex,v.uv) * _MainColor;

  //計算環境光
  fixed3 ambient = UNITY_LIGHTMODEL_AMBIENT.xyz * albedo;


  fixed3 worldNormal = normalize(v.worldNormal);    //世界坐標的法線方向
  fixed3 worldLightDir = normalize(UnityWorldSpaceLightDir(v.worldPos)); //世界坐標的光照方向
  fixed3 worldViewDir = normalize(UnityWorldSpaceViewDir(v.worldPos)); //世界坐標的視角方向

  //計算漫反射顏色,采用Half-Lambert模型
  fixed3 lightColor = _LightColor0.rgb;
  fixed3 diffuse = lightColor * albedo * max(0,0.5*dot(worldNormal,worldLightDir)+0.5);

  //計算高光,采用Blinn-Phone高光模型
  fixed3 halfDir = normalize(worldViewDir + worldLightDir);
  fixed3 specColor = _Specular * lightColor * pow(max(0,dot(worldNormal,halfDir)),_Gloss);

  //疊加流動貼圖  
  fixed4 flowColor = getFlowColor(v.uv,_FlowTex_ST.y,_FlowIdleTime,_FlowDuring); 
  fixed4 flowMaskColor = tex2D(_FlowMaskTex,v.uv);

  //與遮罩貼圖進行混合,只顯示遮罩貼圖不透明的部分
  flowColor.a = flowMaskColor.a * flowColor.a * _FlowColor.a;

  fixed3 finalDiffuse = lerp(diffuse,_FlowColor,flowColor.a);

  return fixed4(ambient + finalDiffuse+specColor,1);
  }

  ENDCG
 }
 }
 Fallback "Diffuse"
}

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


網頁名稱:Unity3DShader如何實現流光效果-創新互聯
標題鏈接:http://m.jcarcd.cn/article/cciheo.html
主站蜘蛛池模板: 国产日产韩 | 日韩免费在线 | 精品一二三区 | 日本a级精品一区 | 国产高清狼人香蕉 | 日韩毛A | 青草在线视频在 | 漂亮的保姆6| 国产精品国语对白 | 午夜a级理| 国偷自产a | 国产欧美在线人成 | 福利导航视频 | 日本三级香港 | 日本黄段在线免费看 | 99热在线上 | 老牛影院在线观看 | 国产精品亚洲片在 | 欧美日韩日本日日骚 | 国产终合在线 | 国产精品一区二区三 | 国产日本韩国 | 国产精品亲子乱 | 欧美在线精品αⅴ | 国产热の有码 | 国内美女精品在线 | 成人伦理动 | 日本成人羞羞网址 | 岛国精品页面 | 日韩欧美自拍区 | www精品| 日本留學| 国产乱人免费视频 | 18岁成年人网站 | 国产精品三级在 | 精品一区国产 | 福利所第一导航 | 欧美一进| 国产欧美日韩免费 | sss国产精品 | 日本高清三区 |