国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 系統 > Android > 正文

OpenGL Shader實例分析(1)Wave效果

2019-10-21 21:25:02
字體:
來源:轉載
供稿:網友

這篇文章主要分析一個Shader,從而感受shader的魅力,并學習相關shader的函數的用法。

先看Shader運行的效果:

OpenGL,Shader,Wave

下面是代碼:

Shader "shadertoy/Waves" { //see https://www.shadertoy.com/view/4dsGzH  CGINCLUDE   #include "UnityCG.cginc"        #pragma target 3.0  struct vertOut {   float4 pos:SV_POSITION;   float4 srcPos;  };  vertOut vert(appdata_base v) {  vertOut o;  o.pos = mul (UNITY_MATRIX_MVP, v.vertex);  o.srcPos = ComputeScreenPos(o.pos);  return o; }  fixed4 frag(vertOut i) : COLOR0 {   fixed3 COLOR1 = fixed3(0.0,0.0,0.3);  fixed3 COLOR2 = fixed3(0.5,0.0,0.0);  float BLOCK_WIDTH = 0.03;   float2 uv = (i.srcPos.xy/i.srcPos.w);   // To create the BG pattern  fixed3 final_color = fixed3(1.0);  fixed3 bg_color = fixed3(0.0);  fixed3 wave_color = fixed3(0.0);   float c1 = fmod(uv.x, 2.0* BLOCK_WIDTH);  c1 = step(BLOCK_WIDTH, c1);  float c2 = fmod(uv.y, 2.0* BLOCK_WIDTH);  c2 = step(BLOCK_WIDTH, c2);  bg_color = lerp(uv.x * COLOR1, uv.y * COLOR2, c1*c2);   // TO create the waves   float wave_width = 0.01;  uv = -1.0 + 2.0*uv;  uv.y += 0.1;  for(float i=0.0; i<10.0; i++) {  uv.y += (0.07 * sin(uv.x + i/7.0 + _Time.y));  wave_width = abs(1.0 / (150.0 * uv.y));  wave_color += fixed3(wave_width * 1.9, wave_width, wave_width * 1.5);  }  final_color = bg_color + wave_color;   return fixed4(final_color, 1.0); }  ENDCG   SubShader {  Pass {   CGPROGRAM    #pragma vertex vert   #pragma fragment frag   #pragma fragmentoption ARB_precision_hint_fastest     ENDCG  }   }   FallBack Off }

下面進行分析:

1. ComputeScreenPos的解析:

用于把三維的坐標轉化為屏幕上的點。有兩種方式,請參考 官方例子

ComputeScreenPos在UnityCG.cginc文件中定義如下:

// Projected screen position helpers#define V2F_SCREEN_TYPE float4inline float4 ComputeScreenPos (float4 pos) { float4 o = pos * 0.5f; #if defined(UNITY_HALF_TEXEL_OFFSET) o.xy = float2(o.x, o.y*_ProjectionParams.x) + o.w * _ScreenParams.zw; #else o.xy = float2(o.x, o.y*_ProjectionParams.x) + o.w; #endif  #if defined(SHADER_API_FLASH) o.xy *= unity_NPOTScale.xy; #endif  o.zw = pos.zw; return o;}

原理解析(待續)

2. 背景的繪制

2.1) fmod用于求余數,比如fmod(1.5, 1.0) 返回0.5;

2.2) step用于大小的比較,step(a,x) :  0 if x<a; 1 if x>=a; 比如: step(1, 1.2), 返回1; step(1, 0.8) 返回0;

2.3) 結合fmod和step可以得到一個虛線的效果。 比如要得到虛線段長度為1的代碼如下:

c1 = fmod(x, 2*width); c1=step(width,c1); //其中width為1

那么如果x的范圍是[0,1),c1的值為0;范圍為[1,2),c1的值為1;2為一個周期;

那么fmod起到了制作周期的作用,step計算周期內的0和1;

2.4)把2.3中的知識運用到2維,就可以計算出方塊。

