77百科网
当前位置: 首页 生活百科

threejs文档示例(threejs3d可视化楼宇源码)

时间:2023-06-02 作者: 小编 阅读量: 1 栏目名: 生活百科

一般说来,对于制图、建模软件通常使用正交投影,这样不会因为投影而改变物体比例;而对于其他大多数应用,通常使用透视投影,因为这更接近人眼的观察效果,以下详细介绍透视投影。far照相机到视景体最远的距离,为正值。Three.js有一系列支持外部导入文件的函数,是在three.js库之外的,使用前需要单独下载。

WebGL

简介:WebGL(全写Web Graphics Library)是一种3D绘图协议,这种绘图技术标准允许把JavaScript和OpenGL ES 2.0(OpenGL for Embedded Systems,OpenGL嵌入式版本,针对手机、游戏机等设备相对较轻量级的版本)结合在一起,通过增加OpenGL ES 2.0的一个JavaScript绑定,WebGL可以为HTML5 Canvas提供硬件3D加速渲染,这样Web开发人员就可以借助系统显卡来在浏览器里更流畅地展示3D场景和模型了,还能创建复杂的导航和数据视觉化。

Three.js

简介:Three.js是WebGL的JavaScript 3D库,其对WebGL提供的接口进行了非常好的封装,简化了很多细节,大大降低了学习成本,成为前端开发者完成3D绘图的得力工具。

three.js官方文档 :threejs.org/

three.js中文文档 :http://techbrood.com/threejs/docs/

Three.js整体认知(附:Three.js功能概览)

一、threejs三大组件(场景-scene,相机-camera,渲染器-renderer)

场景(Scenes)

场景是所有物体的容器,场景只有一种。

场景的构造函数是:

var scene = new THERR.Scene()复制代码

Fog(线性雾):

scene.fog = new THREE.Fog(0xcce0ff, 10, 500)复制代码

照相机(Cameras)

定义了三维空间到二维屏幕的投影方式,投影方式主要分为正交投影和透视投影。

1.正交投影:正交投影照相机获得的结果对于在三维空间内平行的线,投影到二维空间中也一定是平行的。

2.透视投影:透视投影照相机获得的结果是类似人眼在真实世界中看到的有“近大远小”的效果。

一般说来,对于制图、建模软件通常使用正交投影,这样不会因为投影而改变物体比例;而对于其他大多数应用,通常使用透视投影,因为这更接近人眼的观察效果,以下详细介绍透视投影。

透视投影照相机(Perspective Camera)的构造函数是:

var camera = new THREE.PerspectiveCamera(fov, aspect, near, far)复制代码

让我们通过一张透视照相机投影的图来了解这些参数。

透视图中,灰色的部分是视景体,是可能被渲染的物体所在的区域,在该视景体以外的物体将不会被渲染。

fov是视景体竖直方向上的张角(是角度制而非弧度制),如侧视图所示。

aspect等于width / height,是照相机水平方向和竖直方向长度的比值,通常设为Canvas的横纵比例。

near照相机到视景体最近的距离,为正值。

far照相机到视景体最远的距离,为正值。

渲染器(Renderers)

渲染器的作用就是将相机拍摄出的画面在浏览器中呈现出来。渲染器决定了渲染的结果应该画在页面的什么元素上面,并且以怎样的方式来绘制。three.js中有很多种类的渲染器,例如webGLRenderer、canvasRenderer、SVGRenderer,通常使用的是webGLRenderer渲染器。 webGLRenderer渲染器的构造函数是:

renderer = new THERR.WebGLRenderer()复制代码

创建完渲染器之后,需要调用render方法将之前创建好的场景和相机相结合从而渲染出来,即调用渲染器的render方法:

renderer.render(scene,camera)复制代码

了解了three.js完成3D绘图的三大要素之后,便可以在页面中创建场景,并利用相机将场景渲染到网页上。

首先需要下载three.js库,并引用到自己的代码中,以下为三种引入方式,选择合适的方式在自己的项目中。

<script src="lib/three.js"></script>//ES5const THREE=require('three')//CommonJS/AMDimport * as THREE from 'three'//ES6复制代码
// 创建场景var scene = new THREE.Scene(); // 创建透视相机var camera = new THREE.PerspectiveCamera(75, window.innerWidth/window.innerHeight, 0.1, 1000); // 创建一个 WebGL 渲染器var renderer = new THREE.WebGLRenderer({alpha: true,// 默认情况下为黑色场景,此处设置为透明(即白色场景)}); // 设置渲染器为全屏renderer.setSize(window.innerWidth, window.innerHeight); // 添加到网页中document.body.appendChild(renderer.domElement);复制代码

