位置: 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前端面试题)

  • 盘点一种可以自我营销的邮件营销方式(盘点一种可以自学的软件)

    盘点一种可以自我营销的邮件营销方式(盘点一种可以自学的软件)

  • 华为手机屏幕上时间和日期没有了怎么办(华为手机屏幕上的日期和时间没有了怎么办)

    华为手机屏幕上时间和日期没有了怎么办(华为手机屏幕上的日期和时间没有了怎么办)

  • 京东免费上门取件还收运费吗(京东免费上门取件怎么操作)

    京东免费上门取件还收运费吗(京东免费上门取件怎么操作)

  • oppo手机快充怎么设置(oppo手机快充怎么变成慢充了)

    oppo手机快充怎么设置(oppo手机快充怎么变成慢充了)

  • 荣耀play3可以使用EMUI10吗(荣耀play3使用教程)

    荣耀play3可以使用EMUI10吗(荣耀play3使用教程)

  • 芒果tv缓存的视频在哪个文件夹

    芒果tv缓存的视频在哪个文件夹

  • 屏蔽好友消息对方知道吗(屏蔽好友消息对方看不到)

    屏蔽好友消息对方知道吗(屏蔽好友消息对方看不到)

  • 魅族实名认证怎么解除(魅族手机实名认证有什么用)

    魅族实名认证怎么解除(魅族手机实名认证有什么用)

  • 钉钉重新提交作业会显示时间吗(钉钉重新提交作业时间会变吗)

    钉钉重新提交作业会显示时间吗(钉钉重新提交作业时间会变吗)

  • 手机卡放到另一个手机上没有联系人的原因(手机卡放到另一个手机上微信聊天记录可以恢复吗)

    手机卡放到另一个手机上没有联系人的原因(手机卡放到另一个手机上微信聊天记录可以恢复吗)

  • 2400t内存 t是什么意思(2400t内存和2400有区别吗)

    2400t内存 t是什么意思(2400t内存和2400有区别吗)

  • 京东可以拒收货吗(京东拒收货物要付运费吗)

    京东可以拒收货吗(京东拒收货物要付运费吗)

  • 知道手机号能搜快手吗(知道手机号能搜到抖音吗)

    知道手机号能搜快手吗(知道手机号能搜到抖音吗)

  • 苹果x手机怎么关机重启(苹果x手机怎么样值得入手吗)

    苹果x手机怎么关机重启(苹果x手机怎么样值得入手吗)

  • oppo手机怎么导出联系人(oppo手机怎么导入数据到oppo手机)

    oppo手机怎么导出联系人(oppo手机怎么导入数据到oppo手机)

  • 微信的微云在哪里(微信的微云在哪里打开)

    微信的微云在哪里(微信的微云在哪里打开)

  • 华为如何弄电子保修卡(华为能你也能 电子版)

    华为如何弄电子保修卡(华为能你也能 电子版)

  • 手机如何制作ppt(手机如何制作ppt课件)

    手机如何制作ppt(手机如何制作ppt课件)

  • 拼多多砍价成功后怎么看砍价记录(拼多多砍价成功的商品在哪查看)

    拼多多砍价成功后怎么看砍价记录(拼多多砍价成功的商品在哪查看)

  • iphonex多重(苹果x多重)

    iphonex多重(苹果x多重)

  • 三层交换机路由器区别(三层交换机路由表怎么看)

    三层交换机路由器区别(三层交换机路由表怎么看)

  • oppo 新机reno z上市时间(oppo出新手机了)

    oppo 新机reno z上市时间(oppo出新手机了)

  • 荣耀8x发布时间(荣耀8x参数)

    荣耀8x发布时间(荣耀8x参数)

  • vivoz5x多重(vivoz5x多重多少克)

    vivoz5x多重(vivoz5x多重多少克)

  • 如何查找手机nfc功能(如何查找手机定位)

    如何查找手机nfc功能(如何查找手机定位)

  • 在win7中,为什么电脑时间不能同步?(在win7中,为什么打开盘符在新窗口中出现?)

    在win7中,为什么电脑时间不能同步?(在win7中,为什么打开盘符在新窗口中出现?)

  • vue中的get方法\post方法如何实现传递数组参数(vue get方法)

    vue中的get方法\post方法如何实现传递数组参数(vue get方法)

  • 购买方收取的违约金怎么入账
  • 纳税检查调整的销售额确认收入吗
  • 减免所得税会影响工资发放吗
  • 财务软件费用可以抵税吗
  • 一般纳税人的税种有哪些
  • 什么是电子银行渠道限额
  • 如何查看发票是否被抵扣
  • 发票找不到了怎么报销
  • 一般纳税人可以转小规模纳税人吗
  • 房地产开发公司排名
  • 试用期社保是按照应发工资缴纳吗
  • 事业单位已核销怎么处理
  • 收到政府补助的固定资产的账务处理
  • 零余额帐户如何转账
  • 收到报废车款要交什么税
  • 公司开出的经济补偿金可以税前扣除吗
  • 出售房产税收
  • 企业亏损情况下股东借款怎么办
  • 旅游公司发票企业能报销吗
  • 增值税发票时效性
  • 现金流量表的填制方法和构成
  • 收到的劳务费发票进什么科目
  • 补交的城建税怎么账务处理
  • 流动资产包括哪些形式
  • 期末结转生产成本会计分录
  • 向投资者宣告发放股利会影响所有者权益吗
  • 培训机构的收入有哪几方面
  • 注册公司需要注册资金吗
  • win10两个屏幕两个桌面
  • 企业办税人员是干嘛的
  • 附加税会计分录2022
  • 抵押物转让的法律规定
  • 手动ghost还原硬盘
  • PHP:oci_set_client_info()的用法_Oracle函数
  • 代扣代缴个人工会经费 企业所得税
  • 帮忙介绍业务
  • 车辆违章罚款可以报销吗
  • 金融资产减值损失计入什么科目
  • 金融企业呆账核算流程
  • vue实战技巧
  • 外国企业如何在阿联酋注册商标
  • 民营医院所得税税率
  • nginx gui
  • 免抵调库 地方税收有无增加
  • 企业在外地单位怎么交税
  • 投资他人公司
  • phpcms不支持https怎么办
  • 企业员工年终奖仲裁
  • 资产减值损失是什么意思
  • 织梦自定义字段
  • sqlloader-350错误
  • 织梦添加文章如何修改高级参数
  • 小规模纳税人起征点变化历程
  • 财政拨款结转是
  • 解决烧心最快方法
  • 带薪年假一般是什么时候
  • 股权收购被收购方怎么做账
  • 本月未抵扣完的进项税是否转出
  • 生产车间包括什么
  • 以旧验新发票
  • mysql修改表结构的命令
  • mysql分表实践
  • win10如何关闭windows安全中心图标
  • win7电脑网络慢怎么提升
  • windows8.1应用商店打不开
  • linux 卸载 mysql
  • Android游戏开发打砖块
  • 安装运行windows
  • unity4.x升级到unity5.x材质丢失
  • 用Fragment+ViewPager搭建万能的android界面
  • unity learn premium
  • python自动化验证码
  • javascript Keycode对照表
  • python自带的gui
  • 宾馆税务
  • 江西省发票查询系统
  • 企业所属行业代码查询方法
  • 广东省广州市国家安全局
  • 湖南国税电子税务局网
  • 增值税电子普通发票需要盖章吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设