位置: IT常识 - 正文

【THREE.JS学习(3)】使用THREEJS加载GeoJSON地图数据(three.js 教程)

编辑:rootadmin
【THREE.JS学习(3)】使用THREEJS加载GeoJSON地图数据

推荐整理分享【THREE.JS学习(3)】使用THREEJS加载GeoJSON地图数据(three.js 教程),希望有所帮助,仅作参考,欢迎阅读内容。

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

本文接着系列文章(2)进行介绍,以VUE2为开发框架,该文涉及代码存放在HelloWorld.vue中。

相较于上一篇文章对div命名class等,该文简洁许多。

<template><div></div></template>

接着引入核心库

import * as THREE from "three"import {OrbitControls} from "three/examples/jsm/controls/OrbitControls"import * as d3 from "d3"import Stats from "three/examples/jsm/libs/stats.module.js";

其中,{OrbitControls}为控制器,加载后可以通过鼠标来移动加载数据的方向、放缩等

Three.js中的坐标系是以单位为米(m)的坐标系,而在地理数据中,如Geojson使用的是经纬度作为坐标系,所以在使用、加载的过程中需要对数据进行坐标转换,才能够正确的显示地理数据。

而D3.js提供了投影函数能够将Geojson中的经纬度转换为目标格式的数据。

//安装D3.jsnpm install d3

下面的代码展示了使用D3.js将经纬度数据转化为Three.js中的坐标系

//使用墨卡托投影var projection = d3.geoMercator()    //地图投影的中心位置.center([0, 0])    //地图投影的偏移量.translate([0, 0]).scale(1);var path = d3.geoPath().projection(projection);var coords = [-122.4194, 37.7749]; // 经纬度坐标var point = projection(coords); // 将经纬度转换为 Three.js 中的坐标系

{Stats}可以创建一个性能监测器,并将其显示在页面中。

【THREE.JS学习(3)】使用THREEJS加载GeoJSON地图数据(three.js 教程)

stats 库是一个可以用于监测JavaScript性能的工具库。它可以跟踪帧率(FPS)、渲染时间和内存使用情况等信息。在开发过程中,这些信息可以帮助开发者了解应用程序的性能表现,并且有助于识别和优化潜在的性能瓶颈。

下面开始介绍如何加载

STEP 1 :{相机、场景、渲染器} 依旧是最重要的步骤

//将这样对环境初始化的步骤封装成一个函数initTHREE()initTHREE(){this.scene = new THREE.Scene();this.camera = new THREE.PerspectiveCamera(90,window.innerHeight/window.innerWidth,0.1,1000)this.camera.position.set(0,0,100)this.camera.aspect = window.innerWidth / window.innerHeight;this.camera.updateProjectionMatrix();this.scene.add(this.camera)// 加入坐标轴// this.axesHelper = new THREE.AxesHelper(5);// this.scene.add(this.axesHelper)// 加载渲染器this.renderer = new THREE.WebGLRenderer({alpha:true})this.renderer.setSize(window.innerWidth,window.innerHeight)// 将渲染器添加到bodydocument.body.appendChild(this.renderer.domElement);// 初始化控制器 可以旋转this.controls = new OrbitControls(this.camera,this.renderer.domElement)      // 创建地图对象this.map = new THREE.Object3D();this.directionalLight = new THREE.DirectionalLight(0xffffff,0.5)this.scene.add(this.directionalLight)this.light = new THREE.AmbientLight(0xffffff,0.5)this.scene.add(this.light)}

STEP 2:创建地理对象

和mapbox、cesium之类的webgis加载数据不同(原理差不多),不能直接加载json数据,然后直接显示,需要我们对Json数据进行解析,然后按照一定的方式来生成图像。

首先,加载文件

this.loader = new THREE.FileLoader();this.loader.load('xxx.json',(data)=>{})

接着,对加载的文件进行处理

//数据格式化this.jsonData = JSON.parse(data)//创建坐标系、获取数据对象const projection1 = d3.geoMercator().center([0, 0]).translate([0, 0]).scale(1);const features = this.jsonData.features;//对features进行遍历features.forEach((feature) => {// 单个省份 对象const province = new THREE.Object3D();// 地址province.properties = feature.properties.name;// 坐标数组const coordinates = feature.geometry.coordinates;const color = "#99ff99";if (feature.geometry.type === "MultiPolygon") {// 多个,多边形coordinates.forEach((coordinate) => {// coordinate 多边形数据coordinate.forEach((rows) => {        //对坐标点数据进行处理const mesh = this.drawExtrudeMesh(rows, color, projection1);mesh.properties = feature.properties.name;province.add(mesh);});});}this.map.add(province);});

