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

  • 微信怎么看bin图纸(怎么看微信所有图片)

    微信怎么看bin图纸(怎么看微信所有图片)

  • 华为荣耀9xpro有没有录屏功能(荣耀9xpro使用说明)

    华为荣耀9xpro有没有录屏功能(荣耀9xpro使用说明)

  • 小米960帧慢动作只能10秒(小米9960帧慢动作)

    小米960帧慢动作只能10秒(小米9960帧慢动作)

  • 苹果手机发朋友圈怎么显示位置(苹果手机发朋友圈视频变色怎么回事)

    苹果手机发朋友圈怎么显示位置(苹果手机发朋友圈视频变色怎么回事)

  • 钉钉群是干什么的(钉钉群是干什么的群)

    钉钉群是干什么的(钉钉群是干什么的群)

  • 可以申请两个微信号吗(能不能申请2个微信号)

    可以申请两个微信号吗(能不能申请2个微信号)

  • 显卡和机箱孔对不齐(显卡和机箱孔对不齐怎么办)

    显卡和机箱孔对不齐(显卡和机箱孔对不齐怎么办)

  • 快手怎么重置自己的账号(怎么让快手重置)

    快手怎么重置自己的账号(怎么让快手重置)

  • 华为屏幕最大的手机是哪款(华为屏幕最大的是哪一款)

    华为屏幕最大的手机是哪款(华为屏幕最大的是哪一款)

  • 表格被分成两页怎么处理(表格被分成两页了怎么合成一页)

    表格被分成两页怎么处理(表格被分成两页了怎么合成一页)

  • btvdl09是什么平板型号(btvdl09和btvw09)

    btvdl09是什么平板型号(btvdl09和btvw09)

  • 拼多多复制链接在哪里(拼多多复制链接不弹出怎么回事)

    拼多多复制链接在哪里(拼多多复制链接不弹出怎么回事)

  • 华为p30微信聊天记录怎么恢复(华为p30微信聊天图片存在哪里了)

    华为p30微信聊天记录怎么恢复(华为p30微信聊天图片存在哪里了)

  • 钉钉null是什么意思(钉钉的出现)

    钉钉null是什么意思(钉钉的出现)

  • 魅族手机耗电快怎么解决(魅族手机耗电快充电慢怎么办)

    魅族手机耗电快怎么解决(魅族手机耗电快充电慢怎么办)

  • 抖音换号必须换手机吗(抖音换抖音号是重置吗)

    抖音换号必须换手机吗(抖音换抖音号是重置吗)

  • 苹果6s屏幕上的圆点怎么设置(苹果6s屏幕上的小圆点怎么设置)

    苹果6s屏幕上的圆点怎么设置(苹果6s屏幕上的小圆点怎么设置)

  • 华为软件更新在哪里(华为软件更新在哪里nova7)

    华为软件更新在哪里(华为软件更新在哪里nova7)

  • 苹果11pro max港版和国行区别(苹果11pro max港版充电器)

    苹果11pro max港版和国行区别(苹果11pro max港版充电器)

  • 电脑黑屏按哪三个键(电脑黑屏按哪三个键关机)

    电脑黑屏按哪三个键(电脑黑屏按哪三个键关机)

  • 华为屏幕时间怎么调出来(华为屏幕时间怎么显示出来)

    华为屏幕时间怎么调出来(华为屏幕时间怎么显示出来)

  • 华为怎么把通知栏关闭(华为怎么把通知栏调成黑色)

    华为怎么把通知栏关闭(华为怎么把通知栏调成黑色)

  • wo27s光纤猫是千兆吗(光纤猫是千兆的吗)

    wo27s光纤猫是千兆吗(光纤猫是千兆的吗)

  • 手机黑名单打电话提示什么(手机黑名单打电话提示什么怎么拉出来)

    手机黑名单打电话提示什么(手机黑名单打电话提示什么怎么拉出来)

  • 苹果延时摄影怎么调速(苹果延时摄影怎么转换正常)

    苹果延时摄影怎么调速(苹果延时摄影怎么转换正常)

  • 机票行程单能报销几次
  • 企业缴纳增值税后还需缴纳所得税吗
  • 财务凭证和预算凭证目录只能有一条数据
  • 印花税减半征收优惠政策2022
  • 代人开增值税怎么收费?
  • 外贸公司代理出口退税怎么入账
  • 购进蔬菜的进项税额
  • 分公司成立时的法人是谁
  • 股权变更前账务怎么处理
  • 固定资产原价的结余额
  • 网上平台服务年费应该计入什么费用?
  • 委托出口退税账务处理
  • 以固定资产出资设立企业
  • 外汇银行会计特殊处理方法如何理解?
  • 转售的物业
  • 居民小区人防设施主要是什么
  • 冲销上月暂估入账的原材料会计分录
  • 银行汇票计入什么费用
  • 未开票收入缴纳所得税吗
  • 分享下会画画是怎样的体验
  • nmstt.exe - nmstt是什么进程 有什么用
  • linux安装常用命令
  • 应付票据是发票吗
  • 出口货物视同内销征税的会计核算
  • 油气勘探支出包括
  • 自然保护什么意思
  • 发票开错抬头怎么进行税务处理?
  • php gzip压缩
  • javaweb简单项目案例
  • php中类静态成员描述不正确的是
  • vue自定义dialog
  • 增长gdp是什么意思
  • react 入门教程
  • php 输出
  • PHP中使用什么关键字声明变量的作用域为全局
  • 图形验证码api
  • 织梦怎么新建页面
  • 美团算钱
  • dedecms下载
  • 费用票有什么用处
  • 不动产销售额是否为免税
  • db2 -968
  • 房地产按揭贷款政策
  • 外地预缴税款如何查询
  • 会计账户与银行账户
  • 销售固定资产如何申报企业所得税
  • 机动车销售折让红字信息表
  • 材料采购发生的共同费用可以按什么作为分配基础
  • 小规模纳税人采用简易计税方法征收增值税
  • 汽车属于固定资产类吗
  • 折旧计入主营业务成本的情况
  • 本月增加的固定资产本月可以进行部门转移
  • 国际快递能发吗
  • 营改增租赁服务有哪些
  • 销售自己使用过的物品免税吗
  • mysql5.6怎么用
  • navicate创建存储过程
  • win7旗舰版系统激活码
  • 如何自己解封微信号呢
  • centos7升级内核后 无法启动
  • mac系统小技巧
  • win10系统玩dnf闪退
  • linux的ftp命令
  • win7找回删除的文件
  • linux快速查看目录大小
  • 安装win7系统后一直正在启动
  • Win7系统电脑开不开机怎么办
  • Android屏幕外侧滑条
  • 网页跳转的实现方法
  • javascript教程完整版
  • Ext JS 4官方文档之三 -- 类体系概述与实践
  • js随机生成6位数
  • Python快速从注释生成文档的方法
  • perl常用函数
  • 财务审计报告出现数据错误怎么处理
  • 云南省税务局网上办税服务厅官网
  • 装修费也要缴纳房产税吗
  • 税务局工会
  • 2019小规模纳税人标准
  • 河北税务官方网页
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设