首页 > 其他分享 >Threejs之看房案例(上)

Threejs之看房案例(上)

时间:2024-09-21 22:23:38浏览次数:3  
标签:Threejs 12 const THREE texture 案例 renderer new 看房

本文目录

前言

Three.js是一个基于WebGLJavaScript 3D库,它允许在网页上创建和显示3D图形。在房地产行业中,Three.js常被用于实现全景看房案例,为用户提供沉浸式的房屋浏览体验。

效果展示

立方体模式效果:
请添加图片描述
球体模式效果:
请添加图片描述

一、立方体模式

立方体模式的话,我们需要有6张照片,分别是房间的上下左右前后照片,有这6张图片素材,我们分别贴在立方体的6个面上,然后把相机至于其中,就能实现看房效果。

1.1 代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        html,
        body {
            margin: 0;
            padding: 0;
            width: 100%;
            height: 100%;
        }
    </style>
</head>

<body>
    <script type="module">
        // 倒入轨道控制器
        import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
        import * as THREE from 'three';

        // 创建场景
        const scene = new THREE.Scene();
        // 创建相机
        const camera = new THREE.PerspectiveCamera( // 透视相机
            75, // 视角 角度数
            window.innerWidth / window.innerHeight, // 宽高比 占据屏幕
            0.1, // 近平面(相机最近能看到物体)
            1000, // 远平面(相机最远能看到物体)
        );
        camera.position.set(0, 0, 30);
        // 创建渲染器
        const renderer = new THREE.WebGLRenderer({
            antialias: true, // 抗锯齿
        });

        // 设置渲染器宽高
        renderer.setSize(window.innerWidth, window.innerHeight);
        // renderer(渲染器)的dom元素添加到我们的HTML文档中
        document.body.appendChild(renderer.domElement);


        // 控制器
        const control = new OrbitControls(camera, renderer.domElement);
        // 开启阻尼惯性,默认值为0.05
        control.enableDamping = true;
        const images = [
            '../assets/left.png',
            '../assets/right.png',
            '../assets/top.png',
            '../assets/bottom.png',
            '../assets/front.png',
            '../assets/back.png',
        ];
        let materials = [];
        images.forEach((imgUrl, index) => {
            const texture = new THREE.TextureLoader().load(imgUrl);
            
            if (index == '3') {
                texture.rotation = -Math.PI/2;
                texture.center = new THREE.Vector2(0.5, 0.5);
            }
            if (index == '2') {
                texture.rotation = Math.PI/2;
                texture.center = new THREE.Vector2(0.5, 0.5);
            }
            const material = new THREE.MeshBasicMaterial({
                map: texture
            });
            materials.push(material);
        });
        
        const cube = new THREE.Mesh(new THREE.BoxGeometry(40, 40, 40), materials);

        cube.geometry.scale(12, 12, -12);
        scene.add(cube);

        // 渲染循环动画
        function animate() {
            // 在这里我们创建了一个使渲染器能够在每次屏幕刷新时对场景进行绘制的循环(在大多数屏幕上,刷新率一般是60次/秒)
            requestAnimationFrame(animate);
            // 更新控制器。如果没在动画里加上,那必须在摄像机的变换发生任何手动改变后调用
            control.update();
            renderer.render(scene, camera);
        };

        // 执行动画
        animate();
    </script>
</body>

</html>

