Threejs制作虚拟房间效果

简介: 这篇文章详细说明了如何使用Three.js创建一个虚拟房间的3D模型,通过将六个方向的照片作为立方体的纹理,从而实现一个类似于天空盒的室内场景,让用户能够探索房间的不同角落。

我们经常在装修的网站可以看到虚拟房间的效果,通过网站展示3D房间的细节,并且点击可以进入到每个房间查看,今天就用threejs来实现类似的效果,其实就是类似天空盒子的功能,将房间的上下左右前后各拍一张图片,并且保证每个图片的交界处是衔接上的,最后组成一个正方体的盒子,将相机设置在盒子的中间,禁止拖动,就可以实现在房间里查看房间周围家具的效果。

首先第一步创建3D场景

 function initScene() {
        scene = new THREE.Scene();
      }

      // 初始化相机
      function initCamera() {
        camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 10000);
        camera.position.set(0, 0, 10);
      }

      // 初始化灯光
      function initLight() {
        var directionalLight = new THREE.DirectionalLight(0xffffff, 0.3); //模拟远处类似太阳的光源
        directionalLight.color.setHSL(0.1, 1, 0.95);
        directionalLight.position.set(0, 200, 0).normalize();
        scene.add(directionalLight);

        var ambient = new THREE.AmbientLight(0xffffff, 1); //AmbientLight,影响整个场景的光源
        ambient.position.set(0, 0, 0);
        scene.add(ambient);
      }
 // 初始化渲染器
      function initRenderer() {
        renderer = new THREE.WebGLRenderer({
          antialias: true
        });
        renderer.setSize(window.innerWidth, window.innerHeight);
        renderer.setClearColor(0x4682B4, 1.0);
        document.body.appendChild(renderer.domElement);
      }

      // 初始化轨迹球控件
      function initControls() {
        controls = new THREE.OrbitControls(camera, renderer.domElement);
      }

      function animate() {
        requestAnimationFrame(animate);
        renderer.render(scene, camera);
      }

然后找六张房间的图片,图片资源

然后将图片添加到场景中,并作为贴图贴在正方体的6个面上

function initHouse(){
        const geometry = new THREE.BoxGeometry( 40, 40, 40)
        // 立方体纹理加载
        let arr = ['home_left','home_right','home_top','home_bottom','home_front','home_back'];
        let boxMaterials = []
        arr.forEach(item=>{
          const texttrue = new THREE.TextureLoader().load('./images/'+item+'.jpg' ) // 纹理贴纸
          boxMaterials.push(
              new THREE.MeshBasicMaterial({
                color:'#ffffff',
                map:texttrue
              })
          )
        })
        const mesh = new THREE.Mesh(geometry,boxMaterials)
        mesh.geometry.scale(1,1,-1) // 进入内部
        scene.add(mesh)
      }

然后就可以实现了,效果如下:
WechatIMG115.jpg
Threejs查看VR房间

这里不支持上传视频,我就只能上传个图片了,如果想看动态效果可以私我,我发给你视频,或者需要源码也可以给我私信

下面是完整代码

<!DOCTYPE html>
<html>
<head includeDefault="true">
  <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
  <title>位置移动</title>
  <script src="./ThreeJs/js/three.js"></script>
  <script src="./ThreeJs/js/OrbitControls.js"></script>
</head>

