首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Three.js - 走进3D的奇妙世界

一、Three.js相关概念 1.1 Three.JS Three.JS是基于WebGL的Javascript开源框架,简言之,就是能够实现3D效果的JS库。...七、纹理 在生活中纯色的物体还是比较少的,更多的是有凹凸不平的纹路或图案的物体,要用Three.JS实现这些物体的效果,就需要使用到纹理贴图。...环境贴图是将当前环境作为纹理进行贴图,能够模拟镜面的反光效果。...上图的椅子是在3D制图软件绘制出来的,chair.mtl是导出的材质文件,chair.obj是导出的几何体文件,使用材质加载器加载材质文件,加载完成后得到材质对象,给几何体加载器设置材质,加载后得到几何体对象...主要的代码如下: // .mtl材质文件加载器 var mtlLoader = new THREE.MTLLoader(); // .obj几何体文件加载器 var objLoader = new THREE.OBJLoader

8.3K20

Three.js - 走进3D的奇妙世界

一、Three.js相关概念 1.1 Three.JS Three.JS是基于WebGL的Javascript开源框架,简言之,就是能够实现3D效果的JS库。...七、纹理 在生活中纯色的物体还是比较少的,更多的是有凹凸不平的纹路或图案的物体,要用Three.JS实现这些物体的效果,就需要使用到纹理贴图。...环境贴图是将当前环境作为纹理进行贴图,能够模拟镜面的反光效果。在进行环境贴图时需要使用立方相机在当前场景中进行拍摄,从而获得当前环境的纹理。...上图的椅子是在3D制图软件绘制出来的,chair.mtl是导出的材质文件,chair.obj是导出的几何体文件,使用材质加载器加载材质文件,加载完成后得到材质对象,给几何体加载器设置材质,加载后得到几何体对象...主要的代码如下: // .mtl材质文件加载器 var mtlLoader = new THREE.MTLLoader(); // .obj几何体文件加载器 var objLoader = new THREE.OBJLoader

9.8K40

【带着canvas去流浪(12)】用Three.js制作简易的MARVEL片头动画(上)

本节先来解决视频贴图的问题。...绘制字体模型】),它要求先载入字体文件,然后才能实例化,参考官方文档的实现就可以了。...视频贴图就直接失效了。...3.2 纹理贴图的基本原理-UV映射 在Three.js中,几何体是通过点和面的特征构建起来的,如果将一个几何体实例对象在控制台打印出来,就可以看到存储端点坐标信息的vertexs和存储面信息的faces...右图中白色三角形的三个顶点在归一化坐标系中的坐标值已经列出,将[0.2,0.2],[0.2,0.8],[0.7,0.2]这三个坐标点信息填充到对应的UV映射数组中后,Three.js就会用这个三角形区域来对一个三角面进行贴图

3.1K51

谁还没有冰墩墩?速来领→

思否的一位大佬 dragonir ,凭借高超的前端技术和建模技术,使用 Three.js + React 技术栈,自己创造了一个充满趣味和纪念意义的冬奥主题 3D 页面!...当然也可以直接使用 Three.js 自带平面网格加凹凸贴图也可以实现类似的效果。使用 Blender 自建模型的优点在于可以自由可视化地调整地面的起伏效果。...原模型: 冰墩墩贴图: 转换成Blender支持的模型,并在Blender中调整模型贴图法线、并添加贴图: 导出 glb 格式 在 Blender 中给模型添加贴图教程传送门:在Blender中怎么给模型贴图...添加松树的时候用到一个技巧非常重要:我们知道因为树的模型非常复杂,有非常的面数,面数太多会降低页面性能,造成卡顿。...Three.js 中,雨、雪、云、星辰 等生活中常见的粒子都可以使用 Points 来模拟实现。

4.5K10

利用 WebGL 和 Three.js 实现楼层商场地图

为了解决这一问题,利用 WebGL 和 Three.js 技术实现楼层商场地图成为了一种新的解决方案。...技术,我们可以创建一个交互式的楼层商场地图。...scene.add(marker); 这行代码将商店标记添加到Three.js场景中,使其显示在场景中。...在函数内部,首先计算了鼠标的屏幕坐标,并将其转换为 Three.js 场景中的标准化设备坐标系(NDC)。用户体验的优化为了提高用户的体验和使用便捷性,我们可以进一步优化楼层商场地图的功能和性能。...技术实现楼层商场地图,为消费者提供了一种新的导航方式,帮助他们更快速地找到目标店家,提高了商场的吸引力和竞争力。

23510

【带着canvas去流浪(11)】Three.js入门学习笔记

