亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

webgl實(shí)現(xiàn)物體描邊效果的方法介紹

 更新時(shí)間:2019年11月27日 10:30:04   作者:String_Kun  
這篇文章主要給大家介紹了關(guān)于webgl實(shí)現(xiàn)物體描邊效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用webgl具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

終于把手頭的事結(jié)束了,可以有時(shí)間來研究研究技術(shù)~作為一名3D開發(fā)人員,僅僅使用現(xiàn)有的引擎來開發(fā)項(xiàng)目不免有些浮于表面,多研究研究底層的實(shí)現(xiàn)更利于對3D開發(fā)整體的把控~于是我決定最近開始研究webgl一些特效的實(shí)現(xiàn),希望能在秋招前對底層有更深入的理解。

在webgl中實(shí)現(xiàn)描邊的效果有很多種方式,比如我寫卡通風(fēng)格著色器那篇文章講到的(將視線投影到每個點(diǎn)的法線上,這個值越小越說明這個點(diǎn)靠近邊緣),所以接下來介紹實(shí)現(xiàn)的另一種方式:法線延展法。

這種方法不用進(jìn)行法線與視線之間的計(jì)算,而是將物體每個點(diǎn)的x、y、z坐標(biāo)沿著該點(diǎn)的法線擴(kuò)大一定的距離并且添加描邊的顏色,然后在繪制原來的物體覆蓋到上面,這樣便實(shí)現(xiàn)了描邊的效果。

這里將原物體覆蓋到描邊物體上面就有兩種實(shí)現(xiàn)的方式:

1.先關(guān)閉深度檢測,然后繪制描邊物體,開啟深度檢測,繪制原物體。這樣由于繪制描邊物體時(shí)深度檢測被關(guān)閉了,原物體就會覆蓋在描邊物體上繪制從而實(shí)現(xiàn)描邊效果。缺點(diǎn):當(dāng)兩個物體重合時(shí)會出現(xiàn)重合位置沒有描邊的情況,這是由于第二次繪制的東西覆蓋到了第一次描邊的物體上,所以先畫的邊自然就會被遮擋啦~

2.不關(guān)閉深度檢測,開啟背面剪裁,繪制描邊物體時(shí)將卷繞方向置為順時(shí)針方向(默認(rèn)是逆時(shí)針),在進(jìn)行繪制,繪制完成之后將卷繞方向設(shè)置回順時(shí)針方向。這樣背面剪裁的開啟使得描邊物體只能繪制出它的背面,這樣便實(shí)現(xiàn)了描邊效果,而且由于沒有關(guān)閉深度測試,該物體的描邊效果會根據(jù)其位置決定是否遮擋。

  //繪制一幀畫面的方法
  function drawFrame()
  {   
   //若還沒有加載完則不繪制
   if(!ooTri || !mbTri) {return;}
   
   //清除著色緩沖與深度緩沖
   gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); 
   
   //保護(hù)現(xiàn)場
   ms.pushMatrix();   
   //繞Y軸旋轉(zhuǎn)
   ms.rotate(currentAngle,0,1,0);
//方法1
//   gl.disable(gl.DEPTH_TEST);      //啟用深度緩沖寫入
//   mbTri.drawSelf(ms);//繪制描邊物體
//   gl.enable(gl.DEPTH_TEST);      //關(guān)閉深度緩沖寫入
//   ooTri.drawSelf(ms);//繪制原物體
//方法2
   gl.enable(gl.CULL_FACE);      //開啟剪裁
   gl.cullFace(gl.BACK);       //剪裁背面
   gl.frontFace(gl.CW);       //繪制順序?yàn)轫槙r(shí)針
   mbTri.drawSelf(ms);//繪制描邊物體
   gl.frontFace(gl.CCW);       //繪制順序?yàn)槟鏁r(shí)針
   ooTri.drawSelf(ms);//繪制原物體


   //恢復(fù)現(xiàn)場
   ms.popMatrix();
   
   //修改旋轉(zhuǎn)角度
   currentAngle += incAngle;
   if (currentAngle > 360)
   {
    currentAngle -= 360; 
   }   
  } 
  其著色器代碼如下:
