内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

webgl實(shí)現(xiàn)物體描邊效果的方法介紹-創(chuàng)新互聯(lián)

前言

成都創(chuàng)新互聯(lián)公司主營(yíng)吉安網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,app軟件開(kāi)發(fā),吉安h5小程序開(kāi)發(fā)搭建,吉安網(wǎng)站營(yíng)銷(xiāo)推廣歡迎吉安等地區(qū)企業(yè)咨詢(xún)

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

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

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

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

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

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

  //繪制一幀畫(huà)面的方法
  function drawFrame()
  {   
   //若還沒(méi)有加載完則不繪制
   if(!ooTri || !mbTri) {return;}
   
   //清除著色緩沖與深度緩沖
   gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); 
   
   //保護(hù)現(xiàn)場(chǎng)
   ms.pushMatrix();   
   //繞Y軸旋轉(zhuǎn)
   ms.rotate(currentAngle,0,1,0);
//方法1
//   gl.disable(gl.DEPTH_TEST);      //啟用深度緩沖寫(xiě)入
//   mbTri.drawSelf(ms);//繪制描邊物體
//   gl.enable(gl.DEPTH_TEST);      //關(guān)閉深度緩沖寫(xiě)入
//   ooTri.drawSelf(ms);//繪制原物體
//方法2
   gl.enable(gl.CULL_FACE);      //開(kāi)啟剪裁
   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)場(chǎng)
   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);     //給此片元顏色值
}

分享題目:webgl實(shí)現(xiàn)物體描邊效果的方法介紹-創(chuàng)新互聯(lián)
本文來(lái)源:http://www.rwnh.cn/article6/hdiog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃動(dòng)態(tài)網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)電子商務(wù)、App設(shè)計(jì)網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
明水县| 栖霞市| 若尔盖县| 偃师市| 获嘉县| 固阳县| 剑河县| 金沙县| 周口市| 诏安县| 昌吉市| 和龙市| 西丰县| 嘉禾县| 抚宁县| 安宁市| 胶州市| 阿坝县| 庆云县| 嘉禾县| 吉林省| 玉门市| 浪卡子县| 阿勒泰市| 无棣县| 浦城县| 凯里市| 特克斯县| 靖西县| 天津市| 浪卡子县| 敖汉旗| 长治市| 奉贤区| 莆田市| 盐城市| 周口市| 永嘉县| 通山县| 铜川市| 阳泉市|