九九精品影院-九九精品在线-九九精品在线播放-九九九国产-国产成+人+综合+亚洲不卡-国产成a人片在线观看视频

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

2018-5-28    周周

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

WebVR體驗模式

WebVR的體驗方式可以分為VR模式和裸眼模式

一、VR模式

?滑配式HMD + 移動端瀏覽器

        如使用cardboard眼鏡來體驗手機瀏覽器的webVR網頁,瀏覽器將根據水平陀螺儀的參數來獲取用戶的頭部傾斜和轉動的朝向,并告知頁面需要渲染哪一個朝向的場景。

?分離式HMD + PC端瀏覽器

        通過佩戴Oculus Rift的分離式頭顯瀏覽連接在PC主機端的網頁,現支持WebVR API的瀏覽器主要是火狐的 Firefox Nightly和設置VR enabled的谷歌chrome beta。

二、裸眼模式

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

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

準備工作

        技術和框架:three.js for WebGL

         Three.js是構建3d場景的框架,它封裝了WebGL函數,簡化了創建場景的代碼成本,利用three.js我們可以更優雅地創建出三維場景和三維動畫。

        測試工具:智能手機 + 滑配式頭顯

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

       需要引入的js插件:

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

webvr-polyfill.js

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

VRControls.js

        VR控制器,是three.js的一個相機控制器對象,引入VRcontrols.js可以根據用戶在空間的朝向渲染場景,它通過調用WebVR API的orientation值控制camera的rotation屬性。

VREffect.js

        VR分屏器,這是three.js的一個場景分屏的渲染器,提供戴上VR頭顯的顯示方式,VREffect.js重新創建了左右兩個相機,對場景做二次渲染,產生雙屏效果。

webvr-manager.js

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

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

        3D場景構建

        首先我們創建一個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腳本,開始創建我們的3d場景。

1、創建場景

        Three.js中的scene場景是繪制我們3d對象的整個容

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

2、添加相機

Three.js的相機

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

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

3、添加渲染器

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


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

  • 添加一個立方體網格

  • // 創建立方體
  • 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、啟動動畫

  • 產生動畫的原理就是讓camera持續連拍,同時每一次改變物體的屬性,通過requestAnimationFrame()方法遞歸的方式來持續更新場景對象屬性,你可以將它理解為setTimeout的優化版。相比setTimeout函數,requestAnimationFrame可以保證動畫渲染不會因為主線程的阻塞而造成跳幀。


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

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

WebVR場景開發

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

       現在我們開始分別創建上文所說的VR控制器和VR分屏器

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

      然后在前面創建的場景渲染函數里調用

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

       至此,我們已經完成了一個基本的webVR網頁,不過少了點交互效果好像,敬請期待Web開發的新世界---WebVR之交互事件。

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

結語

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






日歷

鏈接

個人資料

藍藍設計的小編 http://www.indbiotech.com.cn

存檔

