接下來我們一起來看一下在webgl中的通用函式,這些函式非常的有特點
第一個通用函式:float abs(float x)
此函式會返回x的無符號絕對值,即如果x大於0則返回x,否則返回-x。
data:image/s3,"s3://crabby-images/43d58/43d58694c34f60da7e93b8a89af4df8e12c95b22" alt="webgl內建函式--通用函式"
第二個通用函式:float sign(float x)
此函式又稱為符號函式,如果x>0返回1.0,如果x=0返回0.0,否則返回-1.0
data:image/s3,"s3://crabby-images/f6cea/f6cea2a672a68d372e646ceab569b95277b3e594" alt="webgl內建函式--通用函式"
第三個通用函式:float floor(float x)
此函式會返回小於等於x並且最接近x的整數,通俗來說就是像下取整。
data:image/s3,"s3://crabby-images/adce3/adce3b0b45bc78b2298a5d299135f132ffc24518" alt="webgl內建函式--通用函式"
第四個通用函式:float ceil(float x)
此函式會返回大於等於x並且最接近x的整數,通俗來說就是向上取整。
data:image/s3,"s3://crabby-images/d8ad0/d8ad05dae5f3d68b64b78497aa06eba65e2656e8" alt="webgl內建函式--通用函式"
第五個通用函式:float fract(float x)
此函式會返回x的小數部分,即x-floor(x)。
data:image/s3,"s3://crabby-images/2ca9e/2ca9e36337029045e36ca61836c8a0d37bdcb193" alt="webgl內建函式--通用函式"
第六個通用函式:float mod(float x, float y)
此函式會返回x除以y的餘數。
data:image/s3,"s3://crabby-images/e9149/e914999c52779e4df027cce667b7a6608739f13e" alt="webgl內建函式--通用函式"
第七個通用函式:float min(float x, float y)
此函式會返回x和y兩個值中的最小值。
第八個通用函式:float max(float x, float y)
此函式會返回x和y兩個值中的最大值。
第九個通用函式:float clamp(float x, float minVal, float maxVal)
此函式會將x限制在minVal和maxVal之間。
data:image/s3,"s3://crabby-images/dfa99/dfa99e1559bd9de1a5e96e0cca8c7589b2622885" alt="webgl內建函式--通用函式"
上面的影象中我將minVal的值調節為0.0,將maxVal的值調節為1.0,那麼x的值比0.0小的時候,就會返回0.0,在0.0到1.0之間就會返回x值本身,而大於1.0的時候就會返回1.0。
第十個通用函式:float mix(float x, float y, float a)
此函式會返回x和y的線性混合,即x*(1-a)+y*a
下面我們看一下y = mix(0.,1.,x);這個函式的影象。
data:image/s3,"s3://crabby-images/3306c/3306cea5836fc0d9864507b4f75f475b42ed2eac" alt="webgl內建函式--通用函式"
第十一個通用函式:float step(float edge, float)
此函式會根據兩個數值生成階梯函式,如果x<edge則返回0.0,否則返回1.0
data:image/s3,"s3://crabby-images/30b62/30b6203f0b7b01e98929af43ea727ee58c6bb643" alt="webgl內建函式--通用函式"
第十二個通用函式:float smoothstep(float edge0, float edge1, float x)
如果x<=edge0則返回0.0,如果x>=edge1則返回1.0,否則
t=clamp((x-edge0)/(edge1-edge0), 0, 1)
return t*t(3-2*t)
data:image/s3,"s3://crabby-images/2ae75/2ae75f96398128a4df5357624cf1d78c6a03f511" alt="webgl內建函式--通用函式"
以上就是webgl內建函式中的通用函式,變化多種多樣,實際的使用價值還在等著你不斷的發掘。