完成上述各个步骤之后,我们在网页上看到的只有一块静态的白色场景,看不到任何东西,接下来通过一些基础图像的学习和了解,以呈现一些图形效果。

二、图像的表示

绘制的前期准备工作已经做完,接下来要做的就是把想要绘制的物体添加到场景中。在计算机世界中,3D世界是由点组成,两个点能够组成一条直线,三个不在一条直线上的点就能够组成一个三角面片,无数个三角面片就能够组成各种各样形状的物体,通常把这种网格模型叫做Mesh模型。Mesh模型是三维开发中使用的最为广泛的型。

Geometries(几何图形)

three.js给出了很多方法去生成固定的网格形状,比如长方体(BoxGeometry)、球体(SphereGeometry)、圆形(CircleGeometry)等等。还有根据具体坐标生成具体形状的方法,可以借助第三方建模软件(SketchUp)建模之后导入,目前支持的模型格式有.obj(最常用),.dae,.ctm,.ply,.stl,.wrl,.vtk等。Three.js有一系列支持外部导入文件的函数,是在three.js库之外的,使用前需要单独下载。(例如:OrbitControls-控制器、OBJLoader-加载.obj 文件、MTLLoader-加载.mtl文件)。

Materials(材质)

three.js给出了很多种直接生成材质的方法,其中比较常用的有MeshBasicMaterial(对光照无感,给几何体一种简单的颜色或显示线框),MeshLambertMaterial(对光照有反应,无光源则不会显示,用于创建暗淡的不发光的物体)、MeshPhongMaterial(对光照有反应,无光源不会显示,用于创建金属类米昂凉的物体)等等。物体之所以能被人眼看见,一种是它自身的材料就能发光,不需要借助外界光源;另一种是自身材料不发光,需要反射环境中的光。对于自身不发光的物体,需要个场景添加光源从而达到可视的效果。

Lights(灯光)

three.js中可以创建出很多不同类型的光源,比如环境光AmbientLight(它的颜色会添加到整个场景和所有对象的当前颜色上),点光源PointLight(这种光源放出的光线来自同一点,且辐射方向四面八方,如蜡烛发出的光),方向光DirectionalLight(也称作无限光,从这种光源发出的光线可以看做是平行的,如太阳光),聚光灯SpotLight(这种光源的光线从一个椎体中射出,在被照射的物体上产生聚光的效果,如手电筒发出的光。)有光源就缺少不了阴影,在Three.js中,能形成阴影的光源只有DirectionalLight和SpotLight;而相对地,能表现阴影效果的材质只有LambertMaterial和PhongMaterial。three.js中渲染阴影的开销比较大,所以默认物体是没有阴影的,需要单独开启。开启阴影的方法:

  • 将渲染器的shadowMapEnabled属性设置为true(告诉渲染器可以渲染隐形)
  • 将物体及光源的castShadow属性设置为true(告诉物体及光源可以透射阴影)
  • 将接收该阴影的物体的receiveShadow属性设置为true(告诉物体可以接收其他物体的阴影)

在了解了关于图形的基本知识之后,在上面的代码的基础上添加简单图像。

var geometry = new THREE.BoxGeometry(1,1,1); // 创建一个长宽高都为1个单位的立方体var material = new THREE.MeshBasicMaterial({color: 0x00ff00}); // 创建材质,对光照无感var cube = new THREE.Mesh(geometry, material); // 创建一个立方体网格(mesh),将材质包裹在立方体上scene.add(cube); // 将立方体网格添加到场景中camera.position.z = 5; // 指定相机位置function render() {requestAnimationFrame(render); // 让浏览器执行参数中的函数,不断循环(浏览器一个新的API)renderer.render(scene, camera); // 结合场景和相机进行渲染,即用摄像机拍下此刻的场景}render();复制代码

在render()函数中添加以下代码使上面在场景中添加的正方体运动起来。

cube.rotation.x += 0.1;cube.rotation.y += 0.1;复制代码

Controls(控制器)

轨道控制插件OrbitControls.js可以实现场景用鼠标交互,让场景动起来,控制场景的旋转、平移和缩放。由于OrbitControls.js是一个插件,所以在three.js 中使用时,需要单独引入该文件。

