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

  • 荣耀X30i支持人脸解锁吗(荣耀x3设置)

    荣耀X30i支持人脸解锁吗(荣耀x3设置)

  • 淘宝怎么取消免密码(淘宝怎么取消免密支付功能支付宝)

    淘宝怎么取消免密码(淘宝怎么取消免密支付功能支付宝)

  • 探探可不可以隐身上线(探探上能隐身吗)

    探探可不可以隐身上线(探探上能隐身吗)

  • 微信打不开点了没反应(微信打不开了是怎么回事)

    微信打不开点了没反应(微信打不开了是怎么回事)

  • 闲鱼曝光率只有85是怎么回事(闲鱼曝光率只有100多)

    闲鱼曝光率只有85是怎么回事(闲鱼曝光率只有100多)

  • 特殊字符指什么(特殊字符指什么数字)

    特殊字符指什么(特殊字符指什么数字)

  • qq怎么@群里的所有人(qq怎么在群里@所有人)

    qq怎么@群里的所有人(qq怎么在群里@所有人)

  • mp3格式错误怎么办(mp3格式错误怎么弄)

    mp3格式错误怎么办(mp3格式错误怎么弄)

  • 大于25兆的视频怎样发到微信(大于25兆的视频怎样发到手机)

    大于25兆的视频怎样发到微信(大于25兆的视频怎样发到手机)

  • 淘宝取消订单有什么影响(淘宝取消订单有赔偿吗)

    淘宝取消订单有什么影响(淘宝取消订单有赔偿吗)

  • 微信旺财什么意思(微信里面旺财是什么意思)

    微信旺财什么意思(微信里面旺财是什么意思)

  • vivos6没有更多设置(vivoz6手机怎么没有更多设置)

    vivos6没有更多设置(vivoz6手机怎么没有更多设置)

  • vb和vba的区别(vb和vba哪个好学)

    vb和vba的区别(vb和vba哪个好学)

  • 电脑跑分16万什么档次

    电脑跑分16万什么档次

  • 华为只能充60的电怎么解决啊(华为手机电池只能充60的电)

    华为只能充60的电怎么解决啊(华为手机电池只能充60的电)

  • 手机上出现hd怎么去掉(手机上出现HD怎么打开)

    手机上出现hd怎么去掉(手机上出现HD怎么打开)

  • vivoy85a屏幕多大尺寸(vivo y85a屏幕尺寸)

    vivoy85a屏幕多大尺寸(vivo y85a屏幕尺寸)

  • 红米note8有红外吗(红米note8红外线)

    红米note8有红外吗(红米note8红外线)

  • 苹果11手机信号不好怎么办(苹果11手机信号下面四个点怎么设置的)

    苹果11手机信号不好怎么办(苹果11手机信号下面四个点怎么设置的)

  • 手机卸载的软件怎么找回来(手机卸载的软件还能找回吗)

    手机卸载的软件怎么找回来(手机卸载的软件还能找回吗)

  • 乐视充电慢怎么办(乐视充电慢怎么回事)

    乐视充电慢怎么办(乐视充电慢怎么回事)

  • iphonexr电量显示在哪设置(iphonexr电量显示怎么设置)

    iphonexr电量显示在哪设置(iphonexr电量显示怎么设置)

  • xr怎么降级系统(苹果xr手机怎么降级)

    xr怎么降级系统(苹果xr手机怎么降级)

  • 目录右侧页码怎样对齐(目录右侧页码怎么和下面内容一致)

    目录右侧页码怎样对齐(目录右侧页码怎么和下面内容一致)

  • 猿创征文|【Python数据科学快速入门系列 | 05】常用科学计算函数(猿猴的作文)

    猿创征文|【Python数据科学快速入门系列 | 05】常用科学计算函数(猿猴的作文)

  • 企业所得税年报怎么查询
  • 社保多交退款多久到账
  • 车船税每年都要交吗标准多少
  • 税收分类编码不可用是什么原因
  • 财务报表提示未审计
  • 企业存货占用资金的比例
  • 认证发票密文有误不能抵扣如何处理?
  • 土地返还款属于政府补助吗
  • 进项交税吗
  • 单位结算卡在pos渠道可办理的功能
  • 成本法下的后续计量
  • 以固定资产出资设立企业
  • 交易性金融资产的交易费用计入哪里
  • 土地款可以抵扣土地增值税么
  • 收购个人独资企业的税收
  • 一般纳税人开专票和普票的税率
  • 营改增开票规定
  • 出租房屋房产税怎么算
  • 仅提供发票
  • 纳税人如何网上申请预填报服务
  • 工资计提如何做账
  • 去年管理费用多记账结账如何调账
  • 公司注销时账面处理
  • 合伙企业财产的管理和使用规定
  • 以前年度亏损在哪个报表体现
  • 购货方收到红字发票计入进项税转出还是进项税额负数?
  • php模块
  • 工程机械设备租赁价格
  • 民间非营利组织会计账务处理
  • pqtray.exe - pqtray 是什么进程 有什么用
  • 在建工程进项税额转出
  • win11专业版和家庭版哪个更流畅
  • msmpeng.exe是什么进程
  • 橡皮树怎么养护
  • 项目差旅费能计入项目费用吗
  • php获取目录所有文件
  • yaf框架优缺点
  • 车道线检测视频素材
  • 浅析中国式现代化的理论价值与现实意义
  • 关于眼中的世界的作文
  • nmblookup安装
  • 个税系统怎么查询已申报个人明细
  • 财务费用的增加记在哪一方
  • 运输途中发生的费用
  • 产品售后维修费放在什么会计科目核算
  • vue3+ts+MicroApp实战教程
  • 门诊收费票据能重新打印吗
  • 发票食品类包含哪些
  • 个体户开发票超过定额是如何交税?
  • sql查询语句怎么用
  • 收款金额比开票金额多怎么处理
  • 固定资产不可以搬走,那什么资产能搬走的?
  • 小规模附加税要交吗
  • 应交税费的记账分录
  • 事业单位其他特殊人员医疗保障是什么意思
  • 如何调整以前年度的实收资本
  • php 访问数据库
  • mysql输入中文显示乱码
  • windows安装在何处
  • 苹果macOS 14 正式发布
  • 任务管理器边框怎么设置
  • win8系统怎么改win10
  • ubuntu文本编辑器怎么打开
  • 新买的u盘安全吗
  • 进不去操作系统 怎么样修复引导
  • macbook如何登录微信
  • 电脑windows7无法验证此文件
  • windows8消费预览版中图片密码使用教程
  • linux怎么禁用用户
  • Unity3D游戏开发毕业论文
  • java面试题简书
  • JavaScript中的math.pi
  • JavaScript开发技巧
  • 即将发布的新能源汽车
  • jquery获取当前日期yyyymmdd
  • 矿山占用荒山是什么意思
  • 公司买的保险怎么查询保单明细
  • 国家税务总局南京市秦淮区税务局纳税服务中心
  • 辽宁国家税务总局电子税务局
  • 预付建造固定资产的工程价款
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设