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

  • vivox80pro怎么唤醒小v(vivox70怎么唤醒屏幕)

    vivox80pro怎么唤醒小v(vivox70怎么唤醒屏幕)

  • vivox70手电筒在哪里打开(vivo的手电筒在哪)

    vivox70手电筒在哪里打开(vivo的手电筒在哪)

  • 荣耀30青春版和荣耀30的区别有哪些(荣耀30青春版和荣耀30哪个好)

    荣耀30青春版和荣耀30的区别有哪些(荣耀30青春版和荣耀30哪个好)

  • 美图秀秀怎么做动漫照片(美图秀秀怎么做壁纸)

    美图秀秀怎么做动漫照片(美图秀秀怎么做壁纸)

  • airpods杂音滋滋滋(airpods滋滋噪音)

    airpods杂音滋滋滋(airpods滋滋噪音)

  • 陌陌进行实名认证安全吗(陌陌进行实名认证解封有用吗?)

    陌陌进行实名认证安全吗(陌陌进行实名认证解封有用吗?)

  • 华为p40应用锁在哪里设置(华为p40pro应用锁)

    华为p40应用锁在哪里设置(华为p40pro应用锁)

  • 小度小度智能音响功能(小度小度智能音箱)

    小度小度智能音响功能(小度小度智能音箱)

  • 华为nova7和7se的区别(华为nova 7和nova 7se)

    华为nova7和7se的区别(华为nova 7和nova 7se)

  • 移动硬盘可以设置密码吗(移动硬盘可以设置虚拟内存吗)

    移动硬盘可以设置密码吗(移动硬盘可以设置虚拟内存吗)

  • 微信群代办一直显示(微信群代办一直在审核中)

    微信群代办一直显示(微信群代办一直在审核中)

  • tas al00是华为什么型号(华为手机型号tas-al00)

    tas al00是华为什么型号(华为手机型号tas-al00)

  • 数字签名错误是怎么回事(数字签名发生错误)

    数字签名错误是怎么回事(数字签名发生错误)

  • 为什么有的公众号不能置顶(为什么有的公众号在订阅里面有的不是)

    为什么有的公众号不能置顶(为什么有的公众号在订阅里面有的不是)

  • 主板bios坏了是什么现象(主板bios坏了能开机吗)

    主板bios坏了是什么现象(主板bios坏了能开机吗)

  • 苹果7指纹键可以换吗(苹果指纹键可以修吗)

    苹果7指纹键可以换吗(苹果指纹键可以修吗)

  • wps表格转为文本(wps表格转为文本怎么操作)

    wps表格转为文本(wps表格转为文本怎么操作)

  • 电脑微信摄像头怎么开(电脑微信摄像头打不开)

    电脑微信摄像头怎么开(电脑微信摄像头打不开)

  • oppor17投屏功能怎么用(oppor17手机投射屏幕教程)

    oppor17投屏功能怎么用(oppor17手机投射屏幕教程)

  • 华为服务器bios默认密码是什么(华为服务器bios密码忘记了怎么办)

    华为服务器bios默认密码是什么(华为服务器bios密码忘记了怎么办)

  • 抖音怎么后半截加音乐(抖音怎么半截添加字幕)

    抖音怎么后半截加音乐(抖音怎么半截添加字幕)

  • 显卡在哪里看(惠普笔记本显卡在哪里看)

    显卡在哪里看(惠普笔记本显卡在哪里看)

  • windows无法启动安装过程(windows无法启动print spooler)

    windows无法启动安装过程(windows无法启动print spooler)

  • Redmi K20 Pro屏幕大小是多少(redmik20pro屏幕分辨率)

    Redmi K20 Pro屏幕大小是多少(redmik20pro屏幕分辨率)

  • 荣耀20带无线充电吗(荣耀20无线充电吗)

    荣耀20带无线充电吗(荣耀20无线充电吗)

  • airpods单耳设置(airpods 单耳设置)

    airpods单耳设置(airpods 单耳设置)

  • 设置按住键盘重复输入字符频率(设置按住键盘重启怎么弄)

    设置按住键盘重复输入字符频率(设置按住键盘重启怎么弄)

  • [九]深度学习Pytorch-transforms图像增强(剪裁、翻转、旋转)

    [九]深度学习Pytorch-transforms图像增强(剪裁、翻转、旋转)

  • 小企业如何做帐
  • 固定资产账务处理实操
  • 社保免征还需要申报吗
  • 财务报表中的存货怎么做掉
  • 软件公司主营业务类别
  • 网银盾属于什么费用
  • 纳税人如何办理纳税申报流程
  • 工业企业生产费用要素一般有哪些
  • 奖金做预发年底结算缴税怎么做?
  • 用于研发的设备会计分录
  • 代缴代扣个人所得税手续费
  • 退回其他单位服务费怎么入账?
  • 外贸企业购进固定资产进项税能留存吗
  • 设备租赁费开票属于哪个大类
  • 案例分析建筑业发展趋势
  • 物业服务费属于什么合同印花税
  • 小规模纳税人附加税减半征收
  • 代扣代缴企业所得税10%
  • 研发费用没做账怎么调账
  • 应收账款坏账准备计算表
  • 事业单位固定资产报废的账务处理
  • 企业收取的会员费当无法继续提供服务能退吗?
  • 在建工程产生废料收入的账务处理?
  • 月末是指
  • 会计主管人员应该具备的基本条件
  • 单位购买图书会计分录
  • 员工报销可以从一般账户转出吗
  • 宽带调制解调器出现问题怎么解决
  • 土地出让金可以代缴吗
  • 路由器怎么重置网络
  • 预交税款分录
  • win11中文安装包
  • php的数据结构
  • phpstudy8
  • php用于输出的有哪些方式
  • 收到的国家电网电话
  • 编写一个php程序,展示双引号和单引号的区别
  • 租赁公司的
  • php+web
  • phpweb缓存技术
  • 出售在建工程账务处理
  • python字符串如何换行
  • 房地产公司计提税金
  • 保税区商品可以开发票吗
  • 所得税费用是指
  • 合伙企业年终分红会计分录
  • 计提坏账准备资产总额会减少吗
  • 应收账款周转速度快表明
  • 异地预交所得税分录
  • 外币账户结汇至人民币账户
  • 举办会议收入如何入账
  • 办公报销项目
  • 什么叫进项税率
  • 三代个税返还算什么费用
  • 工业企业固定资产投资
  • sql like多个
  • mysql第四章
  • sqlserver多表查询 索引
  • 偷天换日角色介绍
  • xp怎么删除系统
  • nec笔记本电脑开机屏幕没反应
  • win7如何删除无法删除的文件
  • win1020h2正式版
  • windows10预览版是什么
  • win10软件报错
  • opencvsharp读取图片
  • Android游戏开发pdf
  • shell字符串操作
  • Unity导出的webgl能做AR吗
  • Unity3d-四元数到矩阵的实现
  • 网页过关类游戏
  • Linux bash Shell中的变量类型详解
  • shell脚本wc
  • js实现ping一个ip地址
  • python如何获取系统绝对路径
  • jquery封装原理
  • 中央与地方增值税
  • 税务开票系统对账流程
  • 固定资产转让要交企业所得税吗
  • 江苏税务ukey怎么申请
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设