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

  • 进项税转出包括什么
  • 企业自产的产品转为自用
  • 会计一般什么时候考试
  • 以前年度多计收入多交税怎么处理
  • 收到退回的款项怎么做分录
  • 厂区地面硬化属于土建还是市政
  • 个人所得税是全部收入吗
  • 定额扣除个税什么意思
  • 发票进项和销项差一个字
  • 冲红退税流程
  • 互联网公司成本包括哪些
  • 营业外收入怎么结转到本年利润
  • 配件的出口是否可以免抵退?
  • 商业企业能否计税
  • 餐饮无票收入怎么做账
  • 佣金支出和手续费税前扣除相关政策依据及会计处理
  • 公益捐赠税前扣除凭证
  • 企业公车私用如何处理
  • 汽油费能计入办公费吗
  • 存货周转天数一般在多少为合适
  • 小规模企业如何
  • 案例分析两个分公司转资金怎么做账?
  • 加油款可以开专用发票吗
  • 现金流量表编制依据和方法
  • 增值税电子普通发票开具规定
  • 普票开错了能退税吗
  • 营改增后无形资产增加的是
  • 母公司并购子公司需要股东会决议吗
  • 快递公司怎么纳入社保
  • 公司公章丢失登报后又找到了
  • 公司代缴个人社保费怎么做账
  • 待抵扣进项税额是二级还是三级
  • 事业单位的费用
  • 销售原材料计入哪里
  • 车间租金计入什么会计科目
  • 收到融资款如何做账
  • 收到某公司的钱的会计分录
  • 内部员工租房租金合法吗
  • 运输发票符合什么要求
  • 工作组只能看到自己
  • onekey.exe是什么
  • php-fig
  • 怎么检查当年的核酸结果
  • 劳务派遣企业简易征收管理办法
  • uniapp自定义tabbar功能
  • php实现文件上传需要使用哪个全局变量
  • SpringBoot+Vue实现简单用户管理平台第一篇(后端接口设计)
  • 万字长文护国安是谁写的
  • 房地产停车场属于公共配套设施吗
  • 小规模餐饮业如何征税
  • 城镇土地使用税征收标准及计算方法
  • 社保局申报工伤款多久能下
  • C++ 使用dll路径不在当前路径时如何调用
  • 一般纳税人年收入500万交多少税
  • 个人社保的缴纳时间
  • 一张记账凭证写不下时合计怎么写
  • sqlserver存储过程语法
  • 会计上视同销售的八种情况是哪些?
  • 厂区地面硬化施工方案
  • 小规模纳税人专票税率是多少
  • 异地预缴的企业所得税
  • 土地增值税的预征和清算
  • 包装袋制版费
  • 农民专业合作社属于什么经济类型
  • 建筑业确认收入的条件
  • 固定资产专票可以不抵扣吗
  • mysql语句的注释符号
  • windows pe无法启动怎么办
  • fedora使用
  • mac电脑虚拟机怎么安装
  • windows不认u盘
  • 手把手教你如何退税
  • 如何切换shell
  • python怎么样学
  • unity3ds
  • Django中login_required装饰器的深入介绍
  • js对象用法
  • 在文件中偏移量为
  • javascript编程基础
  • 累计预扣预缴税额
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设