当前位置: 首页 > news >正文

【threejs】可视化大屏酷炫3D地图附源码

目录

效果如下: 

1. 前言:

2. 使用:

1.修改整体的背景图可以使用颜色或用贴图改材质​编辑

 方法:

2. 取消地图上柱状图显示

3.更换地图、更换省份、市 

4.修改相机的视角,页面展示的远近角度

 5.修改地图的颜色及贴图

6.关闭一些特效

7.页面适配和在vue2版本中使用

3. 源码


效果如下: 

 


1. 前言:

本文主要说明使用threejs技巧,来定制适合项目需求的样式,源码将在本文最后附上gitee地址。


2. 使用:

1.修改整体的背景图可以使用颜色或用贴图改材质

 

 

 方法:

只需修改createChinaMap()方法中的color属性即可,注意一共要修改4个color,其中有两个是地图边界线的颜色。也可以使用贴图,


 

2. 取消地图上柱状图显示

create钩子函数里注释掉// this.createBar()即可

 


3.更换地图、更换省份、市 

 

 

更换很简单,就是如图位置修改引入的地图文件即可,但是修改之后需要注意的是,地图中心点改变了,比如现在将地图展示由金华市改为台州市,那么还需要修改@/comfig文件下的配置,如下图所示:

修改之后的效果如下:

 

 


4.修改相机的视角,页面展示的远近角度


 

 5.修改地图的颜色及贴图

     let city = new BaseMap(this, {
        data: data,
        // topFaceMaterial: material.getMaterial(),
        topFaceMaterial: new THREE.MeshPhongMaterial({
          color: "red", //想要的颜色
          emissive: 0x072534,
          transparent: true,
          opacity: 1,
        }),
        sideMaterial: sideMaterial.getMaterial(),
        renderOrder: 6,
        depth: config.cityName ? 0.3 : 3,
      })

 如果你想引入贴图,这样会更好看,可以使用以下方法:

// 在index.js中引入的给地图做材质estart
const texture = new THREE.TextureLoader()
const textureMap = texture.load(require('./data/map/gz-map.jpg'))
const texturefxMap = texture.load(require('./data/map/gz-map-fx.jpg'))
textureMap.wrapS = texturefxMap.wrapS = THREE.RepeatWrapping
textureMap.wrapT = texturefxMap.wrapT = THREE.RepeatWrapping
textureMap.flipY = texturefxMap.flipY = false
textureMap.rotation = texturefxMap.rotation = THREE.MathUtils.degToRad(45)
const scale = 0.1
textureMap.repeat.set(scale, scale)

然后

 let city = new BaseMap(this, {
        data: data,
        // topFaceMaterial: material.getMaterial(),
        topFaceMaterial: new THREE.MeshPhongMaterial({
           map: textureMap,//不要忘记这里使用贴图
          color: "red", //想要的颜色
          emissive: 0x072534,
          transparent: true,
          opacity: 1,
        }),
        sideMaterial: sideMaterial.getMaterial(),
        renderOrder: 6,
        depth: config.cityName ? 0.3 : 3,
      })

6.关闭一些特效

create中是所有方法的开关,在这里可以进行调试

 create () {
    // 添加雾
    this.scene.fog = new THREE.Fog(0x191919, 30, 70)
    this.getCenterPoint()
    this.createPlane()
    this.createChinaMap()
    this.createProvinceMap()
    this.createCityMap()
    this.createGrid()
    this.createLight()
    this.createRotateBorder()
    this.createLabel()
    this.createWall()
    // this.createBar()
    this.createParticles()
  }

7.页面适配和在vue2版本中使用

页面适配建议给这个地图使用绝对定位,样式代码可参考以下:

 width: 1920px;
  height: 1080px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

在vue2中使用:

npm 下载这个插件:@vue/composition-api
然后main.js注册下即可

3. 源码

以下是gitee下载地址,如果下载不了,可以评论区喊我一声,我给发邮箱~

https://gitee.com/a1543733438/3-d-visualization-mapicon-default.png?t=M85Bhttps://gitee.com/a1543733438/3-d-visualization-map

相关文章:

  • 安路FPGA学习备忘录
  • 目标检测算法——YOLOv5改进之结合MobileOne结构
  • Python之“诗词大会”游戏
  • MySQL:索引知识点盘点
  • 大神之路-起始篇 | 第9章.计算机科学导论之【程序设计语言】学习笔记
  • Python 的Tkinter包系列之四:对话框
  • 大神之路-起始篇 | 第8章.计算机科学导论之【数据算法】学习笔记
  • IDET变化检测模型
  • javascript基本语法(持续补充)
  • Spring Boot开发之Mybatis
  • 卷王杯 easy unserialize
  • 常见Web安全漏洞深入解析
  • 如何从一款单片机移植到另一款单片机
  • linux创建用户和组、授权、禁止root远程登录、限制SSH的IP登录
  • 10大开源的快速开发平台—架构师必看
  • golang 发送GET和POST示例
  • Java|序列化异常StreamCorruptedException的解决方法
  • react 代码优化(一) ——事件处理
  • Spring-boot 启动时碰到的错误
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • 产品三维模型在线预览
  • 如何进阶一名有竞争力的程序员?
  • 入手阿里云新服务器的部署NODE
  • 什么是Javascript函数节流?
  • 原生 js 实现移动端 Touch 滑动反弹
  • 大数据全解:定义、价值及挑战
  • #如何使用 Qt 5.6 在 Android 上启用 NFC
  • (39)STM32——FLASH闪存
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (undone) MIT6.824 Lecture1 笔记
  • (补充)IDEA项目结构
  • (差分)胡桃爱原石
  • (附源码)springboot码头作业管理系统 毕业设计 341654
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (四)TensorRT | 基于 GPU 端的 Python 推理
  • .NET Core 和 .NET Framework 中的 MEF2
  • .NET Framework 3.5中序列化成JSON数据及JSON数据的反序列化,以及jQuery的调用JSON
  • .NET Remoting学习笔记(三)信道
  • .net wcf memory gates checking failed
  • .Net多线程总结
  • .net反编译工具
  • ::什么意思
  • @PreAuthorize注解
  • [CF407E]k-d-sequence
  • [codevs1288] 埃及分数
  • [C语言][C++][时间复杂度详解分析]二分查找——杨氏矩阵查找数字详解!!!
  • [Docker]四.Docker部署nodejs项目,部署Mysql,部署Redis,部署Mongodb
  • [hive] 窗口函数 ROW_NUMBER()
  • [HNOI2015]实验比较
  • [IE编程] 如何获得IE版本号
  • [iOS]如何删除工程里面用cocoapods导入的第三方库
  • [javaSE] GUI(事件监听机制)
  • [JS入门到进阶] 哎,被vite小坑了一波,大家记得配置build.cssTarget为‘chrome61‘
  • [LeetCode][LCR190]加密运算——全加器的实现