1.2 代码解析

  1. 立方体模式下,我们6张图代表一个场景,我们创建了images数组将图片地址填入,接着遍历创建texture贴图,分别贴在立方体6个面上,顺序为左右上下前后。
  2. 如果发现图片位置不对的话,我们可以将贴图旋转,核心代码texture.rotation = -Math.PI/2; texture.center = new THREE.Vector2(0.5, 0.5); 选择的角度可以自己定,调到合适为止。
  3. cube.geometry.scale(12, 12, -12);我们将立方体的z轴缩放为负的,立方体在Z轴方向上的尺寸会减小,并且其方向会与默认情况相反,即从屏幕内向屏幕外看去,立方体的正面实际上是在屏幕的“背后”。让场景中有深度感,这种变换也可以用来实现一些特殊的效果,比如模拟从特定角度观察物体时的透视收缩效果,或者创建视觉上的错觉,使物体看起来像是被“推”到了屏幕的背后或前面。
  4. camera.position.set(0, 0, 1);按道理我们相机的位置如果不设定,默认是在原点(0,0,0)的位置。那不就是刚好在这个立方体的正中心,那为什么我们还要多此一举设置一个z轴为1,因为我们用了OrbitControls轨道控制器,Orbit controls(轨道控制器)可以使得相机围绕目标进行轨道运动。注意这句话,使得相机围绕目标进行轨道运动,默认情况下,OrbitControls会围绕目标物体的中心进行轨道运动。如果目标物体是一个三维对象,那么默认的轨道就是该对象的中心。而在这个案例中,我们使用了const control = new OrbitControls(camera, renderer.domElement);控制器将会围绕原点(0,0,0)进行旋转,如果此时你设置相机也为原点的话,或者不设置相机位置,那么场景将会旋转不起来,不相信的话,自己可以尝试下。

1.3 效果

请添加图片描述


二、球形模式

在球形模式下,我们只用一张全景图即可了。

2.1 代码

代码如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        html,
        body {
            margin: 0;
            padding: 0;
            width: 100%;
            height: 100%;
        }
    </style>
</head>

<body>
    <script type="module">
        // 倒入轨道控制器
        import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
        import * as THREE from 'three';

        // 创建场景
        const scene = new THREE.Scene();
        // 创建相机
        const camera = new THREE.PerspectiveCamera( // 透视相机
            75, // 视角 角度数
            window.innerWidth / window.innerHeight, // 宽高比 占据屏幕
            0.1, // 近平面(相机最近能看到物体)
            1000, // 远平面(相机最远能看到物体)
        );
        camera.position.set(0, 0, 30);
        // 创建渲染器
        const renderer = new THREE.WebGLRenderer({
            antialias: true, // 抗锯齿
        });

        // 设置渲染器宽高
        renderer.setSize(window.innerWidth, window.innerHeight);
        // renderer(渲染器)的dom元素添加到我们的HTML文档中
        document.body.appendChild(renderer.domElement);


        // 控制器
        const control = new OrbitControls(camera, renderer.domElement);
        // 开启阻尼惯性,默认值为0.05
        control.enableDamping = true;

        // 贴图
        const texture = new THREE.TextureLoader().load('../assets/livingRoom.jpg');
        // 创建球体
        const sphereGeometry  = new THREE.SphereGeometry(16, 32, 32);
        const sphereMaterial = new THREE.MeshBasicMaterial({
            map: texture
        });
        const sphere = new THREE.Mesh(sphereGeometry, sphereMaterial);
        sphere.geometry.scale(12,12,-12);
        scene.add(sphere);
        
        // 渲染循环动画
        function animate() {
            // 在这里我们创建了一个使渲染器能够在每次屏幕刷新时对场景进行绘制的循环(在大多数屏幕上,刷新率一般是60次/秒)
            requestAnimationFrame(animate);
            // 更新控制器。如果没在动画里加上,那必须在摄像机的变换发生任何手动改变后调用
            control.update();
            renderer.render(scene, camera);
        };

        // 执行动画
        animate();
    </script>
</body>

</html>

2.2 代码解析

  1. 我们发现球体的就一张全景图就可以了,但是它还是要进行sphere.geometry.scale(12,12,-12);,如果没有设置这个的话如下图效果:
    请添加图片描述
    就会在球外观看,所以我们必须得设置这个属性。

2.3 效果

我们设置了z轴的负数缩放这使得我们在球体里去观察,效果如下:
请添加图片描述
可以看到跟立方体的效果基本上是一致的。

在学习的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。

标签:Threejs,12,const,THREE,texture,案例,renderer,new,看房
From: https://blog.csdn.net/weixin_44103733/article/details/142310647

