threeJS嵌入可交互的普通页面

news2025/8/12 9:58:20
  • 效果图:

        1.这是我将一个地图当作地面,外面再包一个天空盒就更好看了

         2.上面的例子可能不够直观,下面这个例子是嵌入的bilibili官网,嵌入的网页内容可以正常交互

  • 关键
    关键是用到了CSS3DRenderer渲染器。CSS3DRenderer仅仅关注普通的DOM元素,这些元素被包含到了特殊的对象中(CSS3DObject或者CSS3DSprite),然后被加入到场景图中。
  • 代码(是第一个地图的例子哦)
    <!--
     * @Author: WJT
     * @Date: 2022-11-16 16:56:42
     * @Description: file content
    -->
    
    <template>
      <div class="webgl-container">
        <div id="webglDom"
             ref="webglDom"></div>
      </div>
    </template>
    
    <script>
    import * as THREE from 'three'
    // import { TrackballControls } from 'three/examples/jsm/controls/TrackballControls.js'
    import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js'
    import { CSS3DRenderer, CSS3DObject } from 'three/examples/jsm/renderers/CSS3DRenderer.js'
    
    export default {
      name: 'threeJSMap',
      data () {
        return {
          controls: null,
          camera: null,
          glScene: null,
          cssScene: null,
          cssRenderer: null
        }
      },
      mounted () {
        this.initialize()
      },
      methods: {
        createCssRenderer () {
          const cssRenderer = new CSS3DRenderer()
    
          cssRenderer.setSize(window.innerWidth, window.innerHeight)
    
          cssRenderer.domElement.style.position = 'absolute'
          cssRenderer.domElement.style.top = 0
    
          return cssRenderer
        },
        createCssObject (w, h, position, rotation, url) {
          const iframe = document.createElement('iframe')
          iframe.src = 'http://localhost:8081/demo-web/#/map' // 写你自己要嵌入的网页地址即可
          iframe.style.width = w + 'px'
          iframe.style.height = h + 'px'
          iframe.style.border = '0px'
          const cssObject = new CSS3DObject(iframe)
    
          cssObject.position.x = position.x
          cssObject.position.y = position.y
          cssObject.position.z = position.z
    
          cssObject.rotation.x = rotation.x
          cssObject.rotation.y = rotation.y
          cssObject.rotation.z = rotation.z
          return cssObject
        },
        create3dPage (w, h, position, rotation, url) {
          const cssObject = this.createCssObject(
            w, h,
            position,
            rotation,
            url)
          this.cssScene.add(cssObject)
        },
        initialize () {
          this.camera = new THREE.PerspectiveCamera(
            45,
            window.innerWidth / window.innerHeight,
            1,
            10000)
    
          this.camera.position.set(0, 30, 100)
    
          this.cssRenderer = this.createCssRenderer()
    
          document.getElementById('webglDom').appendChild(this.cssRenderer.domElement)
    
          this.controls = new OrbitControls(this.camera, this.cssRenderer.domElement)
          // 定义当平移的时候摄像机的位置将如何移动。如果为true,摄像机将在屏幕空间内平移。 否则,摄像机将在与摄像机向上方向垂直的平面中平移。
          this.controls.screenSpacePanning = true
          this.controls.minDistance = 10
          this.controls.maxDistance = 500
          this.controls.maxPolarAngle = Math.PI / 2
    
          this.glScene = new THREE.Scene()
          this.cssScene = new THREE.Scene()
    
          const ambientLight = new THREE.AmbientLight(0x555555)
          this.glScene.add(ambientLight)
    
          const directionalLight = new THREE.DirectionalLight(0xffffff)
          directionalLight.position.set(-0.5, 0.5, -1.5).normalize()
          this.glScene.add(directionalLight)
    
          this.create3dPage(
            1000, 1000,
            new THREE.Vector3(0, 0, 0),
            new THREE.Vector3(-90 * Math.PI / 180, 0, 0),
            'http://localhost:8081/demo-web/#/map')
    
          this.update()
        },
        update () {
          this.controls.update()
    
          this.cssRenderer.render(this.cssScene, this.camera)
    
          requestAnimationFrame(this.update)
        }
      }
    }
    </script>
    
    <style scoped>
    #webglDom,
    .webgl-container {
      width: 100%;
      height: 100%;
      overflow: hidden;
    }
    </style>
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/15162.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【计算机网络】无线局域网详解

