国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

基于three.js編寫的一個項目類示例代碼

2024-05-06 15:22:54
字體:
供稿:網(wǎng)友

WebVR

在開始之前,先對WebVR進行介紹,WebVR是一個實驗性的Javascript API,允許HMD(head-mounted displays)連接到web apps,同時能夠接受這些設備的位置和動作信息。這讓使用Javascript開發(fā)VR應用成為可能(當然已經(jīng)有很多接口API讓Javascript作為開發(fā)語言了,不過這并不影響我們?yōu)閃ebVR感到興奮)。而讓我們能夠立馬進行預覽與體驗,移動設備上的chrome已經(jīng)支持了WebVR并使手機作為一個簡易的HMD。手機可以把屏幕分成左右眼視覺并應用手機中的加速度計、陀螺儀等感應器,你需要做的或許就只是買一個cardboard。下面話不多說了,來一起看看本文的正文:

這是一篇關(guān)于怎么樣基于three.js進行可配置的three.js的對象創(chuàng)建的文章

項目地址

編寫一個three.js的基類

這是創(chuàng)建的一個Three.js基類其中包含了場景,相機,渲染器,控制器以及一些方法

 // VRcore.js import * as THREE from 'three'; const OrbitControls = require('three-orbit-controls')(THREE) let Scene, Camera, Renderer, Controls, loopID; function createScene({domContainer = document.body, fov = 50,far = 1000}){ if (!(domContainer instanceof HTMLElement)) {  throw new Error('domContainer is not a HTMLElement!'); } // 初始化 scene Scene = new THREE.Scene(); // 初始化 camera Camera = new THREE.PerspectiveCamera(fov, domContainer.clientWidth / domContainer.clientHeight, 1, far); Camera.position.set( 200, 200, 200 ); Camera.lookAt(Scene.position); Scene.add(Camera); // 初始化 renderer Renderer = new THREE.WebGLRenderer({ canvas: domContainer, antialias: true, alpha: true } ); Renderer.clear(); Renderer.setClearColor( 0xeeeeee, 1); // 更改渲染器顏色 Renderer.setSize(domContainer.clientWidth, domContainer.clientHeight); Renderer.shadowMap.Enabled = true; Renderer.setPixelRatio(domContainer.devicePixelRatio); initVR(); } function initVR() {  // 初始化控制器  Controls = new OrbitControls(Camera, Renderer.domElement);;  Controls.addEventListener('change', render);  Controls.enableZoom = true; } function render() { Renderer.render(Scene, Camera); } function renderStart(callback) { loopID = 0; // 記錄循環(huán)幾次,后面有與清除場景中的物體 if (loopID === -1) return; let animate = function(){  loopID = requestAnimationFrame(animate);  callback();  Controls.update();  render(); } animate(); } // 暫停動畫渲染 function renderStop() { if (loopID !== -1) {  window.cancelAnimationFrame(loopID);  loopID = -1; } } // 回收當前場景 function clearScene() { for(let i = Scene.children.length - 1; i >= 0; i-- ) {  Scene.remove(Scene.children[i]); } } // 清理頁面 function cleanPage() { renderStop(); clearScene(); } export { Scene, Camera, Renderer, Controls, createScene, initVR, renderStart, renderStop, clearScene, cleanPage }

創(chuàng)建一個VRpage基類

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 武穴市| 会同县| 大丰市| 平安县| 涟源市| 仙居县| 洛川县| 红河县| 阿拉善右旗| 澎湖县| 富宁县| 务川| 双辽市| 庄河市| 平顶山市| 洞口县| 滕州市| 抚松县| 浏阳市| 巴林右旗| 元氏县| 扎囊县| 富宁县| 泰兴市| 津南区| 华容县| 开平市| 札达县| 长沙县| 新河县| 姚安县| 阜康市| 屯留县| 武强县| 宁陕县| 兰考县| 芒康县| 乌海市| 乾安县| 望谟县| 增城市|