相关文章

  • 【C++】数组案例:考试成绩统计
    要求:一个简单的二维数组使用案例,用于统计三个学生在三门课程中的考试成绩总分。代码要点:二维数组声明和初始化:intscore[3][3]:声明一个3行3列的二维数组,用于存储三个学生的三门课程成绩。初始化列表:为数组的每个元素赋初始值。总分统计:外层循环:遍历每个学生(行)。......
  • Dockerfile的详解与案例
    《Dockerfile详解与案例》一、Dockerfile简介Dockerfile是一个用来构建Docker镜像的文本文件,它包含了一系列指令,用于描述如何创建一个Docker镜像。通过Dockerfile,你可以定义镜像的基础环境、安装软件包、设置环境变量等操作,从而实现快速、可重复地构建容器镜像。......
  • 一文通Maven :入门配置详解与最佳实践、进阶技巧、项目案例分析、常用依赖
    Maven是我们开发中的基础工具之一,尤为重要。它不仅仅是构建工具,还是项目管理、依赖管理、插件管理的强大平台。本文将通过对Maven配置进行详尽分析,并结合实际项目案例,讨论如何有效配置和优化Maven,提升项目的管理和开发效率。一、Maven基础概念与配置结构Maven的核心......
  • 广州浮点ANSA软件许可优化实施成功案例
    浮动版ANSA软件许可证优化、降本增效实施行业:汽车制造实施软件:ANSA软件一、背景概述1.项目背景ANSA是一款用于前处理的工程仿真软件,广泛应用于汽车、航空航天等高端制造行业,用于构建和优化有限元模型。某大型汽车制造企业依赖ANSA进行车辆设计的仿真前处理工作,以加快其研发流......
  • linux 操作系统下的dhclient命令介绍和案例使用
    linux操作系统下的dhclient命令介绍和案例使用dhclient是Linux系统中用于动态主机配置协议(DHCP)客户端的命令。它的主要功能是从DHCP服务器获取网络配置,包括IP地址、子网掩码、默认网关和DNS服务器等信息dhclient命令概述基本语法bashdhclient[选项][网络接口......
  • 七、Scrapy框架-案例1
    1.豆瓣民谣Top排名爬取1.1构建scrapy项目安装Scrapy库pipinstallscrapy创建Scrapy项目通过cmd进入命令窗口,执行命令scrapystartprojectxxxx(xxxx为scrapy项目名),创建scrapy项目。scrapystartprojectdouban_spider2024创建爬虫项目执行scrapygenspider......
  • node.js应用案例
    node.js广泛应用于构建高性能网络和服务器端应用程序,包括:web开发(web服务器、实时聊天)流媒体服务(视频和音频流媒体)微服务架构(服务发现、消息传递)数据处理和分析(数据收集和处理、机器学习)物联网(传感器数据收集、设备连接)自动化和集成(持续集成、开发运营)游戏开发区块链桌面应用程......
  • 手动部署第一个 Servlet 案例
       一般不会手动部署应用,这篇文章适合应付学校老师布置的作业一.准备工作   1.首先下载一个Tomcat。   2.打开下载的Tomcat文件夹,可以看到以下文件列表。    主要讲解一下这几个文件夹的作用:    bin:放Tomcat启动、关闭等命令行工......
  • springboot+vue云农门户经典案例子系统【开题+程序+论文】
    系统程序文件列表开题报告内容研究背景随着信息技术的飞速发展,云计算、大数据与物联网等前沿技术在农业领域的深度融合,正逐步改变着传统农业的面貌。云农门户作为现代农业信息化的重要载体,旨在通过集成化、智能化的服务平台,为农民、农场主及农业相关从业者提供便捷、高效的......
  • 案例269购物商城网站的设计与实现[SSM+MySQL+Vue]
    目录系统展示项目背景系统设计总结系统展示项目背景网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。计算机软件可以针对不同行业的营业特点以及管理需求,设置不同的功能,可以符合各个行......