位置: 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怎么增加子栏目)

  • 核定征收的个体户可以开专票吗
  • 视同销售的增值税怎么申报
  • 资产总额的季度怎么算
  • 预缴增值税附加税费申报明细表
  • 年末计提坏账准备金额怎么算
  • 购买的固定资产什么时候折旧
  • 退货一定要卖家同意吗
  • 报税利润表的第二季度本期金额本年累计金额是什么
  • 工资结算汇总表会计科目
  • 房地产企业拆迁补偿契税政策
  • 偶然所得个税怎么计算公式
  • 红字撤销需要带什么去税务局
  • 资产减值损失转回的账务处理
  • 自己做的房子可以办房产证吗
  • 公司工资发放错误怎么退回
  • 建筑业统一发票可以抵扣吗
  • 实收资本未到位可以注销吗?
  • 入库前的挑选整理费用计入采购成本吗
  • 收到技术服务费计入什么科目
  • 契税和车辆购置税的异同
  • 增值税进项税抵扣规定
  • 预付油卡怎么入账
  • 补开去年的发票怎么结转成本?
  • 企业支出的资产包括哪些
  • 计提固定资产会计科目
  • 保户储金科目属于保险公司的什么科目
  • 资金筹集业务的账务处理重点笔记
  • 上市公司股票下跌可以减持吗
  • mac 的系统
  • win10更新21h1后很卡
  • 农产品成本法计算抵扣
  • win10系统如何设置开机启动软件
  • vue2editor
  • 系统托盘图标禁用
  • PHP:Memcached::getVersion()的用法_Memcached类
  • 财务费用属于期间汇转账户吗
  • ekb install
  • 房地产开发间接费
  • php对数组进行排序
  • php分层架构
  • 前端页面设计
  • mysql的排序规则
  • ai运行环境
  • load命令怎么用
  • 存货盘点会计分录怎么做
  • 以股权抵债的会计分录
  • 上级拔入资金
  • 财务报表不申报可以领票吗
  • 本月应付电费400元,下月支付
  • 工商年报资产状况纳税总额怎么填
  • 发票清单用什么纸打印出来
  • 企业转让股权如何缴纳企业所得税
  • 歌咏比赛服装费用规定标准最新
  • sqlserver2008触发器语法
  • 出口货物退运已补税(未退税)证明
  • 装修费还没摊销怎么办
  • 每月扣除的公积金怎么查
  • 银行承兑汇票背面怎么填写
  • 存货类明细分类账一般采用
  • 独立核算 单独核算
  • 律师事务所日语助理
  • 其他应付款长期挂账违反什么规定
  • 企业的案例分析报告
  • sql server查询数据库大小
  • win8系统电脑没声音怎么办
  • win双系统怎么切换
  • centos7 dns
  • window10如何解除密码
  • opengl颜色混合模式
  • 一行指令
  • node.js快速入门
  • 消耗cpu的软件
  • 一个简单的合并单元
  • jquery 选择
  • 增值税一般纳税人和小规模纳税人的区别
  • 银行关联方认定标准是什么
  • 广东省电子学校
  • 增值税留底抵欠如何处理
  • 浙江网上税务局申报
  • 出口突尼斯提供哪些清关单据
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设