首页
学习
活动
专区
圈层
工具
发布

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

Three.js 提供了很多的几何体,可以画一些简单的物体,但复杂的物体就很难画出来了,这类物体一般会用专业的 3D 建模软件来画,导出 FPX 或者 OBJ 格式的文件由 Three.js 加载并渲染出来...还要贴上墙的纹理贴图。...其中,瓦片的纹理要做下旋转,设置下两个方向的重复次数。...物体由几何体(Geometry)和材质(Material)两部分构成,房子就是由立方体(BoxGeometry)、挤压几何体(ExtrudeGeometry)等各种几何体构成的,设置不同的贴图纹理,还有位置...房子中放了一张床,这种复杂的物体用 Three.js 手画就比较难了,这种一般都是由专业建模软件,比如 blender 来画好,然后用 Three.js 加载并渲染的。

5.9K71
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    用Three.js构建三维世界的房子

    最近在学习Three.js,无奈不知道从哪里下手,查阅大部分资料都是先介绍渲染器(Renderer)、场景(Scene)、照相机(Camera),其实这些概念确实需要了解,如果不给你立体模型,你始终是无法理解的...1 创造世界 很好理解,就是我们现在看到的世界,用Three.js做出来。...首先对Three.js还是要了解其一些概念的,这样才能看的更明白。新建一个项目,引入Three.js,网上不好js找没关系,我会在最后提供本篇文章的完整demo。...img/grass.jpg"); texture.wrapS = THREE.RepeatWrapping; texture.wrapT = THREE.RepeatWrapping; // 纹理对象阵列...wood.jpg'); texture.wrapS = THREE.RepeatWrapping; texture.wrapT = THREE.RepeatWrapping; // 纹理对象阵列

    2.3K21

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

    Three.js中的基本概念 官方文档中的新手示例过于简单,所以本节对Three.js中的概念进行一些补充描述: 客观三要素:场景Scene,相机Camera,渲染器Renderer 具体用法可以看官方文档的...【新手示例Demo】 光照Light THREE.js提供了点光源,射线光源,平行光,环境光的等多种光源来模拟光。...贴图纹理Texture 第三步是为实体选择贴图纹理texture,纹理通常是通过引入图片来生成,通过贴图可以让几何体呈现为它所代表的实体模型,比如一个球体,你贴上足球的纹理,它就是足球,贴上篮球纹理,...THREE.shapeGeometry,THREE.ExtrudeGeometry等一类由平面生成3D实体的模型,感兴趣的可以尝试一下三维建模软件solidworks,完全是一个路数,对理解这些抽象几何实体很有帮助...具体用法可参考SVGLoader文档 ,官方仓库的example中提供了webgl_loader_svg.html示例文件,我们在其中稍作改动,将转换后的shape作为参数来得到拉伸体实例THREE.ExtrudeGeometry

    4.3K11

    【愚公系列】2023年08月 Three.js专题-纹理

    一、纹理 1.简介 Three.js中的纹理贴图方式有以下几种: 基础纹理:使用纹理图像创建基本纹理,可以使用图片或视频等多种类型的纹理贴图。...烘培纹理:通过烘培过程将光影效果转换为纹理,可以提高性能和图形质量。 渲染目标纹理:使用渲染目标纹理可以将场景的渲染结果保存到纹理中,可以用于后处理、渲染效果等。...视频和动态纹理:可以使用视频或动态生成的图像作为纹理,动态纹理可以根据场景的变化实时更新。...2.属性 在Three.js中,贴图是指在材质表面上贴附一张图片纹理,通过纹理映射的方式来呈现出材质表面的不同效果和细节。.../lib/three/three.js"> <script src="..

    32710

    Threejs进阶之十八:使用ExtrudeGeometry从二维图形创建三维几何体

    上一节我们介绍了Threejs中二维图形相关的类,这一节我们来聊一聊如何通过创建的二维图形来生成三维图形 ExtrudeGeometry类 ExtrudeGeometry类(挤压缓冲几何体)...是Three.js中的一个类,用于将二维轮廓线沿着指定路径拉伸成三维立体形状。...它的构造函数如下所示: 构造函数 ExtrudeGeometry(shape, options) 该对象将一个二维形状挤出为一个三维几何体 ExtrudeGeometry的参数 shape:ExtrudeGeometry...我们可以使用两个Three.js对象来创建二维图形:THREE.Shape和THREE.Path。...(shape, extrudeSettings); 在上述代码中,使用ExtrudeGeometry的构造函数和extrudeSettings参数来创建ExtrudeGeometry对象。

    2.9K31

    纹理压缩

    纹理格式是能被GPU所识别的像素格式,能被快速的寻址并采样。 纹理格式如:RGB_565,每个像素占用:5+6+5=16 (bits),共 2 个字节。...随机访问:由于几乎不可能预测纹理像素被访问的顺序,任何纹理压缩算反必须允许对其中的纹理的随机访问。...所以几乎所有的纹理压缩算法都已块为单位压缩和存储纹理像素,当某一个纹理像素被访问时,只有同一块中的若干纹理像素被读取和解压缩。...编码速度:纹理压缩对压缩速度的要求不高,因为绝大多数情况下,纹理只需要进行一次压缩。(但是对解压速度要求较高。)...在纹理贴图中,已经压缩的纹理和没有经过压缩的纹理使用起来基本没有区别,都可以被用来存储颜色数据或其他数据,例如凹凸贴图或法线贴图,也都可以和Mipmapping或各项异性过滤等共同使用。

    1.9K111

    Shader-高级纹理-立方体纹理

    立方体纹理(Cubemap) 是环境映射(EnvironmentMapping)一种实现方式。...纹理采样:对立方体采样需要提供一个三维的纹理坐标,这个三维纹理坐标表示了我们在世界空间下的一个3D、方向。 天空盒子 Skybox是游戏中模拟背景的一种方法,每个面使用的技术就是立方体纹理映射技术。...创建用于环境映射的立方体纹理 1.提供一张具有特殊布局的纹理,类似于立方体展开图的交叉布局、全景布局等。...我们需要将TextureType设置为Cubemap 2.使用Camera.RenderToCubemap方法实现,此方法可以把任意位置观察到的场景存储到6张图像中,从而创建出该位置上的立方体纹理。...将创建的立方体纹理存入一个Cubemap中。 反射 在我们的shader中加入一个模拟反射的环境映射纹理。对立方体的纹理使用CG中的texCUBE函数进行采样。 我们最终得到图中结果 ?

    1K30

    【带着canvas去流浪(14)】Three.js中凹浮雕模型的生成方式

    本文分别对利用Three.js在Web环境中生成凹浮雕模型时的几种策略进行讲解。 一....方案1:ThreeBSP.js或ThreeCSG.js扩展库 在众多技术博客里,提及最多的就是上述两个库,它们声称是Three.js的扩展库,用来对模型进行实体布尔操作。 But!不要用!不要用!...boxShape.holes.push(fontShape[0]); return boxShape; } /*生成拉伸体*/ textGeometry = new THREE.ExtrudeGeometry...方案3:Cinema 4D建模后输出模型文件 Three.js这种基于编程的建模方式并不够直观,面对复杂模型时,通用的解决办法是使用三维建模软件进行模型构建,然后导出Three.js能够识别的模型文件,...Three.js官方建议的模型格式为*.gltf格式,想要在C4D中直接导出这种格式需要安装相应的插件(GLTF格式工具仓库)。

    3K30

    Three.js教程(1):初识three.js

    ---- 为什么要使用three.js 要回答为什么要使用three.js?首先我们想想什么是three.js?...而three.js直接支持前3种渲染方式,可以看出three.js的强大。 大多情况下如果是为了展示3D的效果,那么直接用图片就可以了,如果要动起来的话,视频往往可以胜任。...别急,正因为原生的WebGL这么晦涩难懂,所以才有了我们的主角three.js。...现在你可以忘掉上面的内容,因为three.js封装的特别好,根本看不到任何WebGL的影子,你再也不需要去了解什么着色器,更不用写GLSL ES,我们先来看一个更高级且更简单的three.js的例子。...初识three.js three.js可以使用模块化引入,当然也可以直接用script标签来引入。

    24.7K74
    领券