坐标处理,构建平面,再通过ExtrudeGeometry拉伸高度

drawExtrudeMesh(polygon, color, projection){const shape = new THREE.Shape();polygon.forEach((row, i) => {const [x, y] = projection(row);if (i === 0) {// 创建起点,使用moveTo方法// 因为计算出来的y是反过来,所以要进行颠倒shape.moveTo(x, -y);}shape.lineTo(x, -y);});// 拉伸const geometry = new THREE.ExtrudeGeometry(shape, {depth: 5,bevelEnabled: true,});// 随机颜色const randomColor = (0.5 + Math.random() * 0.5) * 0xffffff;const material = new THREE.MeshBasicMaterial({color: randomColor,transparent: true,opacity: 0.5,});return new THREE.Mesh(geometry, material);}

STEP 3:开始渲染

animate(){this.controls.update()this.stats.update()//const clock = new THREE.Clock();//this.deltaTime = clock.getDelta()requestAnimationFrame(this.animate)this.renderer.render(this.scene,this.camera)},

加载结果

源码回头传到github上。

https://github.com/1996HZP/THREE_3dCHina

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

上一篇:网页表单文本框的自动填写(四种方法)(网页单行文本框)

下一篇:uniapp面试基础(uniapp前端面试题)

  • 作为活动运营,你必须知道的营销引爆方法(活动运营的工作任务)

    作为活动运营,你必须知道的营销引爆方法(活动运营的工作任务)

  • iqoo8pro怎么打开nfc(iqoo8Pro怎么打开NFC)

    iqoo8pro怎么打开nfc(iqoo8Pro怎么打开NFC)

  • 魅族18支持的WLAN功能有哪些(魅族18支持的充电协议)

    魅族18支持的WLAN功能有哪些(魅族18支持的充电协议)

  • 苹果11能微信分身的吗(苹果11微信分身版ios下载安装)

    苹果11能微信分身的吗(苹果11微信分身版ios下载安装)

  • 红包封面怎么领取(腾讯视频红包封面怎么领)

    红包封面怎么领取(腾讯视频红包封面怎么领)

  • 钉钉为什么会被禁言(钉钉为什么会被加入陌生企业)

    钉钉为什么会被禁言(钉钉为什么会被加入陌生企业)

  • iphone的天气无法显示(iphone天气无法使用)

    iphone的天气无法显示(iphone天气无法使用)

  • 微信扫码怎么用不了应该是什么原因(微信扫码怎么用信用卡支付)

    微信扫码怎么用不了应该是什么原因(微信扫码怎么用信用卡支付)

  • nfc读卡失败是什么原因(nfc读卡失败是什么原因-103)

    nfc读卡失败是什么原因(nfc读卡失败是什么原因-103)

  • 如何测试微信好友是否删除或者拉黑了自己(如何测试微信好友是否删除自己)

    如何测试微信好友是否删除或者拉黑了自己(如何测试微信好友是否删除自己)

  • 苹果无法购买腾讯视频(苹果手机购买不了腾讯会员怎么回事)

    苹果无法购买腾讯视频(苹果手机购买不了腾讯会员怎么回事)

  • ddr4内存几种频率(ddr4内存几种频率对应价格)

    ddr4内存几种频率(ddr4内存几种频率对应价格)

  • u盘可以下大型游戏吗(u盘可以下什么)

    u盘可以下大型游戏吗(u盘可以下什么)

  • 拼多多到货了会显示吗(拼多多到货了会怎么通知)

    拼多多到货了会显示吗(拼多多到货了会怎么通知)

  • 怎么把手机图标变大(怎么把手机图标调小一点)

    怎么把手机图标变大(怎么把手机图标调小一点)

  • 华为畅享10plus带不带nfc(华为畅享10plus带框换屏教程)

    华为畅享10plus带不带nfc(华为畅享10plus带框换屏教程)

  • 快手推广12小时和24小时有区别吗(快手推广12小时 为啥过了四个小时就不推了)

    快手推广12小时和24小时有区别吗(快手推广12小时 为啥过了四个小时就不推了)

  • 手机忽略车载蓝牙怎么恢复(手机忽略车载蓝牙后搜索不到了)

    手机忽略车载蓝牙怎么恢复(手机忽略车载蓝牙后搜索不到了)

  • 苹果6怎么设置拿起唤醒(苹果6怎么设置返回键)

    苹果6怎么设置拿起唤醒(苹果6怎么设置返回键)

  • 苹果x一直edge怎么解决(苹果出现edge怎么办)

    苹果x一直edge怎么解决(苹果出现edge怎么办)

  • 苹果7访问限制在哪里(苹果7访问限制密码初始4位数)

    苹果7访问限制在哪里(苹果7访问限制密码初始4位数)

  • xr的3dtouch怎么打开

    xr的3dtouch怎么打开

  • psd格式怎么编辑(psd格式文件怎么弄)

    psd格式怎么编辑(psd格式文件怎么弄)

  • 最右用不了(最右用不了了)

    最右用不了(最右用不了了)

  • gpt.4.0-gpt 国内版(gpt 中文)

    gpt.4.0-gpt 国内版(gpt 中文)

  • 企业纳税申报表怎么查询
  • 一般纳税人是否可以开普票
  • 出差补贴没有发票怎么做账
  • 财务报表与分析课后答案
  • 高速公路费如何冲抵
  • 计入固定资产和其他资产
  • 利息收入记借方负数表示增加还是减少
  • 购进货物的发票是外来凭证吗
  • 资信证明好开吗
  • 增值税16点税降到13点,补缴税款怎么算
  • 增值税专用发票几个点
  • 电子税务局上财务制度备案错误是啥意思
  • 体检怎么写公司抬头
  • 资源税的销售额包括
  • 账簿登记的基本要求
  • 接受捐赠的要交税吗
  • 地税发票联丢失要补救报帐有何办法?
  • 企业物流运输
  • 增值税免税收入计入什么科目
  • 发票抬头是繁体字怎么办
  • 从业人数如何计算
  • 预缴所得税需要结转吗
  • 小规模核定征收税率
  • 全年实现利润总额为6035
  • 公司注销了帐户钱能办款
  • 经营范围外的业务可以开发票吗
  • 控股子公司是
  • 忘记excel工作表保护密码怎么办
  • win10锁屏界面windows聚焦什么意思
  • 怎么解决win11系统不兼容问题
  • 美金收入 如何交税
  • 一般纳税人车辆过户给个人开票几个点
  • 十天学会php教程
  • 非累积带薪缺勤什么时候确认
  • php更新数据
  • RuntimeError: CUDA out of memory 已解决
  • PHP:pg_connection_reset()的用法_PostgreSQL函数
  • 盈余积累转增股本什么意思
  • php写post接口
  • laravel自带队列效率
  • “Ninja is required to load C++ extensions”解决方案
  • php restful接口
  • php分页技术
  • 买花木计入什么科目
  • 企业生产车间发生的费用会计科目
  • 个税少报了能查出来吗
  • 用税盘开发票税费扣除是怎么回事?
  • 织梦cms不更新了吗
  • 资本公积根据什么填列
  • 织梦安装步骤
  • mysql运行报错
  • 公司购买不动产契税税率
  • 应付账款从质保金扣除
  • 内部往来科目设置在哪类下
  • 业务招待费能计入项目成本吗
  • 进项转出再转入
  • 去税务局核定税种多久生效
  • 政府会计制度累计盈余为负数
  • 结余资金结转申请怎么写
  • 收到银行结息收入怎么做会计分录
  • 职工薪酬包括哪四项内容
  • 详解十二建星择日方法
  • Winxp系统打不开浏览器
  • 设置共享文件夹win10
  • jinjia.exe进程
  • WINDOWS操作系统属于什么操作系统
  • diskgenius分区linux
  • win10一年更新一次
  • java程序员准备骑驴找马了,需要怎么准备
  • 骨骼动画程序设计
  • 搭建oj
  • unity接收udp
  • nodejs的组成
  • python的异常处理语句
  • 请问在javascript程序中
  • jquery 3.5
  • python字典常用操作以及字典的嵌套
  • 申报税务登记日期怎么填
  • 太原公交车咨询电话号码
  • 交完了契税后可以办房产证吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设