controls = new THREE.OrbitControls(camera);// 初始化控制器controls.target.set(0, 0, 0);// 设置控制器的焦点,使控制器围绕这个焦点进行旋转controls.minDistance = 80;// 设置移动的最短距离(默认为零)controls.maxDistance = 400;// 设置移动的最长距离(默认为无穷)controls.maxPolarAngle = Math.PI / 3;//绕垂直轨道的距离(范围是0-Math.PI,默认为Math.PI)controls.update();// 照相机转动时,必须更新该控制器复制代码

配置该插件之后实现的效果:

操控效果按住鼠标左键并移动摄像机围绕场景中心旋转转动鼠标滑轮或按住中键并移动放大或缩小按住鼠标右键并移动在场景中平移上、下、左、右方向键在场景中平移

Loaders(加载器)

用来加载不同格式的文件,主要介绍以下三种:

OBJLoader加载器(需要单独引入js文件):用来加载.obj文件(分为有材质和没有材质两种)。

// 没有材质new THREE.OBJLoader().load('./tree.obj', function (obj) {obj.scale.set(10, 10, 10);obj.position.set(-10, 0, 0);obj.children.forEach(function (e) {e.castShadow = true});// 设置阴影scene.add(obj)});复制代码

MTLLoader加载器(需要单独引入js文件):用来加载.mtl文件(即加载有材质物体的obj文件之前先加载mtl文件)。

// 有材质new THREE.MTLLoader().setPath('./model/VANS/').load('VANS.mtl', function (materials) {materials.preload();new THREE.OBJLoader().setMaterials(materials).setPath('./model/VANS/').load('VANS.obj', function (obj) {obj.scale.set(0.8, 0.8, 0.8);obj.position.set(-40, -50, 10);scene.add(obj)})});复制代码

CSS2DRenderer加载器(需要单独引入js文件):如果要将基于HTML的标签与3D对象组合,则CSS2DRenderer渲染器非常有用。这里,各个DOM元素也被包装到CSS2DObject的一个实例中并添加到场景图中。

// 初始化 CSS2DRendererlabelRenderer = new THREE.CSS2DRenderer();labelRenderer.setSize(window.innerWidth, window.innerHeight); // 设置渲染器的大小labelRenderer.domElement.style.position = 'absolute';labelRenderer.domElement.style.top = 0;container.appendChild(labelRenderer.domElement);// 标注实例function addSprite(text, Mash, callback) {biaozhudiv = document.createElement('div');biaozhudiv.className = 'label';biaozhudiv.textContent = text;biaozhudiv.onclick = function () { callback(Mash)};biaozhuLabel = new THREE.CSS2DObject(biaozhudiv);biaozhuLabel.position.set(0, 0, 0);Mash.add(biaozhuLabel);}复制代码

Textures(纹理)

纹理是一个2D图片(甚至也有1D和3D的纹理),它可以用来添加物体的细节;可以想象纹理是一张绘有砖块的纸,无缝折叠贴合到你的3D的房子上,这样你的房子看起来就像有砖墙外表了。

var textureCube = new THREE.CubeTextureLoader().load(urls);scene.background = textureCube;复制代码

Three.js+vue.js

1.用npm 安装three npm install three

three.js 安装地址 :http://www.npmjs.com/package/three

安装成功后,在项目中 import three from ‘three’;,之后运行程序。

发现控制台报错 default export is not declared in imported module 说明three.js没有默认的导出对象,应该写成 import * as three from ‘three’; 或者可以这样: import { Scene, WebGLRenderer, PerspectiveCamera, BoxGeometry, MeshBasicMaterial, Mesh} from ‘three’;

或者使用CommonJS的形式引入var three = require (‘three’);

2.用npm安装轨道控制插件 npm install three-orbit-controls

three-orbit-controls安装地址:http://www.npmjs.com/package/three-orbit-controls

该插件引入之前确认three.js 库已经引入, OrbitControls = require(‘three-orbit-controls’)(THREE)

使用方法: controls = new OrbitControls(camera);

3.用npm安装加载.obj和.mtl文件的插件 npm i –save three-obj-mtl-loader

three-obj-mtl-loader安装地址 :http://www.npmjs.com/package/three-obj-mtl-loader

该插件引入之前必须确认three.js库已经引入,该插件包括加载.obj和.mtl 文件的加载器

import {MTLLoader,OBJLoader} from ‘three-obj-mtl-loader’;

使用方法:mtlLoader = new MTLLoader(); objLoader = new OBJLoader();

注:单独使用three-mtl-loader 和 three-obj-loader两个插件时,会发生错误:

4.用npm安装three-css2drender插件, npm i –save three-css2drender

three-css2drender安装地址:www.npmjs.com/package/three-css2drende