<body>
    <div class="container" ref="container"></div>
  <script>
        var camera, scene, renderer, controls;
      function initScene() {
        scene = new THREE.Scene();
      }

      // 初始化相机
      function initCamera() {
        camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 10000);
        camera.position.set(0, 0, 10);
      }

      // 初始化灯光
      function initLight() {
        var directionalLight = new THREE.DirectionalLight(0xffffff, 0.3); //模拟远处类似太阳的光源
        directionalLight.color.setHSL(0.1, 1, 0.95);
        directionalLight.position.set(0, 200, 0).normalize();
        scene.add(directionalLight);

        var ambient = new THREE.AmbientLight(0xffffff, 1); //AmbientLight,影响整个场景的光源
        ambient.position.set(0, 0, 0);
        scene.add(ambient);
      }
      function initHouse(){
        const geometry = new THREE.BoxGeometry( 40, 40, 40)
        // 立方体纹理加载
        let arr = ['home_left','home_right','home_top','home_bottom','home_front','home_back'];
        let boxMaterials = []
        arr.forEach(item=>{
          const texttrue = new THREE.TextureLoader().load('./images/'+item+'.jpg' ) // 纹理贴纸
            boxMaterials.push(
              new THREE.MeshBasicMaterial({
                color:'#ffffff',
                map:texttrue
              })
            )
          // }
        })
        const mesh = new THREE.Mesh(geometry,boxMaterials)
        mesh.geometry.scale(1,1,-1) // 进入内部
        scene.add(mesh)
      }

      // 初始化渲染器
      function initRenderer() {
        renderer = new THREE.WebGLRenderer({
          antialias: true
        });
        renderer.setSize(window.innerWidth, window.innerHeight);
        renderer.setClearColor(0x4682B4, 1.0);
        document.body.appendChild(renderer.domElement);
      }

      // 初始控制
      function initControls() {
        controls = new THREE.OrbitControls(camera, renderer.domElement);
      }

      function animate() {
        requestAnimationFrame(animate);
        renderer.render(scene, camera);
      }

      function init() {
        initScene();
        initCamera();
        initLight();
        initHouse();
        initRenderer();
        initControls();
        animate();
    }
    init();

  </script>
</body>

</html>
相关文章
Threejs实现天空盒,全景场景,地面草地
Threejs实现天空盒,全景场景,地面草地
1810 0
Threejs实现天空盒,全景场景,地面草地
Threejs制作窗户透亮效果
这篇文章讲解了如何在Three.js中制作窗户的透亮效果,包括设置透明材质和光照以实现逼真的窗户渲染效果的技术细节。
311 1
Threejs用切线实现模型沿着轨道行驶
这篇文章详细介绍了如何使用Three.js让一个模型沿着预定的曲线路径移动,并保持模型的方向始终沿着路径的切线方向,提供了实现这一效果的具体代码和步骤。
714 1
Threejs用切线实现模型沿着轨道行驶
|
开发框架
threejs做特效:实现物体的发光效果-EffectComposer详解!
【8月更文挑战第7天】实现物体的发光效果-EffectComposer详解!
2270 6
threejs做特效:实现物体的发光效果-EffectComposer详解!
|
监控
ThreeJs限制模型拖动的范围
这篇文章讲解了在Three.js中如何限制模型拖动的范围,确保模型在特定边界内移动,提供了实现拖动限制的代码示例和技术细节。
412 1
ThreeJs限制模型拖动的范围
Threejs创建天空和太阳
这篇文章讲解了如何使用Three.js中的Sky组件来创建真实的天空与太阳效果,包括调整天空的颜色、太阳的位置以及实现大气散射等技巧。
513 3
ThreeJs通过射线获取自己的点击位置坐标
这篇文章详细说明了如何使用Three.js来绘制线条,包括创建线几何体、设置材质以及将线条添加到3D场景中的具体步骤。
517 1
ThreeJs通过射线获取自己的点击位置坐标
|
UED
ThreeJs模拟工厂生产过程三
这篇文章介绍了在Three.js中通过使用mergeGeometries技术来合并大量车间模型,以减少浏览器渲染负担,提高性能,并提供了实现模型合并的具体方法和步骤。
241 5
threeJs用精灵模型Sprite实现下雨效果
这篇文章介绍了使用Three.js中的Sprite(精灵)模型来实现下雨特效的方法和技术细节。
512 2
threeJs用精灵模型Sprite实现下雨效果
ThreeJs模拟工厂生产过程七
这篇文章详细介绍了如何在Three.js中为工厂车间的货架动态生成并放置货物,通过循环逻辑和贴图应用使货架上的物品更加逼真,增强了场景的真实感。
176 0