uniform mat4 uMVPMatrix;       //總變換矩陣
attribute vec3 aPosition;         //頂點(diǎn)位置
attribute vec3 aNormal;         //頂點(diǎn)法向量
void main(){
 vec3 position=aPosition;      //獲取此頂點(diǎn)位置
 position.xyz+=aNormal*0.4;    //將頂點(diǎn)位置沿法線方向擠出
 gl_Position = uMVPMatrix * vec4(position.xyz,1);//根據(jù)總變換矩陣計(jì)算此次繪制此頂點(diǎn)位置
}
<#BREAK_BN#>
precision mediump float;        //設(shè)置浮點(diǎn)默認(rèn)精度

void main(){
 gl_FragColor = vec4(0.0,1.0,0.0,0.0);     //給此片元顏色值
}

其實(shí)這兩種描邊方法還是有著一些區(qū)別(第二種對于復(fù)雜物體會產(chǎn)生類似包裹的效果)具體效果還得根據(jù)具體的場景來決定。

PS:這里還要注意一點(diǎn),WebGL是個狀態(tài)機(jī)。我們可以這么理解,假設(shè)WebGL中的屬性P的值為1,你在某一次操作中,把P的值設(shè)置成了2,那么在你下一次設(shè)置P的值之前,P的值永遠(yuǎn)是2。這一點(diǎn)很重要!

Github地址:https://github.com/StringKun/WebGL-object-of-stroke


總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 微信內(nèi)置瀏覽器圖片查看器的代碼實(shí)例

    微信內(nèi)置瀏覽器圖片查看器的代碼實(shí)例

    這篇文章主要介紹了微信內(nèi)置瀏覽器圖片查看器的代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 小程序云開發(fā)實(shí)戰(zhàn)小結(jié)

    小程序云開發(fā)實(shí)戰(zhàn)小結(jié)

    這篇文章主要介紹了小程序云開發(fā)實(shí)戰(zhàn)小結(jié),本文詳細(xì)的介紹了云開發(fā)以及環(huán)境的搭建和項(xiàng)目實(shí)踐,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-10-10
  • JavaScript 關(guān)鍵字屏蔽實(shí)現(xiàn)函數(shù)

    JavaScript 關(guān)鍵字屏蔽實(shí)現(xiàn)函數(shù)

    JavaScript屏蔽關(guān)鍵字,大概的思路就是去用javascript去替換已有的文本,達(dá)到替換的目的
    2009-08-08
  • 利用JavaScript實(shí)現(xiàn)的10種排序算法總結(jié)

    利用JavaScript實(shí)現(xiàn)的10種排序算法總結(jié)

    這篇文章主要介紹了利用JavaScript實(shí)現(xiàn)的十種排序算法,主要介紹了冒泡,選擇,插入,希爾,歸并,快速,堆排,計(jì)數(shù),桶排和基數(shù),有感興趣的小伙伴可以參考閱讀本文
    2023-05-05
  • javascript引用賦值(地址傳值)用法實(shí)例

    javascript引用賦值(地址傳值)用法實(shí)例

    這篇文章主要介紹了javascript引用賦值(地址傳值)用法,以一個簡單實(shí)例分析了javacript引用賦值的原理與用法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • JavaScript 自動完成腳本整理(33個)

    JavaScript 自動完成腳本整理(33個)

    所謂的提升用戶體驗(yàn),其實(shí)就是把所有用戶視為懶鬼,比如JavaScript自動完成(Autocomplete)腳本, 常用于表單,用戶只需輸入一兩個字母,就為你擴(kuò)展、聯(lián)想、匹配和供君選擇,
    2009-10-10
  • javascript正則表達(dá)式之search()用法實(shí)例

    javascript正則表達(dá)式之search()用法實(shí)例

    這篇文章主要介紹了javascript正則表達(dá)式之search()用法,實(shí)例分析了search()的使用技巧,需要的朋友可以參考下
    2015-01-01
  • JS百度地圖搜索懸浮窗功能

    JS百度地圖搜索懸浮窗功能

    這篇文章主要為大家詳細(xì)介紹了JS百度地圖搜索懸浮窗功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • js放大鏡放大購物圖片效果

    js放大鏡放大購物圖片效果

    這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)放大鏡放大購物圖片效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Javascript String 字符串操作包

    Javascript String 字符串操作包

    提供一個 JS String 包,包含了一些常用的對字符串操作的函數(shù),詳細(xì)的請看源碼及演示
    2010-10-10

最新評論