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

  • 闲鱼怎么隐藏已卖出的东西(闲鱼怎么隐藏已经卖出去的东西)

    闲鱼怎么隐藏已卖出的东西(闲鱼怎么隐藏已经卖出去的东西)

  • 拼多多怎么看自己的评论记录(拼多多怎么看自动收货还有几天)

    拼多多怎么看自己的评论记录(拼多多怎么看自动收货还有几天)

  • 华为第一款5g手机是什么型号(华为第一款5g手机多少钱)

    华为第一款5g手机是什么型号(华为第一款5g手机多少钱)

  • ipad2系统最高到多少(ipad2 最高系统)

    ipad2系统最高到多少(ipad2 最高系统)

  • qq图片和文字怎么在一个对话框里(qq图片和文字怎么一起发不了)

    qq图片和文字怎么在一个对话框里(qq图片和文字怎么一起发不了)

  • 微信截图怎么截想要的一部分(手机微信截图怎么截)

    微信截图怎么截想要的一部分(手机微信截图怎么截)

  • 自动换行符在哪里设置(自动换行符在哪里设置excel)

    自动换行符在哪里设置(自动换行符在哪里设置excel)

  • 退出键怎么设置(荣耀退出键怎么设置)

    退出键怎么设置(荣耀退出键怎么设置)

  • word的高级设置在哪里(文档高级设置在哪里)

    word的高级设置在哪里(文档高级设置在哪里)

  • 微信非对方朋友啥意思(微信非对方朋友显示十条朋友圈)

    微信非对方朋友啥意思(微信非对方朋友显示十条朋友圈)

  • word文档怎么消除批注(word文档怎么消除格式标记)

    word文档怎么消除批注(word文档怎么消除格式标记)

  • word被锁定无法编辑(word被锁定无法删除)

    word被锁定无法编辑(word被锁定无法删除)

  • 手机拼多多怎么退货(手机拼多多怎么退店铺保证金)

    手机拼多多怎么退货(手机拼多多怎么退店铺保证金)

  • 设置个人来电专属铃声(设置个人来电铃声)

    设置个人来电专属铃声(设置个人来电铃声)

  • pd快充什么接口(pd快充什么接口最好)

    pd快充什么接口(pd快充什么接口最好)

  • 苹果怎么关闭黑夜模式(苹果怎么关闭黑屏模式)

    苹果怎么关闭黑夜模式(苹果怎么关闭黑屏模式)

  • 苹果11长焦镜头有什么用(苹果11长焦镜头怎么调)

    苹果11长焦镜头有什么用(苹果11长焦镜头怎么调)

  • 什么叫收集数据的方法(收集数据的概念)

    什么叫收集数据的方法(收集数据的概念)

  • pr序列是什么(pr的序列是什么意思)

    pr序列是什么(pr的序列是什么意思)

  • word怎么设置上标表示形式(word怎么设置上角标)

    word怎么设置上标表示形式(word怎么设置上角标)

  • 民心网里的内容怎么看(民心网的作用大吗)

    民心网里的内容怎么看(民心网的作用大吗)

  • 复制朋友圈怎么才能不折叠(复制朋友圈怎么显示全文)

    复制朋友圈怎么才能不折叠(复制朋友圈怎么显示全文)

  • 华为p30可以遥控空调吗(华为P30可以遥控格力美的空调)

    华为p30可以遥控空调吗(华为P30可以遥控格力美的空调)

  • b5手环运动版和商务版有啥区别(b5手环跟b6区别)

    b5手环运动版和商务版有啥区别(b5手环跟b6区别)

  • 什么可以代替电容笔(什么可以代替电视机)

    什么可以代替电容笔(什么可以代替电视机)

  • 钢化膜贴完四周不吸附(钢化膜贴完四周不吸附影响使用吗)

    钢化膜贴完四周不吸附(钢化膜贴完四周不吸附影响使用吗)

  • 企业所得税应纳税额
  • 营业外收入需要结转到本年利润吗
  • 增值税的账务处理 月末怎么结转 案例
  • 机票行程单改成发票可以报销吗
  • 个税手续费返还计入哪个科目
  • 合同违约金账务处理
  • 农产品增值税核定扣除计算
  • 增值税专用发票和普通发票的区别
  • 国外汇款 用什么理由
  • 计提水电费是什么凭证
  • 月销售额小于10万的一般纳税人减免
  • 1697508230
  • 房租税收怎么算?
  • 注册公司需要注册资金吗
  • 如何更改中英文切换
  • 最新气象报告
  • 税金及附加怎么登明细账
  • 租赁合同维修费用
  • 子公司代总公司付款
  • 重置组策略命令
  • php ajax json
  • 无法启用网络发展
  • 长期借款和短期借款会计分录的区别
  • 新手刚接触财务
  • php getheader
  • 融资租入固定资产是什么意思
  • 金融服务企业按照是否办理存款业务
  • 短视频小程序源码
  • 房抵债权
  • ValueError: The device should not be ‘gpu‘, since PaddlePaddle is not compiled with CUDA问题解决(Paddle)
  • 小规模纳税人季度不超30万免增值税
  • 公允价值变动损益
  • 航天远程清卡
  • 进出口额等于进口额加出口额吗
  • 帝国cms到底好不好
  • 固定资产的核算内容包括
  • 结转成本计入
  • 物品登记制度
  • 预收款项可以开发票吗
  • 个体工商户需要给员工交社保吗
  • 工程的直接成本包括哪些内容
  • 负商誉的分录
  • 残疾人残保金如何计算
  • 收到国税退回的税款分录
  • 诉讼费可以退回私账嘛
  • 现金短缺无法查明计入什么科目
  • 备用金分为哪两种
  • 暂估入库可以隔几个月再冲回吗
  • 供应商销售折让怎么入账
  • 车船使用税会计分录怎么写
  • mysql5.7免安装版
  • 批量修改 sql
  • 苹果的mac系统
  • 在linux2.4.0版本中
  • windows下怎么安装mac
  • win8系统怎么创建局域网
  • 开源镜像是什么意思
  • 远程文件管理器
  • win10怎么切任务管理
  • Win7旗舰版64位如何关闭电脑触摸屏功能的方法
  • win10能运行的单机游戏
  • android内存工具
  • jquery焦点
  • Node.js中的包管理工具是什么
  • scrollview不滚动
  • 用python做开发
  • unity 3d教程
  • 本地 node js 启动vue
  • jquery给table赋值
  • JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
  • 在jquery中fadein
  • 深入理解新发展理念
  • 装饰装修公司需要什么
  • 东莞市电子税务局app
  • 河南二套房契税征收2023标准是多少
  • 华为西安总代理
  • 信息报送条例
  • 下载安徽税务app并安装
  • 税务稽查增值税账务调整案例
  • 武汉 工资 税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设