精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

《捕魚達(dá)人3》講解Cocos引擎3D:魚身波光處理

移動開發(fā) Android 游戲開發(fā)
在上一節(jié)的學(xué)習(xí)中,我們已經(jīng)掌握了如何使用Cocos2d-x加載魚的模型和播放魚的動畫,這一節(jié)我們來學(xué)習(xí)一下如何為魚的模型增加波光處理,以使它看起來像在海水中游動。

在上一節(jié)的學(xué)習(xí)中,我們已經(jīng)掌握了如何使用Cocos2d-x加載魚的模型和播放魚的動畫,這一節(jié)我們來學(xué)習(xí)一下如何為魚的模型增加波光處理,以使它看起來像在海水中游動。

在模型的身上加入波光的感覺,是通過紋理動畫來實(shí)現(xiàn)的,其原理是給模型增加一個(gè)紋理,并循環(huán)的移動紋理貼圖尋址的UV坐標(biāo),這樣貼在模型表面的紋理就會按照不斷變化的UV值來產(chǎn)生出貼圖運(yùn)動的效果。下面我們來實(shí)際做一下這個(gè)效果。

我們需要用到Shader文件UVAnimation.vsh和UVAnimation.fsh,它們在Resources\3D目錄中。 UVAnimation.vsh是一個(gè)模型骨骼動畫的計(jì)算Shader,而UV動畫的效果在UVAnimation.fsh中進(jìn)行處理:

  1. uniform sampler2D u_texture1;  
  2. uniform sampler2D u_lightTexture;     
  3. uniform vec4 v_LightColor;     //顏色色彩  
  4. uniform vec2 v_animLight;     //UV動畫紋理偏移  
  5. varying vec2 v_texCoord;      //模型的紋理UV值  
  6.    
  7. void main(void)   
  8. {  
  9.     //通過UV值的移動形成UV動畫  
  10.      vec4 lightcolor = texture2D(u_lightTexture, v_texCoord + v_animLight.xy) * v_LightColor;  
  11.     gl_FragColor = texture2D(u_texture1, v_texCoord) + lightcolor;  
  12. }  

然后我們需要一張波光圖caustics.png,它是黑白圖,用于在模型上增加色值操作,這樣的話,黑色的區(qū)域色值為0,與魚原來的紋理色值相加不變,而白色區(qū)域的值大于0,與魚原來的紋理色值相加后會有增亮效果。這張圖我們放在工程的Resources\3D目錄中。

我們在FishLayer中增加一個(gè)變化的UV值:

  1. Vec2 _lightani;