lerp函數的用法:lerp( a , b ,f ), f為百分數(取值范圍[0,1]);如果f為0,則lerp返回a,f為1,則返回b。f為0到1之間,就返回a到b之間的值。

代碼中的 lerp(uv.x * COLOR1, uv.y * COLOR2, c1*c2); 其中c1和c2的取值不是為1,就是為0,所以就可以變成網格的情況。 背景繪制如下:

OpenGL,Shader,Wave

3. 波紋的繪制

3.1 ) 坐標的轉化

uv = -1.0 + 2.0*uv;  // 把原始的uv進行擴展和位移,得到新的uv。我們的操作就是在新的uv上進行的,最終顯示時會映射到原來到uv,請參考下圖

OpenGL,Shader,Wave

3.2 )  畫一條直線:

由于上面把y軸移動到屏幕的中心,所以屏幕的上半部分為正的,下半部分為負的,代碼如下:

wave_width = abs(1.0 / (50.0 * uv.y));wave_color = fixed3(wave_width * 1.9, wave_width, wave_width * 1.5);

其中50.0是用來控制線的寬度的(數值越大,線越細),效果如下:

OpenGL,Shader,Wave

3.3)把直線變為曲線,并使其動起來:

uv.y += (0.07 * sin(uv.x*10 + _Time.y));wave_width = abs(1.0 / (50.0 * uv.y));wave_color = fixed3(wave_width * 1.9, wave_width, wave_width * 1.5);

效果如下:

OpenGL,Shader,Wave

3.4)多畫幾條曲線,形成波浪:

for(float i=0.0; i<10.0; i++) { uv.y += (0.07 * sin(uv.x + i/7.0 + _Time.y)); wave_width = abs(1.0 / (150.0 * uv.y)); wave_color += fixed3(wave_width * 1.9, wave_width, wave_width * 1.5);}

最終效果請見文章開頭。

