位置: IT常识 - 正文

基于Three.js实现酷炫3D地图效果(three.js gui)

编辑:rootadmin
这篇文章主要为大家详细介绍了如何利用Three.js实现酷炫3D地图的效果,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以尝试一下 目录

推荐整理分享基于Three.js实现酷炫3D地图效果(three.js gui),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:three. js,three. js,three.js例子,three.js bim,three. js,three.js入门指南,three. js,three.js入门指南,内容如对您有帮助,希望把文章链接给更多的朋友!

实现效果前言使用1.修改整体的背景图可以使用颜色或用贴图改材质2.取消地图上柱状图显示3.更换地图、更换省份、市4.修改相机的视角,页面展示的远近角度5.修改地图的颜色及贴图6.关闭一些特效7.页面适配和在vue2版本中使用实现效果

前言

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

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

方法:

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

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

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

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

基于Three.js实现酷炫3D地图效果(three.js gui)

更换很简单,就是如图位置修改引入的地图文件即可,但是修改之后需要注意的是,地图中心点改变了,比如现在将地图展示由金华市改为台州市,那么还需要修改@/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中引入的给地图做材质estartconst 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.RepeatWrappingtextureMap.wrapT = texturefxMap.wrapT = THREE.RepeatWrappingtextureMap.flipY = texturefxMap.flipY = falsetextureMap.rotation = texturefxMap.rotation = THREE.MathUtils.degToRad(45)const scale = 0.1textureMap.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注册下即可

到此这篇关于基于Three.js实现酷炫3D地图效果的文章就介绍到这了,更多相关Three.js 3D地图内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!

本文链接地址:https://www.jiuchutong.com/zhishi/309224.html 转载请保留说明!

上一篇:二、python基本数据类型(python提供的3个基本数字类型)