在FishLayer::init函數(shù)中,我們將上面所寫的vsh,fsh等組合成魚模型可以使用的Shader并使用它:

  1. // 取得文件管理器  
  2. auto fileUtiles = FileUtils::getInstance();  
  3.    
  4. // 加載相應(yīng)的Shader文件  
  5. // 加載UVAnimation.vsh并取得文件內(nèi)容字符串  
  6. auto vertexFilePath = fileUtiles->fullPathForFilename("UVAnimation.vsh");  
  7. auto vertSource = fileUtiles->getStringFromFile(vertexFilePath);  
  8.    
  9. // 加載UVAnimation.fsh并取得文件內(nèi)容字符串  
  10. auto fragmentFilePath = fileUtiles->fullPathForFilename("UVAnimation.fsh");  
  11. auto fragSource = fileUtiles->getStringFromFile(fragmentFilePath);  
  12.    
  13. // 將vsh與fsh裝配成一個(gè)完整的Shader文件。  
  14. auto glprogram = GLProgram::createWithByteArrays(vertSource.c_str(), fragSource.c_str());  
  15. // 由Shader文件創(chuàng)建這個(gè)Shader  
  16. auto glprogramstate = GLProgramState::getOrCreateWithGLProgram(glprogram);  
  17. // 給精靈設(shè)置所用的Shader  
  18. _sprite->setGLProgramState(glprogramstate);  
  19.    
  20. //創(chuàng)建海龜所用的貼圖。  
  21. auto textrue1 = Director::getInstance()->getTextureCache()->addImage("tortoise.png");  
  22. //將貼圖設(shè)置給Shader中的變量值u_texture1  
  23. glprogramstate->setUniformTexture("u_texture1", textrue1);  
  24.    
  25. //創(chuàng)建波光貼圖。  
  26. auto textrue2 = Director::getInstance()->getTextureCache()->addImage("caustics.png");  
  27.    
  28. //將貼圖設(shè)置給Shader中的變量值u_lightTexture  
  29. glprogramstate->setUniformTexture("u_lightTexture", textrue2);  
  30.    
  31. //注意,對于波光貼圖,我們希望它在進(jìn)行UV動畫時(shí)能產(chǎn)生四方連續(xù)效果,必須設(shè)置它的紋理UV尋址方式為GL_REPEAT。  
  32. Texture2D::TexParams tRepeatParams;  
  33. tRepeatParams.magFilter = GL_LINEAR_MIPMAP_LINEAR;  
  34. tRepeatParams.minFilter = GL_LINEAR;  
  35. tRepeatParams.wrapS = GL_REPEAT;  
  36. tRepeatParams.wrapT = GL_REPEAT;  
  37. textrue2->setTexParameters(tRepeatParams);  
  38.    
  39. //在這里,我們設(shè)置一個(gè)波光的顏色,這里設(shè)置為白色。  
  40. Vec4  tLightColor(1.0,1.0,1.0,1.0);  
  41. glprogramstate->setUniformVec4("v_LightColor",tLightColor);  
  42.    
  43. //下面這一段,是為了將我們自定義的Shader與我們的模型頂點(diǎn)組織方式進(jìn)行匹配。模型的頂點(diǎn)數(shù)據(jù)一般包括位置,法線,色彩,紋理,以及骨骼綁定信息。而Shader需要將內(nèi)部相應(yīng)的頂點(diǎn)屬性通道與模型相應(yīng)的頂點(diǎn)屬性數(shù)據(jù)進(jìn)行綁定才能正確顯示出頂點(diǎn)。  
  44. long offset = 0;  
  45. auto attributeCount = _sprite->getMesh()->getMeshVertexAttribCount();  
  46. for (auto k = 0; k < attributeCount; k++) {  
  47.     auto meshattribute = _sprite->getMesh()->getMeshVertexAttribute(k);  
  48.     glprogramstate->setVertexAttribPointer(s_attributeNames[meshattribute.vertexAttrib],  
  49.         meshattribute.size,  
  50.         meshattribute.type,  
  51.         GL_FALSE,  
  52.         _sprite->getMesh()->getVertexSizeInBytes(),  
  53.                                              (GLvoid*)offset);  
  54.         offset += meshattribute.attribSizeBytes;  
  55.     }  
  56.    
  57. //uv滾動初始值設(shè)為0  
  58. _lightani.x = _lightani.y = 0;  

之后我們重載一下FishLayer的draw函數(shù),加入U(xiǎn)V值的變化處理和設(shè)置。

  1. void FishLayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags)  
  2. {  
  3.     if(_sprite)  
  4.     {  
  5.            
  6.         auto glprogramstate = _sprite->getGLProgramState();  
  7.         if(glprogramstate)  
  8.         {  
  9.             _lightani.x += 0.01;  
  10.             if(_lightani.x > 1.0)  
  11.             {  
  12.                 _lightani.x-= 1.0;  
  13.             }  
  14.             _lightani.y += 0.01;  
  15.             if(_lightani.y > 1.0)  
  16.             {  
  17.                 _lightani.y-= 1.0;  
  18.             }  
  19.             glprogramstate->setUniformVec2("v_animLight",_lightani);  
  20.         }  
  21.     }  
  22.     Node::draw(renderer,transform,flags);  
  23. }  

這樣,我們就完成了魚身上的波光處理。

責(zé)任編輯:chenqingxiang 來源: cocoachina
相關(guān)推薦

2015-04-20 18:12:49

Cocos實(shí)戰(zhàn)《捕魚達(dá)人3》

2014-08-14 10:06:14

Cocos2d-x

2014-07-28 17:09:54

Cocos

2015-04-27 15:35:42

Cocos3D場景編輯器

2015-01-19 17:44:02

Cocos引擎3D特效

2013-11-21 19:36:56

暢游游戲引擎Genesis-3D

2024-12-10 09:40:00

AI3D模型

2022-10-19 13:43:42

CocosOpenHarmon3D游戲引擎

2017-07-12 23:08:03

白鷺引擎

2014-11-21 12:37:49

暢思廣告《捕魚達(dá)人3》

