嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片

WebVR大潮來襲 ---前端開發(fā)能做些什么?

2018-5-28    高勁

        去年谷歌和火狐針對(duì)WebVR提出了WebVR API的標(biāo)準(zhǔn),顧名思義,WebVR即web + VR的體驗(yàn)方式,我們可以戴著頭顯享受沉浸式的網(wǎng)頁,新的API標(biāo)準(zhǔn)讓我們可以使用js語言來開發(fā)。今天,約克先森將介紹如何開發(fā)一個(gè)WebVR網(wǎng)頁,在此之前,我們有必要了解WebVR的體驗(yàn)方式。

WebVR體驗(yàn)?zāi)J?/strong>

WebVR的體驗(yàn)方式可以分為VR模式和裸眼模式

一、VR模式

?滑配式HMD + 移動(dòng)端瀏覽器

        如使用cardboard眼鏡來體驗(yàn)手機(jī)瀏覽器的webVR網(wǎng)頁,瀏覽器將根據(jù)水平陀螺儀的參數(shù)來獲取用戶的頭部傾斜和轉(zhuǎn)動(dòng)的朝向,并告知頁面需要渲染哪一個(gè)朝向的場景。

?分離式HMD + PC端瀏覽器

        通過佩戴Oculus Rift的分離式頭顯瀏覽連接在PC主機(jī)端的網(wǎng)頁,現(xiàn)支持WebVR API的瀏覽器主要是火狐的 Firefox Nightly和設(shè)置VR enabled的谷歌chrome beta。

二、裸眼模式

        除了VR模式下的體驗(yàn)方式,這里還考慮了裸眼下的體驗(yàn)瀏覽網(wǎng)頁的方式,在PC端如果探測的用戶選擇進(jìn)入VR模式,應(yīng)讓用戶可以使用鼠標(biāo)拖拽場景,而在智能手機(jī)上則應(yīng)讓用戶可以使用touchmove或旋轉(zhuǎn)傾斜手機(jī)的方式來改變場景視角。

        WebVR的概念大概就如此,這次我們將采用cardboard + mobile的方式來測試我們的WebVR場景,現(xiàn)在踏上我們的開發(fā)之旅。

準(zhǔn)備工作

        技術(shù)和框架:three.js for WebGL

         Three.js是構(gòu)建3d場景的框架,它封裝了WebGL函數(shù),簡化了創(chuàng)建場景的代碼成本,利用three.js我們可以更優(yōu)雅地創(chuàng)建出三維場景和三維動(dòng)畫。

        測試工具:智能手機(jī) + 滑配式頭顯

        推薦使用cardboard或者某寶上三十塊錢的高仿貨。當(dāng)然,如果你練就了裸眼就能將手機(jī)雙屏畫面看成單屏的能力也可以忽略。

       需要引入的js插件:

  • three.min.js
  • webvr-polyfill.js
  • VRcontrols.js
  • VReffect.js
  • webvr-manager.js

webvr-polyfill.js

        由于WebVR API還沒被各大主流瀏覽器支持,因此需要引入webvr-polyfill.js來支持WebVR網(wǎng)頁,它提供了大量VR相關(guān)的API,比如Navigator.getVRDevices()獲取VR頭顯信息的方法。

VRControls.js

        VR控制器,是three.js的一個(gè)相機(jī)控制器對(duì)象,引入VRcontrols.js可以根據(jù)用戶在空間的朝向渲染場景,它通過調(diào)用WebVR API的orientation值控制camera的rotation屬性。

VREffect.js

        VR分屏器,這是three.js的一個(gè)場景分屏的渲染器,提供戴上VR頭顯的顯示方式,VREffect.js重新創(chuàng)建了左右兩個(gè)相機(jī),對(duì)場景做二次渲染,產(chǎn)生雙屏效果。

