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

基于Three.js+WebGL開發移動3D游戲

譯文
移動開發 Android
在本文中,我們將使用WebGL技術來開發一款移動游戲,本游戲能夠以60FPS的幀頻運行于移動設備上,此游戲的風格類似于Flappy Bird和神廟大逃亡(Temple Run),起名叫Winter Rush。本文著重討論和游戲開發過程中所使用的WebGL相關的three.js技術。

一、 引言

在本文中,我們將使用WebGL技術來開發一款移動游戲,本游戲能夠以60FPS的幀頻運行于移動設備上,此游戲的風格類似于Flappy Bird和神廟大逃亡(Temple Run),起名叫Winter Rush。本文著重討論和游戲開發過程中所使用的WebGL相關的three.js技術。

下圖展示了此游戲開始時的一個快照。

 

游戲過程中,玩家可以使用左向與右向箭頭鍵(或者屏幕上左右點按)來左右移動。

二、 為什么60 FPS很重要

幀速率越高,游戲內容渲染效果將是越光滑。對于一款游戲產品來說,運動效果的光滑度和控制的及時響應是尤為重要的。電腦屏幕通常刷新的頻率是60hz,所以這是我們的***的約束。請注意,60幀/秒只是最理想的目標,但實際上任何超過30 FPS的幀速率都有看上去還不錯的效果。

Paul Lewis對這一方面展開了深入探討。為此,他開設了一個專門的網站進行有關技術的探討,網站地址是http://jankfree.org/。

我可以非常自豪地告訴你,本文提供的示例工程能夠以60FPS的幀速率工作于/iPad 4th Gent和Nexus 4手機上。

 

為了實現我想要的FPS目標,我采用了如下方案。

三、 簡化3D場景

幾何體:通過減少網格數目和每個網格的頂點數來簡化場景中的幾何體。切記:“低聚合”永遠是很酷的!在這個游戲中,實現樹效果中實際上僅使用了兩個圓柱體︰一個用于實現樹葉,另一個用于實現樹干。在游戲中,當在賽道上運動時,實際上僅在賽道上放置了10棵樹。

材質:3D引擎計算成本的很大一部分是花費在計算場景中每個幾何面的照明效果上。在場景中燈光越少,則計算成本越低。Three.js引擎中材質運算代價按照從低到高的順序依次分為:

(1)Basic材質:這是***的材質,不需要計算照明,你可以使用Basic材質和圖像紋理做很多的事情。

(2)Lambert材質:使用這種材質能夠呈現并非那么富有光澤性的外觀效果。

(3)Phong材質:使用這種材質能夠實現極富光澤性的外觀效果。在我的測試中,Phong材質被證明比Lambert材質昂貴得多。例如,在本文提供的實例中,如果從Lambert材質切換到Phong材質,在iOS平臺上FPS值會從60降到15。

四、 對象重用

這可能是為實現高性能web體驗應遵循的最重要的規則了。在初始化階段對象創建后,在游戲運行期間盡量不要創建新對象。這將避免內存“顛簸”——其可能會導致瀏覽器“窒息”。網站http://www.html5rocks.com/en/tutorials/speed/static-mem-pools/
處提供了一篇使用JS對象池方面的極好的文章,你可以參考一下。在本文游戲中,我重用3D對象(例如樹)的方法是:當它們位于攝影機后面時重置它們的位置。在每一幀中,都會檢查對象是否位于攝像機之后。如果對象位于攝像機之后,則把其位置重置于遠離賽道的地方。另外需要說明的是,在本游戲中,我使用了THREE.Fog技術實現遮擋樹目的。當然另一方面,因為這也是一種相當流行的解決方案。

五、 移動賽道

游戲中賽道的雪地板是一個平面網格。我們使用Perlin噪聲算法生成地形高度(例如頂點的Y-坐標)。這種辦法能夠實現隨機但平滑變化的坑洼效果。為了實現自然運動的賽道外觀效果,我們使用了以下技術︰

