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

  • 做APP推广不得不知的9大坑(做app推广有前途吗)

    做APP推广不得不知的9大坑(做app推广有前途吗)

  • OPPO R11s单手模式怎么开启(oppoa11怎么单手模式)

    OPPO R11s单手模式怎么开启(oppoa11怎么单手模式)

  • zip格式转rar格式(zip格式转换rar)

    zip格式转rar格式(zip格式转换rar)

  • 苹果计算机怎么后退(苹果计算机怎么显示过程)

    苹果计算机怎么后退(苹果计算机怎么显示过程)

  • 华为手机怎样设置流量超出停用(华为手机怎样设置锁屏壁纸)

    华为手机怎样设置流量超出停用(华为手机怎样设置锁屏壁纸)

  • 固定拨号功能已开启无法发短信(固定拨号功能已开启怎么关闭vivo)

    固定拨号功能已开启无法发短信(固定拨号功能已开启怎么关闭vivo)

  • 电脑屏幕显示偏左怎么解决(电脑屏幕显示偏向一边)

    电脑屏幕显示偏左怎么解决(电脑屏幕显示偏向一边)

  • 电脑自带压缩软件吗(电脑自带压缩软件在哪win11)

    电脑自带压缩软件吗(电脑自带压缩软件在哪win11)

  • 手机支持sa和nsa是什么意思(手机支持sa和nsa双模是什么意思)

    手机支持sa和nsa是什么意思(手机支持sa和nsa双模是什么意思)

  • 华为怎么清理微信缓存呢(华为怎么清理微信图片)

    华为怎么清理微信缓存呢(华为怎么清理微信图片)

  • 苹果x忘记密码怎么弄(苹果X忘记密码锁屏了怎么办)

    苹果x忘记密码怎么弄(苹果X忘记密码锁屏了怎么办)

  • ps打印照片怎么排版(ps打印照片怎么设置)

    ps打印照片怎么排版(ps打印照片怎么设置)

  • 怎么删除淘宝人生账单(怎么删除淘宝人生第一笔订单)

    怎么删除淘宝人生账单(怎么删除淘宝人生第一笔订单)

  • 手机自动转屏怎么关(手机自动转屏怎么弄)

    手机自动转屏怎么关(手机自动转屏怎么弄)

  • 手机节拍器怎么使用(手机节拍器怎么调十六分音符)

    手机节拍器怎么使用(手机节拍器怎么调十六分音符)

  • 手机qq怎么群删好友(手机qq怎么删除群)

    手机qq怎么群删好友(手机qq怎么删除群)

  • iphone的原彩显示有什么用(iphone的原彩显示伤眼睛吗)

    iphone的原彩显示有什么用(iphone的原彩显示伤眼睛吗)

  • 一加7尺寸(一加7尺寸长宽高)

    一加7尺寸(一加7尺寸长宽高)

  • iphonex听筒闷解决办法(iphonex听筒堵了怎么办)

    iphonex听筒闷解决办法(iphonex听筒堵了怎么办)

  • 电脑蓝屏0x000007f(电脑蓝屏0X0000007E是怎么回事)

    电脑蓝屏0x000007f(电脑蓝屏0X0000007E是怎么回事)

  • 天猫旗舰店如何注册(天猫旗舰店如何投诉电话)

    天猫旗舰店如何注册(天猫旗舰店如何投诉电话)

  • steam怎么退款申请退款(steam怎么退款申请退款要多久)

    steam怎么退款申请退款(steam怎么退款申请退款要多久)

  • 织梦模板DEDECMS附加表自定义字段关联主表文章(织梦模板转讯睿模板)

    织梦模板DEDECMS附加表自定义字段关联主表文章(织梦模板转讯睿模板)

  • mysql内连接查询是什么(mysql内连接查询使用汉语作为官方语言的所有国家)

    mysql内连接查询是什么(mysql内连接查询使用汉语作为官方语言的所有国家)

  • 金税开票软件下载安装
  • 应纳税所得额怎么计算应纳税额
  • 一般纳税人每月开票不超10万
  • 计提跌价的存货卖出了
  • 社保基数是按税前工资还是税后工资
  • 收到的其他与筹资活动有关的现金包括
  • 增值税都有哪些科目
  • 发票没有认证怎么报销
  • 事业单位的股东是什么
  • 所得税汇算交的所得税怎么做账
  • 进口货物的代理报关服务费计入
  • 建筑公司运营的流程
  • 一个员工在两家公司上班违法吗
  • 中药税率什么时候变为9
  • 一般纳税人施工费税率是多少
  • 纳税人必须关注的10个涉税风险点
  • 职工向公司借款计入什么科目
  • 个税前几个月没有工资,累计减除费用会累计吗
  • 去年的暂估成本今年如何冲掉
  • 会计差错更正的准则依据
  • 自制半成品生产成本
  • 经营范围外的业务可以开发票吗
  • 金蝶kis云专业版原材料数量怎么录入
  • 上个月开的发票这个月还能用吗
  • 分支机构的季度所得税务报表是填合并报表吗
  • 高薪补贴需要交什么税
  • 物业预收的物业费怎么做会计分录?
  • windows10如何添加英文输入法
  • 企业对外捐赠的税法处理
  • 房地产企业集团内部间的担保费可以税前扣除嚒
  • aspnet_admin.exe进程是安全的吗 aspnet_admin进程信息查询
  • 如何暂停win11更新
  • php umask
  • php render()
  • 进口付汇业务流程
  • php语言版本
  • 未分配利润为负的原因
  • cnn三层
  • css选择器详解
  • 个人提供劳务需要开发票吗
  • 材料采购会计科目怎么使用
  • mysql更新视图的方式
  • MYSQL数据库设计与应用第二版
  • 租金收入如何分析
  • 固定资产货币化,货币资产保险化,保险资产信托化
  • 交通运输企业有什么优惠政策
  • short int、long、float、double使用问题说明
  • sqlserver模糊查询表名
  • 申报错误后处理有影响吗
  • 银行开户费属于现金流量表的哪一类
  • 现金发放工资有什么风险
  • 分公司注销库存车怎么办
  • 银行承兑汇票利息归谁
  • 预算会计年末如何结账
  • 专用发票过期未认证最新规定
  • 报关单不在海关信息中
  • 确认医院体检收费怎么办
  • mysql优化十大技巧
  • 被放弃的遗产
  • 安装win8系统需要什么条件
  • msp sncp
  • gzip与zip
  • linux中快捷键
  • windows10 不能启动
  • win8搜索不到自己家的WiFi
  • linux操作系统入门教程
  • cocos2d游戏源码
  • 在bootstrap中,有哪几种导航
  • dos命令中运行文件的命令
  • 无法加载odbc驱动程序
  • jquery自带的弹出框
  • jquery 滑动显示
  • 红杏是什么意思什么样的
  • 无序列表html
  • 安卓数据储存方式有哪些
  • javascript总结
  • 福建国税电子税务局app
  • 第十三个人
  • 大征期 是什么
  • 河北地税网上申报纳税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设