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

  • 预缴增值税的销售额怎么填
  • 宁波财税网会计招聘
  • 公司的现金收入可以直接发工资吗
  • 冲回存货跌价准备所得税是调增还是调减
  • 国内增值税专用发票造假第一大案
  • 企业控股情况怎么填写
  • 社保怎样新增人员
  • 企业审计费入什么科目
  • 个人厂房租赁税率是多少
  • 在建工程在现金流量表中
  • 持有至到期投资是什么意思
  • 公司成立时代垫资合法吗
  • 公允价值变动损益借贷方向
  • 车辆购置税免税申报如何操作
  • 申请补贴费用怎么写
  • 多计提的应收账款如何调整
  • 固定资产忘了折旧有什么影响
  • 核定征收企业所得税能否享受税收优惠
  • 跨年了可以补去年的养老吗
  • 房产税计税依据房产原值怎么算
  • 一般纳税人从小规模纳税人取得专用发票
  • 价内税与价外税名词解释
  • 自然人税收管理扣缴端(原个税)申报实训
  • 公司控股的公司下子公司有哪些
  • 上月预提的费用怎么记账
  • 国家税务开票流程
  • 浏览器显示英语怎么设置成中文
  • php怎么读取txt
  • php_fileinfo作用
  • uniapp使用高德猎鹰服务
  • php7.1
  • 处理固定资产时的账务处理
  • 在Win2003(64位)中配置IIS6+PHP5.2.17+MySQL5.5的运行环境
  • 视同销售的行为
  • yolov3原理及代码解析
  • 累计折旧在贷方还是借方
  • vue 滚动条
  • iframe之间通信
  • cp命令使用
  • 租入厂房需做环保检测吗
  • php面试题目100及最佳答案
  • 原材料存货跌价准备会计分录
  • java中double是什么数据类型
  • SQLserver数据库的while附近有语法错误,应为AS
  • 酒店如何控制成本汇报怎么写
  • 销售费用专票能抵扣吗
  • 社保下个月扣款
  • 事业单位财政直接支付购置固定资产
  • 施工总包能分包土方吗
  • 开出去的发票没有进项发票怎么核算成本?
  • 收到商业汇票计什么科目
  • 今年缴纳上年的税收滞纳金
  • 民办非企业单位什么意思
  • 企业汇算清缴需要提供什么资料
  • 发票限额如何限定
  • 百旺购货方红字信息表怎么开具
  • 鉴证咨询服务费可以抵扣吗
  • 收到货款就必须付货款吗
  • 税控盘费用抵扣怎么申报什么表怎么说什么表怎么填报
  • 发生费用未取得发票
  • sql wind
  • Ubuntu 14.04/14.10如何安装记账软件HomeBank?
  • centos 安装chia
  • xp电脑网络连接配置异常怎么办
  • mac safari浏览器翻译功能
  • centos6启动服务的命令
  • 举例说明linux的主要应用领域
  • linux操作系统配置网络
  • linux用什么版本
  • javascript闭包优缺点
  • css一个页面跳转到另一页面
  • shell echo-e
  • cmd替换文件命令
  • javascript声明变量的语句
  • linux c 线程池
  • 全国企业信用信息系统网官网
  • 房产契税退税在哪里办理
  • 耕地建仓库属于违规
  • 所属税务局怎么填写
  • 山东税务师协会官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设