(1)在每幀中,我們向照相機移動整個地板一小段距離,至于移動速度則基于玩家的操作速度。

(2)程序中,我們會檢查是否地板已經移動到攝影機后面并超過一個預定義的STRIP_WIDTH量。如果是這樣,我們會沿賽道向后重置地板STRIP_WIDTH大小的位置。然后,我們重新計算地形高度——這是通過把Perlin噪聲位置增加到STRIP_WIDTH值大小實現的。

在游戲中,大致效果如下面的截圖所示。

 

 

六、 簡化碰撞檢測

在Three.js編程中,你完全可以通過使用Raycasters方法實現非常精確的針對于每一個面的碰撞檢測。有關這一方法,Lee Stemkoski就提供了一個不錯的例子(http://stemkoski.github.io/Three.js/Collision-Detection.html)。然而,這種方法可能代價昂貴,需要針對每一對有可能發生碰撞的對象進行測算。在許多情況下,你完全可以簡化碰撞檢測;辦法是,假設每個對象都是一個球體,那么,只需要簡單地測量這些對象之間的距離即可。

請注意,您可能需要手動調整碰撞距離和碰撞盒位置,從而實現更可玩性的感覺。但是,也有一個問題,就是當掃射的時候玩家可能擊中了關閉相機的對象。針對這一問題的解決辦法是,把玩家射擊盒從鏡頭前移出一點距離。

七、 實現陰影效果

在Three.js編程中,EffectComposer類允許你依次執行多個后處理著色器(post-processing shader)。這種方法需要使用多個脫屏緩沖(off-screen buffer),從而把上一個著色器結果傳遞到下一個。在手機設備上,這種方法給出并不理想的性能表現。解決方法是:把我們編寫的多個著色器合并成一個超級著色器(SuperShader)。當然,實現這一點僅需要把每一個著色器代碼復制并粘貼即可,但還要考慮適當的順序。對于我們的Winter Rust游戲來說,我們把Vignette,Brightness/Contrast和Hue/Saturation著色器結合為一個大的著色器。此外,需注意,有些效果對于移動設備來說GPU消耗太大,最引人注目的是模糊相關技術。

八、 時間控制

在動畫循環方面,我們應使用requestAnimationFrame方法并為動畫應用時間偏移量。這樣可以使動畫速度獨立于游戲幀速率。旅行距離應取決于已經過去實際的時間而不是幀數量。這種技術不會提高你的游戲的FPS值,但如果FPS值實在太低時會提高你的游戲玩家的速度知覺。請參考如下有關代碼:

  1. //kick off animation 
  2.  
  3. var clock = new THREE.Clock(); 
  4.  
  5. clock.start(); 
  6.  
  7. gameLoop(); 
  8.  
  9. function gameLoop(){ 
  10.  
  11.     requestAnimationFrame(gameLoop ); 
  12.  
  13.     var delta = clock.getDelta(); 
  14.  
  15.     //use delta to determine all distances travelled 
  16.  
  17.     movePlayer(MOVE_SPEED * delta); 
  18.  

九、 運行于目標設備

一旦你確定了目標設備,那么你會不斷地在這些設備上進行測試并不斷關注FPS值。OS X中的IOS模擬器是一個在桌面開發時調試iOS問題的優秀工具;但要注意,模擬器并不反映實際設備的性能。Adobe的Edge Inspect(https://creative.adobe.com/products/inspect)是另一個優秀的工具,它使你能夠輕松地將多個移動設備連接到本地網頁。當頁面更改時它將自動重新加載該頁面,并且還允許您訪問Android控制臺錯誤。

十、 移動開發的JS庫

本小節給出開發我的游戲時使用的幾個著名的js庫,它們是:

  • Three.js:這個不用多說;
  • Zepto.js:這是一個jQuery的***替代品,共25K大小,而且在移動設備上速度很快;
  • Howler.js:這是一個優秀的聲效庫,它能夠應付多種移動設備的聲音問題;
  • TweenLite:使用該庫可以很容易地實現緩動效果,在移動設備上效率不錯。

十一、 哪些設備可以運行WebGL

支持WebGL的設備數量正在快速增長。除了在所有主流的桌面瀏覽器上運行外,現在WebGL內容運行于iOS和Android設備上沒有大的問題。

然而,不是所有的支持WebGL功能的設備都是生而平等的。WebGL是一種要求苛刻的技術,因此在一些相對較舊的設備上運行時建議主要運行一些最基本的內容。例如,iPad 2在2011年推出,它能夠運行WebGL,但能力非常有限。WebGL在近兩年制造的移動設備上通常運行很好。我主要的移動測試設備是一臺第4代iPad(2013年生產)和一臺Nexus 4(2012年生產),這就是一個相對很好的參考基準。

十二、 待改進的地方

建議有興趣的各位朋友,在學習本文提供實例項目過程中可以嘗試向此項目添加以下項︰

  • 移動設備上的傾斜控制。我選擇使用點按方式來實現在手機上的傾斜移動,因為這樣可以更匹配桌面體驗。請注意:使用傾斜加速度計可是一種完全不同的控制系統,讀者可另外嘗試一下這種方案。
  • 開發發燒友類型的桌面版。因為我想盡量使這個游戲在較慢的設備上也能運行良好,所以我不得不放棄使用一些漂亮的效果和幾何體。因此,在構建桌面版本時使用更豐富的圖形,效果應當更好。
  • 使用Android全屏API
  • 把程序中使用的HTML菜單技術浮動到WebGL場景上面,也許還可以添加一些漂亮的著色器擺動過渡效果,等等。

十三、 小結

本文簡述了使用Three.js開發一款移動設備3D游戲的要點。***,真誠希望讀者能夠開發出在移動設備上具備良好性能的WegGL游戲產品。

附:本文中實例游戲Winter Rush的下載地址是https://github.com/felixturner/winter-rush。

【51CTO.com獨家譯稿,合作站點轉載請注明來源】

責任編輯:李英杰 來源: 51CTO
相關推薦

2024-07-18 06:58:36

2023-08-04 09:56:15

2019-11-29 09:30:37

Three.js3D前端

2012-06-16 16:57:52

WebGL

2022-01-16 19:23:25

Three.js粒子動畫群星送福

2023-08-18 08:00:00

游戲開發3D模型

2021-12-28 10:52:10

鴻蒙HarmonyOS應用

2017-12-26 17:42:12

前端WebGLThree.js

2010-09-08 11:26:26

Windows PhoXNA 4.0 3D游戲開發

2021-11-23 22:50:14

.js 3D幾何體

2012-04-01 15:14:52

2023-09-01 09:30:22

Three.js3D 圖形庫

2021-11-27 10:42:01

Three.js3D可視化AudioContex

2017-05-08 11:41:37

WebGLThree.js

2012-04-03 12:53:47

諾基亞

2012-05-25 10:37:21

AdobeStage3D

2025-06-30 09:15:47

2013-11-21 19:36:56

暢游游戲引擎Genesis-3D

2023-07-13 10:48:22

web 3DThree.jsBlender

2012-12-24 08:48:25

iOSUnity3D
點贊
收藏

51CTO技術棧公眾號

亚洲成人黄色av| 欧美日韩精品综合| 欧美色图一区二区| 日韩电影不卡一区| 欧美日韩中字一区| 男人添女荫道口喷水视频| 免费毛片在线| 国产不卡视频一区二区三区| 热久久美女精品天天吊色| 狂野欧美性猛交| 国产精品白丝av嫩草影院| f2c人成在线观看免费视频| 欧美三区美女| 亚洲人午夜精品| 善良的小姨在线| 三上悠亚国产精品一区二区三区| 亚洲人成网站精品片在线观看| 久草精品电影| 亚洲第一页综合| 美女诱惑一区二区| 7m精品福利视频导航| 成人18视频免费69| 伊人久久大香线蕉综合网站| 欧美一区二区三区视频免费| 人妻丰满熟妇av无码区app| 欧洲黄色一区| 综合电影一区二区三区 | 99久久国产综合精品色伊| 国产久一一精品| av黄色在线播放| 亚洲激情精品| 欧美激情欧美激情| 手机在线免费看片| 欧美超碰在线| 亚洲欧美日韩天堂一区二区| 中文字幕精品久久久| 欧美一区一区| 欧美一区二区大片| 波多野结衣国产精品| 99re66热这里只有精品4| 欧美日韩精品中文字幕| 人人干视频在线| 午夜小视频福利在线观看| 一区在线观看免费| 亚洲欧美日韩综合一区| www.成人.com| 国产精品看片你懂得| 日韩视频专区| 91免费在线| 亚洲欧洲99久久| 亚洲一区二区欧美日韩| 国产成人精品免费视频| 黄色在线视频网址| 国产精品一区毛片| 性色av一区二区三区在线观看| 免费在线观看日韩| 国产一区日韩一区| 久久久中精品2020中文| 精品无码人妻一区二区三区| 欧美日韩成人| 久久久亚洲国产天美传媒修理工| 久久精品视频9| 亚洲精品影院在线观看| 97香蕉超级碰碰久久免费软件| 91午夜视频在线观看| 久久国产精品99国产| 国产97在线|亚洲| 中文字幕一区二区人妻| 激情深爱一区二区| 999热视频| 网站黄在线观看| 国产日韩欧美一区二区三区综合| 色噜噜一区二区| 免费av不卡| 亚洲午夜电影在线观看| 日本一本二本在线观看| 国产精品久久久久久久久免费高清 | 超碰资源在线| 色香蕉成人二区免费| 日本www.色| 欧美一级片网址| 亚洲精品久久视频| 欧美极品jizzhd欧美18| 亚洲一区 二区 三区| 久久久久久久久久久久av| 6080午夜伦理| 极品美女销魂一区二区三区 | 欧美亚洲国产成人精品| 黄色一区二区视频| 国产精品羞羞答答xxdd | 99精品小视频| 久久久亚洲网站| 在线观看中文字幕码| 成人免费观看av| 亚洲视频在线二区| 丁香花在线观看完整版电影| 在线观看亚洲一区| aaa黄色大片| 色婷婷色综合| 欧美亚洲国产日韩2020| 国产sm主人调教女m视频| 97se亚洲国产综合自在线| 正在播放亚洲| 女生影院久久| 欧美成人欧美edvon| 天天躁日日躁aaaa视频| 国产精品分类| 国产精品爽爽爽| 天天操天天干天天操| 国产精品久久久久久福利一牛影视 | 欧美调教femdomvk| 欲求不满的岳中文字幕| 91精品精品| 国产精品久久久久999| 亚洲成熟女性毛茸茸| 国产精品嫩草99a| 青青艹视频在线| 中文字幕区一区二区三| xxx欧美精品| jizz国产在线| ww久久中文字幕| 欧美男女爱爱视频| 日韩激情精品| 久久久精品一区二区| 亚洲精品久久久久久久蜜桃| av亚洲产国偷v产偷v自拍| 超碰10000| 一级欧美视频| 色诱女教师一区二区三区| av黄色在线播放| 久久综合999| 妞干网在线观看视频| 亚洲国产视频二区| 久久这里有精品| 97在线播放免费观看| 欧美国产乱子伦| www.欧美日本| 欧美在线电影| 国产精品免费久久久久久| 免费在线视频一级不卡| 色综合欧美在线视频区| 免费a级黄色片| 久久久久久9| 日本不卡久久| 欧美激情喷水| 国产一区二区三区中文 | 国产成+人+综合+亚洲欧洲| a级片在线免费看| 一区在线观看免费| 99中文字幕在线| 女生裸体视频一区二区三区| 91久久国产精品| www视频在线免费观看| 91精品久久久久久久91蜜桃| 亚洲波多野结衣| 国内精品久久久久影院薰衣草| 一区二区三区免费看| 久久国内精品| 久久综合免费视频| 国产后入清纯学生妹| 亚洲一区二区三区四区的| 免费啪视频在线观看| 日韩午夜黄色| 欧美一区二区三区四区在线观看地址 | 国产精品视频在线观看| 2021av在线| 欧美一区二区三区男人的天堂 | 精品日韩中文字幕| 成人性生交大免费看| 日日夜夜精品视频免费| 欧美国产成人精品| 日韩久久不卡| 电影在线观看一区二区| www日韩欧美| 亚洲欧美国产不卡| 宅男噜噜噜66国产精品免费| 欧美成人合集magnet| 蜜臀av在线观看| 日本道免费精品一区二区三区| 日本二区在线观看| 国产一区二区三区香蕉| heyzo亚洲| 日本一区二区三区视频| 不卡视频一区| 日韩精品99| 不卡毛片在线看| 四虎免费在线观看| 欧美日韩视频在线第一区| 在线观看美女av| 99久久免费国产| jizz18女人| 极品裸体白嫩激情啪啪国产精品| 欧美大陆一区二区| 激情视频亚洲| 国产成人久久久| 欧美高清另类hdvideosexjaⅴ| 亚洲精品美女免费| 亚洲影院一区二区三区| 亚洲高清三级视频| 91导航在线观看| av成人老司机| 午夜一区二区视频| 国产一区二区三区久久| 裸体大乳女做爰69| 欧美日韩爱爱| 国产日韩亚洲精品| 亚州精品国产| 日本久久91av| 男男gaygays亚洲| 最近中文字幕mv在线一区二区三区四区| 亚洲国产成人精品一区二区三区| 91久久精品午夜一区二区| 免看一级a毛片一片成人不卡| 久久久www成人免费毛片麻豆| 69久久精品无码一区二区| 人人超碰91尤物精品国产| 国产va亚洲va在线va| 亚洲精品久久久| 色女孩综合网| 杨幂一区二区三区免费看视频| 痴汉一区二区三区| 韩国一区二区三区视频| 91精品久久久久久综合乱菊| 日本久久免费| 欧美一级在线亚洲天堂| 国产蜜臀一区二区打屁股调教| 久久精品国产亚洲7777| 国产黄在线观看免费观看不卡| 亚洲精品黄网在线观看| 黄色av一区二区三区| 日韩一区二区免费电影| 国产精品高潮呻吟av| 欧美日韩一区二区在线观看| 69国产精品视频免费观看| 大伊人狠狠躁夜夜躁av一区| 精品视频一区二区在线观看| 亚洲免费观看高清| 国产免费一区二区三区四区| 国产精品久久久久久久久快鸭| 手机看片福利视频| 久久精品视频免费| 全黄一级裸体片| 久久久久9999亚洲精品| 中文字幕丰满孑伦无码专区| 91在线视频观看| 法国伦理少妇愉情| 久久精品水蜜桃av综合天堂| 一级黄色性视频| 欧美国产精品一区二区三区| 超碰97av在线| 成人免费一区二区三区在线观看| 91久久久久久久久久久久久久| 国产精品久久99| 麻豆精品国产免费| 亚洲日穴在线视频| 免费在线观看黄视频| 亚洲一区二区三区在线| 久久精品免费在线| 最近日韩免费视频| 欧美色播在线播放| www.日本精品| 欧美日韩国产精品一区| www.国产色| 日韩欧美在线字幕| 五月天激情国产综合婷婷婷| 一本大道久久a久久精品综合| 国产伦精品一区二区三区视频我| 亚洲国产视频一区二区| 国产一二三四区在线观看| 婷婷亚洲最大| 裸体裸乳免费看| 亚洲香蕉网站| 浮妇高潮喷白浆视频| 男人的天堂成人在线| 欧美精品aaaa| 日本福利片在线| 日韩精品视频在线观看免费| 国内精品一区视频| 日韩在线免费视频观看| 品久久久久久久久久96高清| 男人av在线播放| 久久婷婷一区| 国产精品乱子乱xxxx| 久久精品色综合| 欧美二区在线| 天天综合网网欲色| 久久精品无码中文字幕| 亚洲在线视频| 国模私拍视频在线观看| 国产电影精品久久禁18| 一区二区视频观看| 国产精品免费久久| 久久午夜无码鲁丝片| 欧美三级免费观看| 国产美女免费视频| 精品视频www| 麻豆视频在线观看免费网站| 欧美激情一级二级| 色猫猫成人app| 狠狠色狠狠色综合人人| 日韩av密桃| 国产原创中文在线观看| 极品少妇一区二区三区精品视频 | 日本高清中文字幕二区在线| 在线播放日韩欧美| 丝袜国产在线| 亚洲午夜在线视频| 欧美精品尤物在线| 日韩在线视屏| 国产婷婷一区二区三区| 麻豆国产欧美日韩综合精品二区| 99久久免费看精品国产一区| 最新国产成人在线观看| 日本一区二区三区精品| 亚洲成年网站在线观看| a视频在线观看| 国产精品永久在线| 女厕嘘嘘一区二区在线播放| 国产人妻777人伦精品hd| 国内精品第一页| 国产综合精品久久久久成人av| 亚洲mv在线观看| 国产女人18毛片18精品| 正在播放亚洲1区| 电影网一区二区| 国内一区二区三区在线视频| 欧美1级日本1级| 天天干天天玩天天操| 国产校园另类小说区| 亚洲婷婷综合网| 日韩成人性视频| 中文字幕有码在线观看| 91精品视频一区| 久久看人人摘| 国产福利在线免费| 国产精品伦理一区二区| 夜夜躁日日躁狠狠久久av| 亚洲美女又黄又爽在线观看| 川上优av中文字幕一区二区| 国产高清在线一区| 伊人久久大香线蕉av超碰演员| www.日本久久| 亚洲人吸女人奶水| 无码精品一区二区三区在线播放 | 一级欧美一级日韩| 亚洲精品国产电影| 超级碰碰不卡在线视频| av在线不卡一区| 国产精品久久观看| 8x8x成人免费视频| 91成人精品在线| 夜夜嗨av一区二区三区四季av| 校园春色 亚洲| 欧美一个色资源| 天使と恶魔の榨精在线播放| 97视频资源在线观看| 国语精品一区| 日韩aaaaa| 色综合久久天天综合网| 国产美女视频一区二区三区| 国产精品青青在线观看爽香蕉| 成人三级视频| 一级黄色片国产| 一区二区三区四区五区视频在线观看 | 欧美日韩不卡合集视频| 精品久久福利| 女同性恋一区二区| 成人小视频在线| 天天干在线播放| 中文字幕国产亚洲| 91精品国产一区二区在线观看 | 影音先锋欧美在线| 久久精品国产999大香线蕉| 日本精品在线免费观看| 欧美成人a∨高清免费观看| 91九色在线看| 欧美黑人欧美精品刺激| 99久久免费视频.com| 日韩av大片在线观看| 国产亚洲视频在线观看| 91麻豆精品一二三区在线| 欧美极品少妇无套实战| 2021久久国产精品不只是精品| 中文字幕+乱码+中文字幕明步| 欧美成人精品一区| 亚洲欧美校园春色| 亚洲成人精品久久| 浪潮色综合久久天堂| 手机看片日韩国产| 91网上在线视频| 国产精品久久久久久久成人午夜| h视频久久久| 宅男av一区二区三区| 欧美中文字幕一区二区三区| 精品国产av鲁一鲁一区| 91精品国产亚洲| 五月激情综合| 素人fc2av清纯18岁| 91精品久久久久久久99蜜桃 | 亚洲国产合集|