文章目录无线局域网IEEE802.11IEEE802.11的MAC帧头有固定基础设施的无线局域网无固定基础设施无线局域网的自组织网络VLAN传统局域网的局限VLAN虚拟局域网基本概念virtual local area networkVLAN 实现&#x1f343;博主昵称&#xff1a;一拳必胜客 &#x1f338;博主寄语&…

数据增强方法汇总

数据增强1.有监督数据增强1.1 单样本数据增强augly安装augly使用方法1.2 多样本数据增强1.2.1 SMOTEpython实现1.2.2 SamplePairingpython实现1.2.3 mixuppython实现2.无监督数据增强2.1 GAN2.2 Diffunsion2.3 Autoaugmentation1.有监督数据增强 1.1 单样本数据增强 augly安装…

MongoDB(4.0.9)数据从win迁移到linux

服务器从win迁移导了linux上了&#xff0c;对应的md里面的数据也需要做全量迁移&#xff0c;在网上找了一大堆方案&#xff0c;不是缺胳膊就是少腿&#xff0c;没有一个是完整的&#xff0c;最终加以分析和整理&#xff0c;得出这套方案&#xff0c;希望对你有用 第一步&#…

Java集合框架【二容器(Collection)[Vector容器类]】

文章目录三 Vector容器类3.5 Vector容器类3.5.1 Vector的使用3.5.2 Stack容器3.5.3.1 Stack容器介绍3.5.3.2 操作栈方法Stack的使用案例三 Vector容器类 3.5 Vector容器类 Vector底层是用数组实现的&#xff0c;相关的方法都加了同步检查&#xff0c;因此“线程安全&#xff…

D. Divide and Sum(组合数学)

Problem - 1445D - Codeforces 题意: 给你一个长度为2n的数组a。考虑将数组a划分为两个子序列p和q&#xff0c;每个子序列的长度为n&#xff08;数组a的每个元素应该正好在一个子序列中&#xff1a;要么在p中&#xff0c;要么在q中&#xff09;。 让我们以非递减顺序对p进行排…

matplotlib笔记

一、安装matplotlib总是超时导致失败 鉴于公司内网服务器上直接pip install matplotlib容易超时退出的问题&#xff0c;可以采用下面的方法解决&#xff1a; 方法一&#xff1a;指定更新源 pip install -i Simple Index matplotlib3.2.2 注意选择3.2.2&#xff0c;因为最新版本…

AP22615AWU-7、SLG5NT1758V配电开关 驱动器 IC资料

AP22615配电开关具有输出过压保护 (OVP) 功能&#xff0c;设计用于USB和其他热插拔应用。该器件提供输出过压保护&#xff0c;可保护这些应用的系统。具有输出过压保护、反向电流阻断、过流、过热和短路保护功能。其他功能包括受控上升时间和欠压锁定功能。 AP22615具有可调限…

【Java篇】备战面试——你真的了解“基本数据类型”吗?

目录 基本介绍&#xff1a; 整数类型 浮点类型 布尔类型和char类型 自动类型转换 数据类型转换必须满足如下规则&#xff1a; 基本介绍&#xff1a; Java是一门强类型语言&#xff0c;这就意味着必须为每一个变量声明一种类型。Java为我们提供了八种基本类…

[附源码]计算机毕业设计JAVA归元种子销售管理系统

[附源码]计算机毕业设计JAVA归元种子销售管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM my…

【毕业设计】大数据分析的航空公司客户价值分析 - python

文章目录0 前言1 数据分析背景2 分析策略2.1 航空公司客户价值分析的LRFMC模型2.2 数据2.3 分析模型3 开始分析3.1 数据预处理3.1.1 数据预览3.1.2 数据清洗3.2 变量构建3.3 建模分析4 数据分析结论4.1 整体结论4.2 重要保持客户4.3 重要挽留客户4.4 一般客户与低价值客户5 最后…

