位置: IT常识 - 正文

【THREE.JS学习(3)】使用THREEJS加载GeoJSON地图数据(three.js 教程)

发布时间:2024-01-15
【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前端面试题)

  • 个体工商户的报税流程
  • 进口关税怎么做分录
  • 进项税额比销项税额大怎么办
  • 自行申报需补缴税款时征收滞纳金吗
  • 国债利息收入计入财务费用吗
  • 财政基建拨款如何做分录
  • 企业所得税零申报表怎么填写
  • 农民合作社交哪些税
  • 软件企业购进软件服务怎么入账
  • 外购原材料自用
  • 商业汇票的样本
  • 出口退税计算方式
  • 补开去年未开票收入
  • 研发无形资产摊销加计扣除计算
  • 核定征收企业所得税能否享受税收优惠
  • 未达起征点销售额和小微企业免税销售额
  • 现金收款能开专用发票吗
  • 个体户可以申请公章吗
  • 什么是季初值和季末值
  • 现金流量表右边
  • 两年前的发票能开红字发票吗
  • 当月认证下月抵扣
  • 对赌协议的账务处理流程
  • 一般纳税人资格登记表
  • 公司委托第三方缴纳社保合法吗
  • php数据库添加失败的原因
  • 集团内部调拨账务处理
  • 前期做了无票收入,后期怎么填写
  • 劳动保护费计入什么会计科目
  • php中construct
  • 应收票据计提利息应做的会计分录是
  • 政府购买企业服务是否交税
  • 什么是收付实现制?什么是权责发生制?
  • 公司制作横幅计入什么科目?
  • less预处理器详解
  • 常见的归中反应有哪些
  • css前端还是后端
  • 长期借款账务处理会计分录怎么写
  • jquery 兄弟选择器
  • 浅谈人工智能时代财务会计向管理会计的转型
  • php考试时间倒计时
  • php路径问题
  • 微擎框架破解版v2.7.7
  • 来料加工企业的划分标准
  • 选择简易计税方法按照5%的征收率计税公式
  • 研发费用的会计处理方法
  • 如何用织梦在本地搭建网站
  • 预收的贷方余额表示什么
  • 购买银行短期理财产品的会计处理
  • 运输公司挂靠车辆的会计处理?
  • 公允价值进行会计计量
  • 企业所得税资产总额季初季末怎么填
  • 销项税额专栏记录企业销售货物
  • 个税适用税率怎么确定
  • 行政单位无偿划拨资产账务处理
  • 租赁公司账务科目
  • 管理费用如何分摊到项目
  • 培训费做什么会计分录
  • 装修待摊费用当月摊销吗
  • 本期摊余成本
  • sql servers
  • 如何查看solaris版本
  • win10更新dx
  • ubuntu笔记软件
  • 国产系统叫啥
  • bios屏蔽nvme
  • Linux中QQ软件的安装和配置
  • windows 8/10whql
  • Extjs grid panel自带滚动条失效的解决方法
  • cocos2djs
  • js中的原型是什么
  • java程序员练手项目
  • 骨骼动画程序设计
  • unity向量的规范化
  • python中的面向对象
  • document对象常用方法
  • 简单的设计模式
  • 经营所得个人所得税税率表
  • 广东税务个人账号注销后会怎样
  • 支付宝申领失业金申请审核多久
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号