Three.js中的基本概念 官方文档中的新手示例过于简单,所以本节对Three.js中的概念进行一些补充描述: 客观三要素:场景Scene,相机Camera,渲染器Renderer 具体用法可以看官方文档的...贴图纹理Texture 第三步是为实体选择贴图纹理texture,纹理通常是通过引入图片来生成,通过贴图可以让几何体呈现为它所代表的实体模型,比如一个球体,你贴上足球的纹理,它就是足球,贴上篮球纹理,...把周围环境作为贴图贴在它表面,它就是水晶球。...morph和skeleton动画对比,morph文件更大加载更慢,但实际在网页上计算量更小;骨骼动画文件更小,当在网页上运行时需要进行更多计算。...舞台背景scene.background是可以设置贴图纹理的。 调整贴图的 四.补充示例 第15节-关于物体阴影 后来发现这个问题在第27节有说明。

3.8K10

一文搞懂如何在Three.js里创建阴影效果 |《Three.js零基础直通14》

阴影优化 渲染尺寸 要知道,Three.js里阴影的本质其实是通过计算实时生成阴影贴图。...Near and far Three.js使用相机来帮助计算阴影贴图。这些相机与我们前面学到的相机具有相同的属性。比如我们必须定义相机的近视距离和远视距离。...因为我们使用的是平行光,所以Three.js在为它渲染阴影贴图时使用的是正交相机。如果您还记得相机课程,我们可以通过顶部,右侧,底部和左侧属性控制相机在每一侧可以看到的距离。...阴影贴图算法 three.js中有几种内置的阴影贴图算法供我们选择: THREE.BasicShadowMap 性能很好,但质量很差 THREE.PCFShadowMap 性能较差,但边缘更光滑 THREE.PCFSoftShadowMap...这是由于在Three.js中点光源的阴影贴图要依赖6个方向上的相机来实现-_-!。 正因为点光源会在每个方向上发光,所以Three.js必须通过6个方向的渲染才能创建出多维数据集阴影贴图

6.5K10

我是如何用 Three.js 在三维世界建房子的(详细教程)

这样一个房子,其实也是由几个几何体堆起来的: 具体有这么些几何体: 地板就是个平面,用 PlaneGeometry(平面几何体) 就可以画,贴上个纹理贴图就行。...Three.js 提供了很多的几何体,可以画一些简单的物体,但复杂的物体就很难画出来了,这类物体一般会用专业的 3D 建模软件来画,导出 FPX 或者 OBJ 格式的文件Three.js 加载并渲染出来...房子的墙、地板、房顶都可以用 BoxGeometry(立方体)、ExtrudeGeometry(挤压几何体)画出来,但是床这种复杂的就不行了,会直接加载模型文件。...还要贴上墙的纹理贴图。...房子中放了一张床,这种复杂的物体用 Three.js 手画就比较难了,这种一般都是由专业建模软件,比如 blender 来画好,然后用 Three.js 加载并渲染的。

4.9K61

大神驾到|「大掌教」带你上车Cocos3D!

大掌教,从事游戏开发多年,精通 Cocos/Unity 等游戏引擎,精通安卓/iOS/H5等多种平台开发,发表过多个开源项目和 100 篇原创博文,经验丰富,技术精湛。...很多同学不满足于开发2D游戏,想尽办法搞一些3D效果,比如自己接入three.js,手写opengl等,还有的使用2.5来假装3D。...新建一个工程,会莫名其妙一个资源文件internal,跟我们以前熟悉的大为不同。 多出来的这个internal是啥玩意啊,在新建的项目里面根本找不到这么一个文件或目录。...有很多同学有强迫症,把这个删掉,然后项目就打不开了,这也是新版本坑的一贯尿性。...导入工程 随便找个fbx模型,当然为了表现效果好一点,这个模型最好有配套的纹理贴图和骨骼动画。

1.4K10

打造H5里的“3D全景漫游”秘籍 - 腾讯ISUX

故近年来,也是VR技术的一大热门实现手法,用前面的贴图例子来个demo。而在移动端的全景漫游,更是可以绑定陀螺仪,让你更有身临其境的感觉。...(3)Three.js源自Github的一个开源项目,https://github.com/mrdoob/three.js,官网:http://threejs.org/ 。...Three表示3D的意思,js表示javascript的意思,故three.js就是使用javascript来写3D程序的意思,格外的直白清晰啊。...这里,考虑到星空背景主要为了氛围烘托,我们将6个面的贴图减少成2个,以此缩减了资源文件的大小,如下图所示。...(8)其他 在项目完成的初期,对部分安卓机的内存消耗还是过大,为此在完成项目之后继续尝试了一些优化工作,包括 缩减宇宙的尺寸,合并全景贴图,禁用陀螺仪,预加载和懒加载,星球CSS3动画缩减,资源文件深度压缩等工作

5.1K10
领券