插件引入之前必须确认htree.js库已经引入

import {CSS2DRenderer,CSS2DObject} from ‘three-css2drenderer’;

使用方法:

labelRenderer = new CSS2DRenderer();

label = new CSS2DObject( text );

    推荐阅读
  • 大白豆的功效与作用(大白豆的功效与作用禁忌)

    1、大白豆含蛋白质、脂肪、糖类、磷、钙、铁、锌,维生素B1、B2和烟酸、泛酸、豆甾醇、磷脂、氰甙、血球凝结素等成分。

  • 女生出门一定要提高安全意识(天气渐暖女性出行需防)

    日前,公交警方及时抓获了在公交车或地铁等公共场所猥亵女性的违法犯罪人员,有力打击了这些人员的嚣张气焰。公安公交总队营口道治安派出所经过侦查,很快将违法人员孙某抓获。最终,孙某被公交警方行政拘留。营口道治安派出所民警赶到后,通过调看车厢内的监控,确定王某某的违法行为。对此,公交警方出招,助广大女性辨别“色狼”,防范“咸猪手”。同时应立即拨打110报警,民警会尽快赶到现场进行处理。

  • 100个好听的女生吃鸡名字大全(100个好听的女生吃鸡名称大全)

    吃鸡的少女绝版萌贝贝,下面我们就来说一说关于100个好听的女生吃鸡名字大全?我们一起去了解并探讨一下这个问题吧!

  • 家庭教育如何培养孩子学习能力(如何让孩子爱上学习)

    相比30年前的父母的读书状态而言,今天孩子的问题非常的严重,很多妈妈对教育孩子已经非常困惑了。下面以王博士的视角说个他的事。王博士在一个私立学校,讲完课之后,有个爸爸就提问了,他说王博士,我想问一下,今天的社会环境非常的恶劣,到处都是网络里面充满着负面新闻,黄色图片,甚至是各种网络游戏,我觉得我的孩子在这样的社会环境下非常的危险,我们该如何应对?以上是我最佩服的王博士的原话。

  • 平板充电一直显示红色 平板充电一直显示红色的电池是什么颜色

    以iPhone平板为例,充电一直显示红色的原因及解决方法是:1、先确认数据线是否正常,数据线外表看似正常,里面可能已经出现断裂了;2、电池电量过低电池保护了,会导致电池进入休眠状态,需要充20至30分钟来激活电池才可以继续充电;3、按住power键,和home键,出现iPhone标志后,松开power键,继续按住home键,直到出现连接iTunes的标志,然后连接充电器充电,半个小时就会好的;4、电池或者设备硬件出现故障导致,去售后或专卖店检测维修。

  • gdg总决赛(GDBA半决赛开战战火一触即发)

    本阶段,广州、东莞、深圳、湛江四支队伍硝烟弥漫,胜者将晋级总决赛,负者则争夺季军席位。在西区一、二名争夺的两场比赛中,广州队仅让湛江队得到56分和61分。这将会是本场比赛的一大看点。4结语上届联赛仅取得第10名的深圳队,在今年联赛中已经焕然一新,成为新晋四强的队伍。在面对另一支至今保持全胜的广州队,希望深圳队在主场不要留下遗憾。

  • 春天大蒜的种植方法(大蒜种植的月份是几月)

    具体时间是在三四月份,这时气温基本稳定了,种下之后能更快出苗,且后期温暖些,小苗也能更好的生长。种植之前要先选大蒜,要求是饱满,外表没有损伤的且没有病虫害的。处理好之后放在水里进行浸泡处理,大概泡三五分钟即可,最后取出晾干。此外,还要撒适量的基肥,提高土壤的肥沃度。种下之后及时浇透水,适当保温处理,很快就可长出蒜苗。此外,发现杂草时的时候及时清理掉,做好防治工作。

  • 广州地铁23号线2023年规划图(广州地铁26号线一)

    今年,大良将推进6所中小学新建、改建、扩建,预计逐步增加学位超3900个。大良容桂已经超100万常住人口,但吸引广州人到此居住的条件尚未成熟。南沙榄核到容桂马冈段需要佛山市上报建设,良桂应高度重视。希望这些项目尽快落实,成为顺德南部快速发展的支撑力量,做实广佛高质量融合发展试验区,顺德南沙加快集聚资源成为湾区中心的极核之一。

  • iPhone骚扰电话怎么拦截(苹果怎么拦截骚扰电话)

    以iPhonexsmax为例,iPhone骚扰电话拦截的方法是:1、打开手机,点击电话。