欧美精品在线一区二区三区_亚洲女同精品视频_日韩一区免费_国产欧美久久久精品免费_国产这里只有精品_僵尸再翻生在线观看_久久99精品国产一区二区三区_亚洲免费一区二区_女教师淫辱の教室蜜臀av软件_中文字幕国产一区二区

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.ocunn.cn

存檔

亚洲精品无amm毛片| 国产精品美女999| www.成人av| 国产3p露脸普通话对白| 国产精品1000部啪视频| 久久精品偷拍视频| 在线观看二区| 国产精区一区二区| 亚洲国产美女| 国产精品免费网站在线观看| 精品国产91久久久久久久妲己| 国内精品久久久久久中文字幕| 日本高清不卡三区| 在线视频一二区| 国产无套丰满白嫩对白| 视频一区二区三区国产| 日韩一区中文| 亚洲欧美成人综合| 一区二区三区波多野结衣在线观看 | 亚洲精品一区二区三区新线路| 8x8ⅹ拨牐拨牐拨牐在线观看| 久久国产亚洲| 久久久午夜精品| 精品福利一区二区三区| 亚洲一区二区三区视频播放| 国产v亚洲v天堂无码久久久| 久久精品这里有| 97电影在线| 精品福利久久久| 99久精品国产| 欧美精品一区二区精品网| 成人在线国产精品| 精品亚洲一区二区三区四区| 免费黄色小视频在线观看| 蜜乳av一区| 亚洲黄色毛片| 性欧美大战久久久久久久久| 欧美激情视频网站| 野外做受又硬又粗又大视频√| 欧美成人精品一区二区免费看片| 可以免费看污视频的网站在线| 日韩a级大片| 91在线小视频| 亚洲图片欧美日产| 欧美精品v日韩精品v国产精品| 精品黑人一区二区三区观看时间| 人人妻人人澡人人爽人人欧美一区| 成人国产一区| 韩国精品一区二区| 日韩一区二区免费高清| 成人午夜影院在线观看| 一级黄色片毛片| 色综合视频在线| av不卡一区二区| 99综合电影在线视频| 精品一区二区三区三区| 日本一区视频在线观看| 影音先锋男人看片资源| 自拍视频在线| 欧美在线网站| 色综合久久88色综合天天免费| 国产精品电影在线观看| 网站在线你懂的| 欧美 日韩 中文字幕| 99亚洲乱人伦aⅴ精品| 久久蜜桃av一区二区天堂| 中文字幕在线看视频国产欧美| 中国成人亚色综合网站| 久久精品亚洲无码| 成年人黄色大片在线| 视频一区二区中文字幕| 欧美一区二区视频在线观看 | 国产一区二区三区香蕉| 亚洲精品黄网在线观看| 亚洲精品一区二区三区蜜桃久| 欧美日韩免费做爰视频| 丁香高清在线观看完整电影视频| 毛片一区二区| 日韩视频一区在线观看| 日本10禁啪啪无遮挡免费一区二区| 欧美乱大交做爰xxxⅹ小说| 黄黄的网站在线观看| 国产亚洲综合精品| 欧美一区二区三区在线视频| 免费国产在线精品一区二区三区| 国产精品视频一区二区在线观看| av免费在线免费观看| 久久最新视频| 亚洲第一在线视频| 四虎免费在线观看视频| 免费无码国产精品| 日韩在线观看一区二区三区| 国产欧美日韩不卡| 45www国产精品网站| 女人扒开腿免费视频app| 亚洲高清福利| 亚洲国内欧美| 欧美精品一区二区不卡| 国产精品久久国产| 国产精品久久久久久久久久久久久久久久| 6080成人| 亚洲影视在线播放| 亚洲一区二区久久久久久久| 日韩在线观看免| 午夜激情在线播放| 91免费观看视频| 久久全球大尺度高清视频| 亚洲高清av一区二区三区| 国产小视频在线| 久久久精品网| 亚洲欧美另类人妖| 亚洲熟妇av一区二区三区漫画| 丰满熟妇乱又伦| 99久久亚洲精品蜜臀| 欧美日韩成人综合| 在线一区亚洲| 国产毛片一区二区三区va在线 | 任我爽在线视频| 日韩pacopacomama| 国产欧美日韩中文久久| 国产精品精品视频| 在线免费看视频| 日本欧美一区| 亚洲欧美中日韩| 亚洲a中文字幕| 久久久久亚洲av成人片| 久久三级中文| 午夜视频在线观看一区二区三区| 精品一卡二卡三卡四卡日本乱码| av资源免费观看| 琪琪久久久久日韩精品| 黑人精品xxx一区一二区| 欧美亚洲丝袜| 91资源在线视频| 国产精品久久久久久| 欧美一区二区三区色| 国产一二三在线视频| ga∨成人网| 水野朝阳av一区二区三区| 色婷婷综合成人av| 18禁一区二区三区| 九色porny自拍视频在线观看| 久久中文娱乐网| 成人黄色在线播放| 99久在线精品99re8热| 麻豆一区二区| 欧美日韩激情在线| 国产xxxx振车| 日韩在线免费看| 狠狠色丁香久久婷婷综合_中| 欧美韩国理论所午夜片917电影| 成人免费无码大片a毛片| 欧美日韩国产v| 亚洲精品五月天| 欧美高清性xxxxhd| av天堂一区二区三区| 日韩午夜电影| 欧美成aaa人片免费看| 少妇光屁股影院| 成人午夜毛片| 欧美日韩国产一中文字不卡| 91免费网站视频| eeuss在线观看| 激情欧美一区二区| 日韩av成人在线| 国产精品第二十页| 成人区精品一区二区婷婷| 亚洲韩国日本中文字幕| 婷婷中文字幕在线观看| 888av在线视频| 亚洲欧美日韩久久| 视频在线精品一区| 污污网址在线观看| 国产精品18久久久| 成人精品一区二区三区电影免费| av片免费观看| 国语精品一区| 久久资源免费视频| 国产一区在线观看免费| 女一区二区三区| 亚洲精品一区二区三区福利| 日韩 国产 一区| 中文字幕在线直播| 大伊人狠狠躁夜夜躁av一区| 欧美亚洲日本一区二区三区| 午夜视频在线| 国产精品视频一二| 亚洲精品国产一区| 青青九九免费视频在线| 久久亚洲二区三区| 久久综合给合久久狠狠色| 亚洲三级黄色片| 大桥未久av一区二区三区中文| 99精品国产一区二区| www日本在线| 精品午夜久久福利影院| 亚洲xxx自由成熟| www.久久成人| 国产麻豆精品视频| 国产另类第一区| 亚洲人妻一区二区| 99国产精品国产精品毛片| 开心色怡人综合网站| 在线免费激情视频| 久久久综合精品| 亚洲国产欧美不卡在线观看| 黄色毛片在线观看| 亚洲欧洲国产日本综合| 日本男女交配视频| 久久香蕉av| 色婷婷国产精品久久包臀| 日本激情视频在线播放| 日本免费在线一区| 精品少妇一区二区三区| 国产美女视频免费观看下载软件| 久久综合社区| 中文字幕av一区中文字幕天堂 | 麻豆成人在线观看| 99蜜桃在线观看免费视频网站| 你懂的网站在线| 99精品1区2区| 一区二区日本伦理| av毛片在线看| 色综合久久综合网欧美综合网| 午夜久久久精品| 国产91在线播放精品| 日韩欧美高清在线| 91视频免费观看网站| 亚洲理论电影| 久久精品成人欧美大片| 国产一级特黄视频| 葵司免费一区二区三区四区五区| 91丨九色丨国产在线| 99久热re在线精彩视频| 中文成人综合网| 国产日韩欧美精品在线观看| 自拍在线观看| 日韩欧美国产综合| 成人免费视频入口| 欧美人与禽猛交乱配视频| 日韩美女免费线视频| 性中国xxx极品hd| 久久一日本道色综合| 亚洲精品天堂成人片av在线播放| 538在线精品| 日韩天堂在线观看| 亚洲图片第一页| 黑丝一区二区| 7777精品伊久久久大香线蕉语言| 在线国产三级| 亚洲一区二区三区自拍| 天堂在线中文在线| 久久精品色综合| 欧美极品少妇全裸体| 国产精品久久婷婷| 久久美女艺术照精彩视频福利播放| 美女av免费观看| 97成人超碰| 在线a欧美视频| 波多野结衣视频网址| 成人激情免费电影网址| 久久久久99精品成人片| 99久久综合国产精品二区| 亚洲人成网7777777国产| 亚洲欧美精品一区二区三区| 国产99久久久精品| 日韩精品免费一区| 99精品女人在线观看免费视频| 色哟哟网站入口亚洲精品| 精人妻无码一区二区三区| 岛国av在线一区| 亚洲熟妇国产熟妇肥婆| 中文字幕一区二区三区日韩精品| 欧美精品免费看| 亚洲国产精品欧美久久| 亚洲人亚洲人成电影网站色| 久久久久亚洲av无码麻豆| 欧美黄色大片在线观看| 亚洲综合精品伊人久久| 色网站免费在线观看| 欧美伦理视频网站| a在线视频播放观看免费观看| 麻豆传媒一区二区三区| 91传媒免费视频| 高清国产一区二区三区四区五区| 欧美国产一区二区三区| 西西人体44www大胆无码| 亚洲午夜羞羞片| 国产ts丝袜人妖系列视频| 亚洲黄色av| 亚洲国产日韩欧美| 国产成人午夜性a一级毛片| 美女少妇精品视频| 三级网站免费观看| 欧美视频一二三| 人妻互换一区二区激情偷拍| 麻豆精品视频在线| 国产 欧美 日韩 一区| 91精品日本| 国产精品久久久久久亚洲影视| а√天堂中文在线资源bt在线 | 精品成人免费视频| 91麻豆免费视频| 网站在线你懂的| 亚洲大片av| 中文字幕精品一区日韩| 麻豆视频久久| 国产精品久久久久久五月尺| 黄视频在线观看网站| 日韩精品在线免费播放| 一炮成瘾1v1高h| 亚洲无线码一区二区三区| 亚洲欧美va天堂人熟伦 | 欧美一区二区在线播放| 亚洲va在线观看| 国产精品久久久久久户外露出 | 亚洲欧洲一区| 一区二区三区国产福利| 中文字幕亚洲在线观看| 国产在线一区二区三区| 欧美人与禽性xxxxx杂性| 色噜噜狠狠色综合网图区| 四虎永久在线观看| 欧美色网一区二区| 日韩精品1区2区| 亚洲视频一区二区在线| 中文字幕人妻一区二区三区在线视频| 久久国产视频网| 久久国产色av免费观看| 中文字幕亚洲精品乱码| 色综合久久av| 国产成人在线中文字幕| 亚洲一区中文字幕| 韩国美女久久| 欧美一区第一页| 污污网站在线看| 久久这里只有精品视频首页| 岛国在线视频| 国产香蕉97碰碰久久人人| 午夜激情在线视频| 欧美一区二区三区在线观看视频| 中文字幕在线一| 欧美丝袜一区二区三区| 久久一区二区三区视频| 一个色在线综合| 亚洲国产美女视频| 欧美国产欧美亚州国产日韩mv天天看完整 | 欧美丝袜美腿| 国产综合第一页| 亚洲精品黑牛一区二区三区| 91成人免费观看| 99er精品视频| 91久久精品一区二区别| 欧洲亚洲精品久久久久| 成人免费视频a| 国产精品99| 91久久久久久久久| 日本午夜免费一区二区| 91精品视频免费观看| 国产精品99| 91中文字幕一区| 97久久中文字幕| 99国产高清| 日韩欧美另类中文字幕| 狠狠色综合网站久久久久久久| 欧洲精品99毛片免费高清观看| 99re在线| 国产精品宾馆| 日本精品一区二区三区高清 久久| 另类尿喷潮videofree| 日本欧美精品久久久| 国产一区二区电影在线观看| 亚洲精美视频| 欧美aaaaaaaaaaaa| 国产 欧美 日韩 一区| 激情国产一区| 国产一区二区在线免费播放| 日本一不卡视频| 午夜免费视频网站| 国产成人在线视频网站| 免费看污黄网站在线观看| 久久蜜臀中文字幕| 欧美激情精品久久| 亚洲国产成人av网| 伊人网中文字幕| 91麻豆精品国产| 8×8x拔擦拔擦在线视频网站| 亚洲欧洲在线视频| 日本在线播放| 欧美最猛性xxxxx亚洲精品| 高清电影一区| 国产精品亚洲一区| 国产一区二区在线| 欧美国产综合在线| 久久久人人人| 国产乱淫av片| 国产日韩欧美不卡在线| 久久网免费视频| 91传媒视频在线播放| 亚洲精品一区二区三区蜜桃|