webvr-manager.js

         這是WebVR的方案適配插件,它提供PC端和移動(dòng)端的兩種適配方式,通過new WebVRManager()可以生成一個(gè)VR圖標(biāo),提供VR模式和裸眼模式的不同體驗(yàn),當(dāng)用戶在移動(dòng)端點(diǎn)擊按鈕進(jìn)入VR模式時(shí),WebVRManager便會(huì)調(diào)用VREffect分屏器進(jìn)行分屏,而退出VR模式時(shí),WebVRManager便用回renderer渲染器進(jìn)行單屏渲染。

        具體使用方法我們將在下文說明。

        3D場景構(gòu)建

        首先我們創(chuàng)建一個(gè)HTML文件

       <!DOCTYPE html>

       <html lang="en">

       <head> 

              <meta charset="UTF-8">

                  <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0, shrink-to-fit=no">

              <title>webVR-helloworld</title>

                   <style type="text/css">

                         * { 

                           margin: 0;

                           padding: 0;

                            }

                     html,body {

                                 height: 100%;

                                overflow: hidden;

                     }

               </style>

         </head>

         <body>

         </body>

        <script src="./vendor/three.min.js"></script>

          <script src="./vendor/webvr-polyfill.js"></script>

          <script src="./vendor/VRControls.js"></script>

       <script src="./vendor/VREffect.js"></script>

       <script src="./vendor/webvr-manager.js"></script>

       <script src="./main.js"></script>

       </html>

         接下來編寫js腳本,開始創(chuàng)建我們的3d場景。

1、創(chuàng)建場景

        Three.js中的scene場景是繪制我們3d對(duì)象的整個(gè)容

       1.var scene = new THREE.Scene();

2、添加相機(jī)

Three.js的相機(jī)

Three.js中的camera相機(jī)代表用戶的眼睛,我們通過設(shè)置FOV確定視野范圍,

  • //定義一個(gè)60°的視角,視線范圍在1到1000的透視相機(jī)
  • var camera = new THREE. new THREE.PerspectiveCamera(60,window.innerWidth/window.innerHeight,1,1000);
  • scene.add(camera);

3、添加渲染器

  • Three.js的渲染器用來渲染camera所看到的畫面


  • //初始化渲染器 antialias參數(shù)為ture表示開啟抗鋸齒策略
  • var renderer = new THREE.WebGLRenderer({ antialias: true } );
  • //設(shè)置渲染器渲染尺寸
  • renderer.setSize(window.innerWidth,window.innerHeight);
  • //設(shè)置渲染背景為白色
  • renderer.setClearColor(0xeeeeee);
  • //將渲染場景的canvas放入body標(biāo)簽里
  • document.body.appendChild(renderer.domElement);

  • 添加一個(gè)立方體網(wǎng)格

  • // 創(chuàng)建立方體
  • var geometry = new THREE.CubeGeometry( 10,10,10);
  • var cubematerial = new THREE.MeshLambertMaterial( { color: 0xef6500,needsUpdate: true,opacity:1,transparent:true} );
  • var cube = new THREE.Mesh( geometry, Cubematerial );
  • cube.position.set(0,100,-50);
  • cube.rotation.set(Math.PI/6,Math.PI/4,0);
  • scene.add(cube);

4、啟動(dòng)動(dòng)畫

  • 產(chǎn)生動(dòng)畫的原理就是讓camera持續(xù)連拍,同時(shí)每一次改變物體的屬性,通過requestAnimationFrame()方法遞歸的方式來持續(xù)更新場景對(duì)象屬性,你可以將它理解為setTimeout的優(yōu)化版。相比setTimeout函數(shù),requestAnimationFrame可以保證動(dòng)畫渲染不會(huì)因?yàn)橹骶€程的阻塞而造成跳幀。


  • function animate() {
  •     //讓立方體旋轉(zhuǎn)
  •     cube.rotation.y += 0.01;
  •     //渲染器渲染場景,等同于給相機(jī)按下快門
  •     renderer.render(scene, camera);
  •     //遞歸運(yùn)行該函數(shù)
  •     requestAnimationFrame( animate );
  • }
  • animate();//啟動(dòng)動(dòng)畫

      至此,我們已經(jīng)繪制了一個(gè)簡單的3d場景并且讓它動(dòng)了起來,接下來,我們需要讓我們的場景可以支持WebVR模式。