欧美大片aaaa一级毛片| 日本免费乱人伦在线观看 | 国产欧美精品| 国产国语在线播放视频| 亚飞与亚基在线观看| 中文字幕97| 久久精品免视看国产明星 | 久草免费在线观看| 99热热久久| 可以免费在线看黄的网站| 一本高清在线| 国产一区二区精品久久| 黄色免费三级| 一级毛片视频免费| 四虎影视精品永久免费网站| 日韩avdvd| 精品国产一区二区三区精东影业| 欧美一级视频免费| 欧美激情影院| 999久久狠狠免费精品| 国产精品免费久久| 精品在线视频播放| 亚欧成人毛片一区二区三区四区| 精品视频在线观看一区二区| 日韩中文字幕一区二区不卡| 国产网站免费视频| 韩国毛片免费大片| 亚洲不卡一区二区三区在线| 午夜欧美成人久久久久久| 成人影视在线播放| 亚洲 国产精品 日韩| 午夜欧美成人香蕉剧场| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 可以在线看黄的网站| 精品国产一区二区三区久久久狼| 欧美另类videosbestsex久久| 国产麻豆精品| 九九精品在线播放| 欧美激情一区二区三区视频高清| 国产一区二区精品久久| 精品国产一区二区三区久久久蜜臀 | 免费国产在线观看不卡| 欧美爱色| 韩国毛片免费| 精品久久久久久影院免费| 色综合久久天天综线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美大片aaaa一级毛片| 国产亚洲精品成人a在线| 99久久精品国产免费| 国产视频在线免费观看| 亚洲第一色在线| 日本特黄特黄aaaaa大片| 久久精品成人一区二区三区| 欧美一级视频免费观看| 中文字幕一区二区三区精彩视频| 精品美女| 成人免费观看网欧美片| 国产福利免费观看| 人人干人人插| 国产精品12| 精品久久久久久影院免费| 欧美激情伊人| 亚洲精品影院久久久久久| 免费一级片网站| 九九久久国产精品| 欧美另类videosbestsex| 999久久狠狠免费精品| 97视频免费在线观看| 一级毛片视频播放| 免费毛片播放| 黄视频网站在线免费观看| 韩国毛片免费| 国产综合91天堂亚洲国产| 国产成人女人在线视频观看| 免费一级片在线| 国产原创中文字幕| 一级毛片视频免费| 色综合久久天天综合观看| 午夜欧美福利| 一本高清在线| 国产91精品系列在线观看| 一级女性全黄久久生活片| 国产麻豆精品hdvideoss| 色综合久久天天综合观看| 四虎影视久久久| 韩国三级视频网站| a级毛片免费观看网站| 国产亚洲精品aaa大片| 国产成人啪精品视频免费软件| 国产一区二区高清视频| 一级女性大黄生活片免费| 久久成人综合网| 精品视频一区二区三区免费| 二级片在线观看| 日本特黄特色aaa大片免费| 日本在线不卡免费视频一区| 国产不卡精品一区二区三区| 日日爽天天| 国产不卡在线观看| 欧美一区二区三区性| 精品视频在线观看免费 | 欧美激情一区二区三区在线| 国产欧美精品午夜在线播放| 国产麻豆精品免费密入口| 日韩男人天堂| 亚洲精品久久久中文字| 国产美女在线观看| 999久久66久6只有精品| 黄色短视屏| 999久久66久6只有精品| 国产麻豆精品免费密入口| 成人高清视频免费观看| 九九精品在线播放| 可以免费看毛片的网站| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产a毛片| 成人a级高清视频在线观看| 国产不卡精品一区二区三区| 欧美a级成人淫片免费看| 精品国产香蕉在线播出| 日韩中文字幕在线播放| 欧美一区二区三区在线观看| 欧美一区二区三区在线观看| 欧美激情一区二区三区中文字幕| 色综合久久天天综合绕观看| 午夜精品国产自在现线拍| 久久国产精品只做精品| 精品久久久久久中文字幕一区| 免费国产在线视频| 99久久网站| 日韩av东京社区男人的天堂| 亚洲第一页乱| 韩国三级香港三级日本三级| 成人a大片在线观看| a级精品九九九大片免费看| 999久久久免费精品国产牛牛| 国产一区精品| 欧美大片a一级毛片视频| 国产亚洲精品aaa大片| 欧美1卡一卡二卡三新区| 日本特黄一级| 精品久久久久久中文字幕一区| 四虎影视精品永久免费网站| 99色吧| 可以免费看毛片的网站| 欧美另类videosbestsex| 香蕉视频一级| 毛片高清| 夜夜操网| 91麻豆精品国产片在线观看| 日韩免费片| 国产欧美精品| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品视频免费在线| 国产极品精频在线观看| 午夜在线观看视频免费 成人| 999久久久免费精品国产牛牛| 亚洲 欧美 成人日韩| 国产欧美精品| 中文字幕97| 毛片的网站| 欧美a级片视频| 亚洲第一页乱| 一级片免费在线观看视频| 国产国语在线播放视频| 欧美激情一区二区三区视频高清| 国产网站免费视频| 毛片的网站| 国产91丝袜在线播放0| 一级毛片看真人在线视频| 亚洲www美色| 日本在线不卡视频| 国产不卡在线观看视频| 国产伦精品一区二区三区无广告| 韩国三级视频在线观看| 韩国毛片 免费| 亚洲不卡一区二区三区在线| 欧美国产日韩久久久| 青青久久国产成人免费网站| 成人a大片高清在线观看| 亚洲第一页色| 日韩免费在线| 国产a毛片| 日本在线不卡视频| 99热视热频这里只有精品| 99色视频| 精品久久久久久中文字幕2017| 中文字幕97| 91麻豆精品国产自产在线| 99色视频在线| 午夜欧美福利| 欧美激情一区二区三区在线播放| 精品国产一区二区三区久| 成人免费观看视频| 午夜精品国产自在现线拍| 久久成人综合网| 91麻豆精品国产自产在线观看一区 | 国产国产人免费视频成69堂| 午夜激情视频在线观看|