2011-10-06 13:30:45

宏碁投影儀

2012-11-26 12:51:44

木材3D打

2012-12-24 08:48:25

iOSUnity3D

2022-09-14 09:23:51

Java3D引擎

2011-05-26 10:05:07

優(yōu)派投影機(jī)

2015-04-03 11:40:08

Cocos 2015

2011-04-26 14:21:20

3DJVC投影機(jī)

2011-08-26 14:50:23

2023-03-03 21:42:18

鴻蒙

2012-08-13 17:11:37

Silverlight
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

国产在线一级片| 男男一级淫片免费播放| 欧美性videos| 国产电影一区二区三区| 性色av一区二区咪爱| 加勒比一区二区| www.成人| 色综合久久中文字幕综合网| 亚洲精品国产精品久久| 性欧美一区二区三区| 午夜宅男久久久| 伦伦影院午夜日韩欧美限制| 97人妻天天摸天天爽天天| 国产精品美女午夜爽爽| 亚洲国产精品精华液网站| 日韩性感在线| 色一情一乱一区二区三区| 青青草国产精品亚洲专区无| 久久久久国色av免费观看性色| 91资源在线播放| 久久婷婷国产| 国产精品一区二区三区四区 | 国产网红主播福利一区二区| 久久久精品亚洲| 538国产视频| 免费看成人午夜电影| 中文字幕亚洲综合久久| 免费网站永久免费观看| 天天干视频在线| 国产成人一区二区三区别| 久久免费看少妇高潮v片特黄| 六月丁香久久丫| 91.com在线观看| 国产亚洲欧美日韩一区二区| 777久久久精品一区二区三区| 91精品国产综合久久久久久豆腐| av资源网一区| 国产99在线播放| 一级淫片免费看| 久久只有精品| 欧美最近摘花xxxx摘花| 五月天婷婷丁香| 欧美日本免费| 大胆欧美人体视频| 国产精品成人69xxx免费视频| 亚洲传媒在线| 日韩精品免费在线观看| 日本性生活一级片| 国产一区二区三区亚洲| 欧美r级在线观看| 能看毛片的网站| 精品一区二区三区四区五区| 欧美军同video69gay| 国产九九在线视频| 日本美女久久| 欧美日韩一区二区在线观看视频| 熟女人妇 成熟妇女系列视频| 亚洲午夜天堂| 日韩欧美精品免费在线| 日本精品免费在线观看| 亚洲一区站长工具| 日本韩国欧美一区| 日本a√在线观看| 精品肉辣文txt下载| 在线免费亚洲电影| 男女视频在线看| 成人免费在线观看视频| 欧美日韩国产中文| 爱情岛论坛亚洲自拍| 亚洲不卡视频| 国产视频精品xxxx| 欧美三级视频网站| 亚洲综合五月| 久久久久久久一区二区| 欧美不卡视频在线观看| 亚洲欧美视频| 91精品久久久久久久久| 国产高潮流白浆喷水视频| 成人免费av在线| 欧美日韩三区四区| 午夜小视频在线| 亚洲美女屁股眼交3| 亚洲人成无码网站久久99热国产| 中文字幕乱码在线播放| 欧美日本国产视频| 亚洲视频天天射| 色综合综合色| 久久精品99久久香蕉国产色戒| 少妇aaaaa| 制服诱惑一区二区| 国产精品日韩一区| 亚洲AV无码乱码国产精品牛牛| 99久久夜色精品国产网站| 亚洲国产另类久久久精品极度| 乱人伦中文视频在线| 亚洲高清免费视频| 午夜免费高清视频| 大桥未久女教师av一区二区| 亚洲香蕉在线观看| 欧美丰满艳妇bbwbbw| 日韩精品免费专区| 欧美亚洲网站| 性开放的欧美大片| 亚洲一区二区三区四区电影 | av片免费观看| 国产一区二区三区免费在线观看| 国产精品区二区三区日本| 欧美日韩综合在线观看| 男人天堂视频在线观看| 欧美性xxxx| 婷婷激情综合五月天| 小说区图片区色综合区| 美女性感视频久久久| 一级片视频在线观看| 国产精品白丝jk黑袜喷水| 欧美大香线蕉线伊人久久| 爆操欧美美女| 欧洲国产伦久久久久久久| 69亚洲乱人伦| 一区二区免费不卡在线| 国产精品日韩在线| 男人的天堂在线| 亚洲地区一二三色| 黄色一级片免费播放| 欧洲视频一区| 欧美自拍视频在线观看| 日本美女一级视频| 亚洲综合在线免费观看| 看看黄色一级片| 狠狠色狠狠色综合婷婷tag| 97精品国产91久久久久久| 精品久久国产视频| 亚洲人精品一区| www.欧美日本| 久草在线成人| 欧美在线视频在线播放完整版免费观看| 国产美女自慰在线观看| 国产精品免费视频观看| 日本中文字幕高清| 欧美伦理在线视频| 欧美影院在线播放| 无码h黄肉3d动漫在线观看| 亚洲韩国精品一区| 丰满熟女人妻一区二区三区| 欧美黄色大片网站| 成人免费看片网址| 欧美日韩色网| 欧美成人午夜电影| 懂色av.com| 成人深夜在线观看| 无码专区aaaaaa免费视频| 国产日韩三级| 欧美在线观看视频| 欧美高清电影在线| 日本韩国一区二区三区视频| 娇妻被老王脔到高潮失禁视频| 青青草伊人久久| 亚洲一区三区电影在线观看| 香蕉成人在线| 美日韩精品免费视频| 国产精品无码专区av免费播放| 国产精品成人在线观看| 中文av字幕在线观看| 一区二区三区四区日韩| 99国内精品久久久久久久软件| 羞羞污视频在线观看| 精品福利一二区| 在线能看的av| 国产亚洲欧美一区在线观看| 欧美一级特黄a| 国产精品麻豆久久| 亚洲综合中文字幕在线| 日本色护士高潮视频在线观看| 亚洲成av人片在线观看香蕉| 国产微拍精品一区| 亚洲国产精品精华液2区45| 天天做天天干天天操| 亚洲网址在线| 日本免费高清一区二区| 中文字幕乱码在线人视频| 日本天堂在线| 欧洲一区二区三区免费视频| 欧美xxxx精品| 国产福利不卡视频| 成人免费观看视频在线观看| 精品久久久中文字幕| 91麻豆国产精品| √8天堂资源地址中文在线| 亚洲深夜福利网站| 国产丝袜视频在线观看| 欧美日韩午夜激情| 亚洲女人毛茸茸高潮| 国产**成人网毛片九色 | 少妇大叫太粗太大爽一区二区| 日本欧美在线观看| 成人免费a级片| 国产99久久精品一区二区300| 成人激情视频网| 在线观看涩涩| 久久色在线播放| 免费人成黄页在线观看忧物| 欧美一级高清片| 日韩黄色一级视频| 亚洲一区二区三区自拍| 1024在线看片| 91在线视频播放地址| 992kp免费看片| 久久婷婷av| 黄色一级片在线看| 99久久婷婷国产综合精品电影√| 久久综合中文色婷婷| 久久69av| 国产欧美精品久久久| 蜜桃av在线播放| 久久综合伊人77777蜜臀| 国产中文字幕在线| 亚洲国产精品va| 99久久国产热无码精品免费| 日本高清不卡视频| 99视频在线看| 亚洲综合色自拍一区| 免费成人深夜蜜桃视频| 久久久亚洲国产美女国产盗摄| 精品国产一二区| 国内精品久久久久影院薰衣草| 久久久久久久久久久免费视频| 欧美性久久久| 久久国产精品免费观看| 欧美大人香蕉在线| 色噜噜狠狠一区二区三区| 农村少妇一区二区三区四区五区| av观看久久| 久久一级大片| 91在线观看免费高清| 国产精品亲子伦av一区二区三区| 欧美最猛性xxxxx(亚洲精品)| 欧美sm一区| 久久免费视频在线| 久久亚洲资源| 久久久久久91香蕉国产| 麻豆蜜桃在线| 97在线看福利| 岛国在线视频网站| 欧美亚洲第一页| 成人短视频app| 日本高清久久天堂| 美女福利一区二区| 人九九综合九九宗合| 欧美xxxxxx| 国产精品v片在线观看不卡| 户外露出一区二区三区| 国产激情久久久久| 国产综合色区在线观看| 国产精品免费一区二区三区都可以 | 国产图片一区| 精品国产乱码久久久久久久软件 | 永久免费精品视频网站| 日韩系列欧美系列| 婷婷视频在线播放| 欧美日韩一区二区国产| 久草热视频在线观看| 亚欧成人精品| 国内国产精品天干天干| 国产伦精品一区二区三区免费迷| 最好看的中文字幕| www.亚洲免费av| 成人精品999| 国产精品理论片在线观看| 黄色a级片在线观看| 亚洲第一福利视频在线| 久久精品视频1| 欧美日韩国产首页在线观看| 国产女无套免费视频| 精品国产成人系列| 久久国产精品高清一区二区三区| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 欧美成年人视频| av在线不卡免费| 国产成人精品久久久| 91精品国产一区二区在线观看| 肥熟一91porny丨九色丨| 亚州综合一区| 一区二区三区四区在线视频| 欧美激情1区| 日韩手机在线观看视频| 国产一区二区导航在线播放| 97人妻天天摸天天爽天天| 国产精品美女久久久久高潮| 精品深夜av无码一区二区老年| 色狠狠色狠狠综合| a天堂中文在线观看| 亚洲视频在线看| 91精选在线| 国产精品久久久久久久久| 欧美影院视频| 日韩国产精品一区二区| 欧美视频二区| 超碰成人在线播放| 91蝌蚪porny| 青草影院在线观看| 色猫猫国产区一区二在线视频| 精品国产伦一区二区三| 亚洲人成网站999久久久综合| 深夜国产在线播放| 国产精品视频免费在线| 亚欧洲精品视频在线观看| 色婷婷777777仙踪林| 日韩精品三区四区| 日本japanese极品少妇| 亚洲欧美日韩国产中文在线| 国产成人无码专区| 日韩激情第一页| 污污片在线免费视频| 国产精品一区二区三区在线播放| 女仆av观看一区| 日本熟妇人妻xxxx| 国产在线一区二区| 久久久久99精品成人| 色综合久久久网| 欧美自拍偷拍第一页| 久热精品视频在线观看一区| 色综合天天色| 日产国产精品精品a∨| 在线亚洲国产精品网站| aaaaa黄色片| 亚洲激情六月丁香| 国产精品无码专区av免费播放| 这里只有精品视频| 经典三级一区二区| 美女一区视频| 一本色道久久| 中文字幕 日本| 亚洲大片一区二区三区| www.爱爱.com| 欧美成人精品三级在线观看| 91丨精品丨国产| 中文字幕人成一区| 久久99精品久久久久久动态图 | 精品人妻一区二区乱码| 中文字幕一区二区三区四区 | 久久99精品久久只有精品| 美国黑人一级大黄| 欧美三级一区二区| 天堂资源在线中文| 91精品国产综合久久香蕉最新版 | www日本高清| 九九九久久久久久| 91麻豆精品激情在线观看最新| 中文精品无码中文字幕无码专区 | 在线免费观看日本一区| 成人性生交大片免费看午夜| 国产精品露脸自拍| 99re6这里只有精品| 超碰在线免费av| 一区二区三区不卡在线观看| 国产91免费在线观看| 国产69精品久久久久99| 人人精品亚洲| 久草综合在线观看| 国产精品欧美久久久久无广告 | 精品一区二区国语对白| 欧美成人777| 亚洲成人久久久久| 深夜成人福利| 亚洲午夜精品福利| 国产不卡视频在线观看| 久久高清免费视频| 在线播放国产一区二区三区| 国产精品天堂蜜av在线播放| 免费日韩在线观看| 99精品欧美一区二区三区小说 | 日本在线高清| 日韩精品av一区二区三区| 精品一区二区三区久久| 精品无码av在线| 亚洲天堂av电影| 超碰国产精品一区二页| 婷婷无套内射影院| 国产欧美中文在线| 亚洲a视频在线| 国产成人精品久久二区二区| 亚洲一区欧美| 久久久久久久久久久国产精品| 欧美三级三级三级| 丁香花高清在线观看完整版| 欧美在线一二三区| 国产一区二区免费在线| 超碰超碰超碰超碰| 美日韩精品免费视频| 综合综合综合综合综合网| 日本精品一区在线| 日本韩国欧美三级| 懂色av一区| 亚洲狠狠婷婷综合久久久| 国产成人av一区二区三区在线观看| 中文字幕一区二区三区四区欧美| 九九视频直播综合网| 国产一区二区三区网| 五月天丁香社区| 51精品国自产在线|