WebVR場景開發(fā)

       WebVR網(wǎng)頁的基本原理其實(shí)是通過瀏覽器的WebVR API獲取用戶輸入,進(jìn)而控制相機(jī)的視角,在VR模式下通過VR控制器和VR分屏器以二分屏+gyroscope(使用水平陀螺儀)的方式顯示畫面,裸眼情況下提供全屏+touchmove/gyroscope。

       現(xiàn)在我們開始分別創(chuàng)建上文所說的VR控制器和VR分屏器

  • //初始化VR控制器需要傳入場景相機(jī)
  • var vrControls = new THREE.VRControls(camera);
  • //初始化VR渲染器需要傳入場景渲染器
  • var vrEffect = new THREE.VREffect(renderer);
  • //初始化VR適配器,傳入渲染器和分屏器
  • var vrManager = new WebVRManager(renderer, vrEffect);

      然后在前面創(chuàng)建的場景渲染函數(shù)里調(diào)用

  • function animate() {
  •     cube.rotation.y += 0.01;
  •     //實(shí)時(shí)更新相機(jī)的位置和轉(zhuǎn)角
  •     vrControls.update();
  •     vrManager.render(scene, camera);
  •     //遞歸運(yùn)行該函數(shù)
  •     requestAnimationFrame( animate );
  • }

       至此,我們已經(jīng)完成了一個(gè)基本的webVR網(wǎng)頁,不過少了點(diǎn)交互效果好像,敬請(qǐng)期待Web開發(fā)的新世界---WebVR之交互事件。

  • 完整代碼:在文章基礎(chǔ)上添加了天空和地面相關(guān)代碼,以及下篇文章將講到VR凝視交互事件。
  • demo演示地址 :手機(jī)瀏覽需設(shè)置允許橫屏。

結(jié)語

        目前,國外的谷歌、火狐、Facebook和國內(nèi)百度已推出支持WebVR瀏覽器的版本,微軟也宣布將推出自己的VR瀏覽器,隨著后期5g網(wǎng)絡(luò)極速時(shí)代的到來以及HMD頭顯的價(jià)格和平臺(tái)的成熟,WebVR的體驗(yàn)方式將是革命性的,用戶通過WebVR瀏覽網(wǎng)上商店,線上教學(xué)可進(jìn)行“面對(duì)面”師生交流等,基于這種種應(yīng)用場景,我們可以找到一個(gè)更好的動(dòng)力去學(xué)習(xí)WebVR。






日歷

鏈接

個(gè)人資料

存檔

嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片
<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 久久久久久久性| 欧美日韩国产综合视频在线观看 | 久久手机免费观看| 久久成人精品无人区| 欧美一区综合| 久久亚洲精品网站| 欧美激情国产日韩精品一区18| 亚洲电影在线| 欧美99久久| 亚洲人永久免费| 亚洲视频国产视频| 欧美一区在线看| 欧美成人精品1314www| 欧美色一级片| 韩国三级在线一区| 亚洲精品久久久蜜桃| 亚洲图片欧洲图片日韩av| 亚洲免费中文| 欧美高清你懂得| 亚洲在线视频| 麻豆亚洲精品| 国产精品久久久久aaaa樱花| 国内精品免费在线观看| 亚洲看片网站| 久久久久亚洲综合| 在线亚洲伦理| 米奇777超碰欧美日韩亚洲| 99国产精品99久久久久久| 亚洲精品护士| 国产九色精品成人porny| 影音先锋亚洲视频| 一区二区三区高清在线观看| 久久人人看视频| 一区二区三区.www| 免费不卡中文字幕视频| 国产欧美日韩一区二区三区在线观看| 亚洲国产精品久久久久秋霞蜜臀| 性久久久久久| 亚洲麻豆一区| 免费视频一区| 一区视频在线看| 欧美在线视频一区二区| 99re8这里有精品热视频免费| 久久综合五月| 国产一区日韩欧美| 久久av免费一区| 亚洲自拍偷拍色片视频| 欧美色精品天天在线观看视频| 亚洲美女精品一区| 亚洲电影在线观看| 六月天综合网| 91久久久久久久久久久久久| 久久久777| 欧美在线国产| 国产视频一区欧美| 久久精品国产第一区二区三区最新章节| 99在线精品视频在线观看| 欧美精品久久天天躁| 99pao成人国产永久免费视频| 亚洲夫妻自拍| 欧美精品一区二| 亚洲美女啪啪| 一本色道婷婷久久欧美| 国产精品毛片在线看| 午夜精品美女久久久久av福利| 一区二区三区成人| 国产精品视频一| 久久国产欧美精品| 久久久噜噜噜久久| 亚洲成色www久久网站| 亚洲第一成人在线| 欧美精品久久久久久久久老牛影院| 99精品久久久| 亚洲一区二区三区精品在线观看| 国产精品一区二区三区乱码| 久久久国产精品一区二区三区| 亚洲欧美在线一区| 黄色成人91| 亚洲日本成人在线观看| 国产精品日韩专区| 老司机免费视频久久| 美女国产一区| 一区二区三区高清视频在线观看| 夜夜嗨av一区二区三区网站四季av| 国产精品久久久| 久久久亚洲国产美女国产盗摄| 久热精品视频在线观看一区| 亚洲午夜性刺激影院| 亚洲一二三级电影| 欧美日韩一级片在线观看| 亚洲欧美日韩国产中文| 久久久精品日韩| 亚洲视频视频在线| 一区二区三区高清在线观看| 亚洲免费网站| 亚洲国产高清aⅴ视频| 99pao成人国产永久免费视频| 国产欧美三级| 最新国产の精品合集bt伙计| 久久综合精品国产一区二区三区| 免费成人黄色av| 午夜免费久久久久| 猫咪成人在线观看| 久久国产精品久久国产精品| 欧美激情视频给我| 久久久久久久97| 欧美午夜无遮挡| 欧美激情在线免费观看| 国产欧美大片| 日韩视频一区二区在线观看| 在线不卡中文字幕播放| 亚洲免费视频在线观看| 制服丝袜亚洲播放| 麻豆成人小视频| 久久久一本精品99久久精品66| 欧美日韩一区二区高清| 欧美黄在线观看| 精品91久久久久| 亚洲一区二区黄| 亚洲午夜高清视频| 欧美精品国产精品日韩精品| 欧美va天堂va视频va在线| 国产欧美精品一区二区三区介绍| 日韩视频在线观看一区二区| 亚洲欧洲一区二区三区在线观看 | 亚洲天堂免费观看| 99视频日韩| 欧美黄色成人网| 亚洲电影激情视频网站| 午夜在线电影亚洲一区| 亚洲天堂成人在线观看| 欧美精品激情在线观看| 亚洲电影在线播放| 亚洲国产一区二区在线| 欧美午夜不卡在线观看免费 | 亚洲美女黄网| 99视频精品| 欧美日韩国产色综合一二三四| 欧美成人精品在线视频| 亚洲另类视频| 亚洲午夜国产成人av电影男同| 欧美日韩亚洲不卡| 亚洲精品黄色| 亚洲私人影院在线观看| 欧美视频在线视频| 久久福利精品| 亚洲图片欧洲图片日韩av| 欧美高清成人| 日韩视频二区| 一本色道久久综合狠狠躁篇怎么玩 | 国产九九精品视频| 亚洲永久精品大片| 午夜精彩视频在线观看不卡| 欧美视频官网| 亚洲午夜精品久久久久久浪潮| 欧美专区在线观看一区| 国产综合久久| 欧美激情在线观看| 一区二区三区毛片| 午夜精品视频在线观看| 国产一区二区三区四区在线观看| 久久久国产91| 亚洲大胆av| 亚洲欧美一区二区三区久久| 国产精品视频一二| 久久免费高清视频| 亚洲美女免费精品视频在线观看| 午夜视频在线观看一区| 经典三级久久| 欧美激情91| 性欧美大战久久久久久久久| 欧美第十八页| 午夜精品视频在线观看| 狠狠综合久久| 欧美屁股在线| 欧美在线视频二区| 亚洲国产精品久久久久| 亚洲伦理精品| 欧美性开放视频| 免费国产一区二区| 亚洲欧美在线一区| 亚洲巨乳在线| 欧美高清视频一二三区| 亚洲欧美99| 亚洲精品小视频| 国产精品一区二区女厕厕| 欧美激情欧美激情在线五月| 亚洲女性喷水在线观看一区| 亚洲国产小视频| 蜜桃av综合| 久久国产婷婷国产香蕉| 一区二区三区四区在线| 在线观看欧美日韩| 国产三级精品在线不卡| 欧美午夜片欧美片在线观看| 欧美激情影院| 欧美激情亚洲| 欧美激情网站在线观看| 你懂的视频欧美| 米奇777超碰欧美日韩亚洲|