下一篇:帝国cms怎么增加专题(帝国cms怎么增加子栏目)

  • 最实用的网络推广四种方法(哪种网络推广效果好)

    最实用的网络推广四种方法(哪种网络推广效果好)

  • 华为麦芒9是否有红外功能(华为麦芒9是否已停产了)

    华为麦芒9是否有红外功能(华为麦芒9是否已停产了)

  • 抖音如何把字消除看全屏(怎样消去抖音上的字)

    抖音如何把字消除看全屏(怎样消去抖音上的字)

  • 惠普1005和m1005的区别(惠普m1005和1005w)

    惠普1005和m1005的区别(惠普m1005和1005w)

  • c语言中d%是什意思(c语言中是什么意思)

    c语言中d%是什意思(c语言中是什么意思)

  • 华为荣耀20Pro手机如何自制图标(华为荣耀20PRO手机充电器原配)

    华为荣耀20Pro手机如何自制图标(华为荣耀20PRO手机充电器原配)

  • 淘宝月卡待补充什么意思(淘宝月卡显示待补充)

    淘宝月卡待补充什么意思(淘宝月卡显示待补充)

  • 华为freebuds3充电要多久(华为freebuds3充电指示灯绿色)

    华为freebuds3充电要多久(华为freebuds3充电指示灯绿色)

  • 微软的聊天机器人叫什么(微软聊天机器人tay上线不到一天就紧急下线了)

    微软的聊天机器人叫什么(微软聊天机器人tay上线不到一天就紧急下线了)

  • 苹果屏幕部分区域失效(苹果屏幕部分区域失效开不了锁怎么办)

    苹果屏幕部分区域失效(苹果屏幕部分区域失效开不了锁怎么办)

  • 华为手机如何添加天气到桌面(华为手机如何添加饭卡)

    华为手机如何添加天气到桌面(华为手机如何添加饭卡)

  • 电脑可以看电视频道吗(电脑可以看电视剧的软件)

    电脑可以看电视频道吗(电脑可以看电视剧的软件)

  • 路由器哪几个灯闪是正常的(路由器哪几个灯亮正常能正常上网)

    路由器哪几个灯闪是正常的(路由器哪几个灯亮正常能正常上网)

  • 微博如何设置不让别人看(微博如何设置不让别人搜索到)

    微博如何设置不让别人看(微博如何设置不让别人搜索到)

  • vue怎么挪动贴纸位置(vue 粘贴)

    vue怎么挪动贴纸位置(vue 粘贴)

  • 如何关闭airpods(如何关闭airpods pro语音播报)

    如何关闭airpods(如何关闭airpods pro语音播报)

  • 360小水滴怎么恢复出厂设置(360小水滴怎么恢复出厂设置视频)

    360小水滴怎么恢复出厂设置(360小水滴怎么恢复出厂设置视频)

  • 快手商品管理审核多久(快手商品审核岗)

    快手商品管理审核多久(快手商品审核岗)

  • 华为nova3i上市时间(华为nova3i上市时间多久)

    华为nova3i上市时间(华为nova3i上市时间多久)

  • 抖音审核中是怎么回事(抖音审核中怎么办)

    抖音审核中是怎么回事(抖音审核中怎么办)

  • 斗鱼实名认证怎么取消(斗鱼实名认证怎么解除绑定)

    斗鱼实名认证怎么取消(斗鱼实名认证怎么解除绑定)

  • 苹果电脑如何提高音质?提升Mac音质效果教程介绍(苹果电脑如何提高网速)

    苹果电脑如何提高音质?提升Mac音质效果教程介绍(苹果电脑如何提高网速)

  • 房地产企业土地增值税
  • 申报社保不报个人账户
  • 销售净收入咋算
  • 专家住宿费入什么科目
  • 坏账准备计入营业收入如何报年报
  • 应收款和应付款对抵
  • 零星小额交易要交税吗
  • 小规模增值税税率表
  • 接受捐赠材料需要交税吗
  • 房地产增值税怎么算举例说明
  • 商业汇票的申请人是谁
  • 转让股权取得的收益是调增还是调减
  • 外币报表折算差额在会计报表中应作为
  • 客户把发票弄丢了,红冲重新开了会有什么风险
  • 开票方与受票方的区别
  • 哪些发票可以抵扣成本
  • 关联企业股份
  • 河道工程维护管理费征收
  • 增值税发票提示文件不匹配
  • 资产类账户的期末余额计算公式
  • 当月增加的投资性房地产当月提折旧吗
  • 收到有误的增值税专用发票的怎么处理
  • 1697510217
  • 苹果手机m开头的序列号代表什么
  • won11检测
  • 华为鸿蒙系统如何刷机
  • 信息化生产力是指什么
  • 企业购入一批材料卖价5万元
  • 购买监控设备费用谁出
  • php写json
  • win10下载的软件打不开
  • thinkphp d
  • 黑暗的树荫
  • phalcon model在插入或更新时会自动验证非空字段的解决办法
  • df 命令执行显示不出来
  • 普通动产和特殊动产如何分类
  • phpcms教程
  • Spring(三)-AOP
  • dede标签的使用
  • 企业正常性停产什么意思
  • 工会经费发放奖励个税处理
  • 零税率与免税有关系吗
  • SQL Server Native Client下载 SQL Server Native Client安装方法
  • MySQL中distinct与group by语句的一些比较及用法讲解
  • 什么情况下要缴纳房产税
  • 查账征收和核定征收有什么区别
  • 固定资产登记在三栏明细账可以吗
  • 到银行提取备用金
  • 过路费发票可以抵扣进项税吗
  • 股东出资怎么写
  • 支付借款利息需要交税吗
  • 商业承兑过期后可以退回吗
  • 收到汇算清缴后怎么做账
  • 税收返还如何做账
  • 没有发票的费用怎么报销
  • 固定资产清理期末
  • sql server?
  • sql语句的调优
  • mysql批量更新多条数据
  • 怎么提高windows7性能
  • app隐藏库
  • xp启动时间长
  • linux如何用
  • 创建自己百度百科
  • [置顶] 《精神怪谈》 后续起点
  • jquery判断div是否显示
  • perl变量后拼接字符串
  • js控制display属性
  • ansible客户端需要装python
  • 微信假消息
  • 如何安装python环境安装包
  • jquery操作元素样式
  • 江西烟草公司局长
  • 广东税务局查验
  • 宣城市有什么好玩的景区
  • 深圳国税电子税务局官网
  • 上海嘉定小学入学积分
  • uk怎么添加发票
  • 我们是小规模纳税人,有个人所得税代扣代缴的业务吗
  • 福建福州有几个火车站
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设