Cadence Allegro PCB设计88问解析(十七) 之 Allegro中焊盘的全连接和花焊盘

一个学习信号完整性仿真的layout工程师 上一篇文章和大家分享了关于铜皮shape的一些基本操作。我们进行铺铜是为了连接网络(焊盘、过孔等)&#xff0c;一般都是GND或者电源网络。Shape和走线还是不一样的&#xff0c;走线直接从焊盘或者过孔等直接拉出一根layout&#xff0c;但…

【MySQL数据库笔记 - 进阶篇】(三)SQL优化

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?spm1011.2415.3001.5343 &#x1f4da;专栏地址&#xff1a;暂定 &#x1f4dd;视频地址&#xff1a;黑马程序员 MySQL数据库入门到精通 &#x1f4e3;专栏定位&#xff1a;这个专栏我将会整理 B 站黑马程序员的 MySQL…

LeetCode[剑指Offer54]二叉搜索树的第K大节点

难度&#xff1a;简单 题目&#xff1a; 给定一棵二叉搜索树&#xff0c;请找出其中第 k 大的节点的值。 示例 1: 输入: root [3,1,4,null,2], k 13/ \1 4\2 输出: 4 示例 2: 输入: root [5,3,6,2,4,null,null,1], k 35/ \3 6/ \2 4/1 输出: 4 限制&#xff1a; …

[附源码]java毕业设计旅游网站

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Nodejs编写接口

编写接口 1.自定义路由模块 const expressrequire(express) const routerexpress.Router()// 挂载对应的路由 router.get(/get,(req,res)>{// 通过req.query获取客户端通过查询字符串&#xff0c;发送到服务器的数据const queryreq.query// 调用res.send()方法&#xff0c…

集成学习-Bagging和Boosting算法

文章目录集成学习Bagging随机森林BostingAdaboostGBDTXGBoost集成学习 集成学习&#xff08;ensemble learning&#xff09;博采众家之长&#xff0c;通过构建并结合多个学习器来完成学习任务。“三个臭皮匠顶个诸葛亮”&#xff0c;一个学习器&#xff08;分类器、回归器&…

【微服务】SpringCloud微服务续约源码解析

目录 一、前言 二、客户端续约 1、入口 1.1、构造初始化 1.2、initScheduledTasks() 调度执行心跳任务 2、TimedSupervisorTask组件 2.1、构造初始化 2.2、TimedSupervisorTask#run()任务逻辑 3、心跳任务 3.1、HeartbeatThread私有内部类 3.2、发送心跳 3、发送心…

使用OpenAPI提升网关安全的开源软件,诚邀小伙伴参与

看过我博客的人都知道&#xff0c;我们是一家推广OpenAPI的企业。 OpenAPI是一种用于定义API结构的规范&#xff0c;在Java里我们可以使用swagger进行自动生成。其他语言也可以&#xff08;Golang等&#xff09;。通过这种对开发人员零成本的工具&#xff0c;我们可以高效的获…

典型的偏微分方程数值解法

马上要参加亚太杯啦&#xff0c;听说今年亚太杯有经典的物理题&#xff0c;没什么好说的&#xff0c;盘它&#xff01; 偏微分方程的数值解十分重要 椭圆型偏微分方程&#xff08;不含时&#xff09; 数值解法 二维拉普拉斯方程 例 边界条件 import numpy as np import mat…

教你如何使用云服务器搭建我的世界Minecraft服务器(超级简单-10分钟完成)

一个人玩游戏没啥意思&#xff0c;和朋友一块联机呢&#xff0c;距离太远&#xff0c;家庭局域网宽带又没有公网ip&#xff0c;你的朋友没办法与你联机&#xff0c;然而你只需要一台服务器即可搞定了&#xff1b;但是很多用户没没接触过相关的内容&#xff0c;具体的该怎么操作…