其實寫shader,很多時候都是要通過不斷地效果疊加并調試來達到效果。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
亚洲欧美精品日韩欧美| 91在线视频免费看| 国产成a人亚洲精v品| 福利视频在线导航| 亚洲欧美自拍另类| 日本调教视频在线观看| 波多野结衣久久高清免费| 青青草在线视频免费观看| 九色精品视频在线观看| 中文字幕国产视频| 18成年在线观看| www.操.com| 国产人成网在线播放va免费| 在线视频观看亚洲| 国产免费人人看| 最近中文av字幕在线中文| 99在线播放| 丁香花在线电影| 中文岛国精品亚洲一区| 久久久久久国产视频| 国产激情视频一区二区三区| h视频在线网站| 国产成人无吗| 国产在线视频自拍| av免费在线一区二区三区| 国产精品自产拍在线网站| 亚洲伊人网在线观看| 尤物视频免费在线观看| 亚洲夜夜综合| 国产黄色一级电影| 天天av天天爽| 好男人免费精品视频| 亚洲国产日韩在线人成电影| 国产精品bbw一区二区三区| 欧美亚洲系列| 精品999视频| 国产高清大尺度一区二区不卡| 激情五月色综合亚洲小说| 精品福利影院| 国产成免费视频| 国产导航在线| 国产精品99999| 中文字幕免费在线视频| 中文字幕视频在线| 懂色av一区| 国产精品午夜久久久久久| 人成在线免费视频| 日本片在线看| 午夜影院在线免费观看| 在线免费看黄网站| 亚洲精品少妇久久久久久| 亚洲精品影视在线| 天堂网中文在线| 欧美日韩一区二区三区在线播放| 日本动漫理论片在线观看网站| yjizz视频网站在线播放| 国产在线观看网站| 国产一区精品| 国产精品毛片一区二区三区四区| 国产精品四虎| av在线中文| а√资源新版在线天堂| 美女网站在线观看| 中文字幕国产视频| 伊人狠狠av| 免费精品国产自产拍观看| 狠狠操视频网| 国产福利资源| gogogogo高清视频在线| 久久精品国产亚洲777| 中文字幕在线永久在线视频| 精品无人区乱码1区2区3区免费| av一级在线| 国产一卡2卡3卡四卡网站| 伊人中文字幕在线| 久久久久久77777| 国产亚洲精品自在线观看| 四虎久久影院| 国产欧美一区二区三区小说| 四虎国产精品永久地址998| 交视频在线观看国产| 精品推荐蜜桃传媒| 国产美女在线免费观看| 色欧美在线观看| 国产深夜视频在线观看| 任你操视频在线观看| 国产福利小视频在线观看| 黄色网页网址在线免费| 天堂√中文在线| 伊人久久青青草| 精品无人乱码| 国产麻豆精品高清在线播放 | 亚洲精品在线播放视频| 国产黄色一级片| 国产麻豆精品高清在线播放 | а√资源新版在线天堂| 精品推荐蜜桃传媒| 国产极品视频| 国产区av在线| 国产黄在线观看免费观看不卡| 丁香在线视频| 麻豆精品永久免费视频| h网站免费在线观看| 国产一二在线观看| √天堂资源地址在线官网| 超碰国产在线| 国产美女极品在线| 国产丝袜精品丝袜| 国产精品入口麻豆免费观看| 五月综合激情在线| 国产精品被窝福利一区| 国产porny蝌蚪视频| 精品国产高清自在线一区二区三区| 国产精品视频流白浆免费视频| 国产人成在线观看| 99精品老司机免费视频| 日本视频三区| 国产麻豆高清视频在线第一页| 激情视频国产| 国产私拍精品| 99久久99久久免费精品小说| 日韩欧美中文字幕不卡| 国产永久免费高清在线观看| 国产日韩欧美第一页| 午夜在线网站| 国产美女在线看| 在线中文资源天堂| 免费特级黄毛片| 国产精品777一区二区| 四虎精品成人a在线观看| 国产九色视频| 亚洲视频手机在线观看| 成 人免费视频播放| 国产精品天堂| 夜夜操天天干| 九九热视频精品在线观看| 国产精品免费视频一区一| 精品一区二区在线欧美| 欧美日韩国产亚洲沙发| 国产视频97| 久草一本av| 亚洲人在线播放| 国产一二三区在线| 超碰国产在线| 18被视频免费观看视频| 国产美女高潮| www.av在线视频| 99色在线观看| 中文字幕成人乱码在线电影| 欧美色第一页| 午夜在线不卡| 精品入口蜜桃| 国产精品久久久精品a级小说| 欧美性猛交xxxx免费看蜜桃| 在线中文字幕资源| 国产对白在线| 国产高清视频免费最新在线| 国产精品臀控福利在线观看| 国产在线观看91| 天天操夜夜做| 四虎影院成人| 99久热re在线精彩视频| 国产精品18久久久久网站| 人人干在线视频| 四虎影视成人永久免费观看视频| 中文乱码字幕av网站| 91资源在线观看| 国产精品第八页| 国产www网站| 夜色资源网av在先锋网站观看| 91视频久色| 999精品网| 天天草天天爽| 狠狠干天天干| 国产亚洲精品拍拍拍拍拍| 国产精品剧情一区二区在线观看 | 18激情网站| 国产wwww| 亚洲第一区视频| 久久五月精品| 国产一卡2卡3卡4卡网站免费 | 综合蜜桃精品| 国产精品免费视频一区一| 国产福利在线观看| 亚洲一本大道| 最近最好的中文字幕2019免费 | 国产一级片在线播放| 国产高清免费视频| 四虎精品视频| 自拍亚洲国产| 亚洲成人福利| 国产在线高潮| 国产粉嫩一区二区三区在线观看| 一本大道久久精品| 九九在线观看免费视频| 69av二区| 另类专区欧美| 国产特级嫩嫩嫩bbb| 男女午夜视频在线观看| 国产黄色免费网|