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

  • 华为p40是屏幕指纹吗(华为p40触摸屏设置)

    华为p40是屏幕指纹吗(华为p40触摸屏设置)

  • 魔百盒的复位孔在哪(魔百盒的复位孔是干什么用的)

    魔百盒的复位孔在哪(魔百盒的复位孔是干什么用的)

  • 检查appleid电话号码是什么意思(检查appleid电话号码咋通过)

    检查appleid电话号码是什么意思(检查appleid电话号码咋通过)

  • 苹果11有什么特别的功能吗(苹果11有什么特别)

    苹果11有什么特别的功能吗(苹果11有什么特别)

  • 佳能3680打印机闪黄灯(佳能3680打印机三角黄灯闪)

    佳能3680打印机闪黄灯(佳能3680打印机三角黄灯闪)

  • 怎么把两张图片p在一起(怎么把两张图片p到一张图片上)

    怎么把两张图片p在一起(怎么把两张图片p到一张图片上)

  • 华为gt1有什么功能(华为gt1 功能测评)

    华为gt1有什么功能(华为gt1 功能测评)

  • 钉钉撤回痕迹怎么删除(钉钉撤回的流程对方能看见吗)

    钉钉撤回痕迹怎么删除(钉钉撤回的流程对方能看见吗)

  • qq课堂回放可以下载吗(qq课堂回放怎么导出来)

    qq课堂回放可以下载吗(qq课堂回放怎么导出来)

  • 8p屏幕左上角有黑影会扩大吗(8p屏幕左上角有涨开了)

    8p屏幕左上角有黑影会扩大吗(8p屏幕左上角有涨开了)

  • 蓝色的网线是几类网线(蓝色是网线还是灰色)

    蓝色的网线是几类网线(蓝色是网线还是灰色)

  • 华为无线耳机怎么接电话(华为无线耳机怎么使用)

    华为无线耳机怎么接电话(华为无线耳机怎么使用)

  • 手机嗡嗡响是怎么回事(手机嗡嗡响是怎么回事但是没有显示)

    手机嗡嗡响是怎么回事(手机嗡嗡响是怎么回事但是没有显示)

  • 京喜和京东买东西有区别吗(京东和京喜是一起的吗)

    京喜和京东买东西有区别吗(京东和京喜是一起的吗)

  • 华为平板第一次充电注意事项(华为平板第一次正确充电方法)

    华为平板第一次充电注意事项(华为平板第一次正确充电方法)

  • 微信橱窗怎么开通(微信商品橱窗开通需要什么条件)

    微信橱窗怎么开通(微信商品橱窗开通需要什么条件)

  • 段落的对齐有哪五种(段落的对齐有哪几种)

    段落的对齐有哪五种(段落的对齐有哪几种)

  • 手机如何打希腊字母(手机怎么打出希腊的数字)

    手机如何打希腊字母(手机怎么打出希腊的数字)

  • 华为nova3i宽度(华为nova3i机身尺寸)

    华为nova3i宽度(华为nova3i机身尺寸)

  • 快闪是个什么意思(快闪是什么意思外卖)

    快闪是个什么意思(快闪是什么意思外卖)

  • 荣耀9x开机键在哪里(荣耀9x开机键在哪里设置)

    荣耀9x开机键在哪里(荣耀9x开机键在哪里设置)

  • erofs什么意思(eros flame什么意思)

    erofs什么意思(eros flame什么意思)

  • 小米屏蔽的相册去哪里找(小米屏蔽的相册怎么看)

    小米屏蔽的相册去哪里找(小米屏蔽的相册怎么看)

  • ctrl+h是什么快捷键(ctrl + h)

    ctrl+h是什么快捷键(ctrl + h)

  • JSP页面实现验证码校验(用jsp实现用户登录验证)

    JSP页面实现验证码校验(用jsp实现用户登录验证)

  • 小规模纳税人收到专票可以抵扣吗
  • 补报以前年度收入后当年所得税怎么处理
  • 增值税留抵抵欠税政策解读
  • 幼儿园经营支出指什么
  • 水利建设专项收入怎么计算
  • 个体开票
  • 外币账户间互转流程
  • 股东借款可以免增值税吗
  • 企业对固定资产进行计量时应选择的计量属性是
  • 应交税费明细分类账图片
  • 企业卖了个人如何交税
  • 金蝶软件怎么设置会计科目
  • 小规模文化交流活动
  • 出口企业增值税税负率
  • 详解出口退税的涵义
  • 特殊行业会计公司排名
  • 补提以前年度摊销
  • 固定资产弃置费用预计负债
  • 公司员工驻外补贴政策
  • 固定资产的折旧从什么时候开始
  • 年末应计提坏账准备为什么是负数
  • 考后审核是什么时候
  • 上市公司发行股票会计分录
  • 默认网关不可用怎么修复
  • win11资源管理器卡死
  • 期间损益的科目
  • neoDVDstd.exe - neoDVDstd是什么进程 有什么用
  • 社保征集单是什么样子的
  • 以前年度损益调整属于哪类科目
  • 小规模纳税企业在应交增值税明细科目
  • 应收票据其他应收款都需要提取坏账准备么
  • yii2整合百度编辑器umeditor及umeditor图片上传问题的解决办法
  • php读取数据输出html
  • php连接数据库的基本步骤是什么
  • php测验
  • php和mysql关系
  • 斯坦福大学起源
  • midjourney 初级使用说明
  • 一文速学-XGBoost模型算法原理以及实现+Python项目实战
  • 会计审核费用报销单的职责
  • uname命令功能
  • 政府购买服务交几险
  • 土地增值税预征税率一览表
  • 小程序渲染是什么意思
  • 印花税计提分录怎么写
  • windows11/windows10专业清理的系统工具Duplicate Cleaner5.0.13中文破解免费下载
  • 取得投资是什么意思
  • 服务器配置mysql
  • 个体工商户怎么开发票
  • 认缴出资额就是营业执照上的注册资金
  • 开具红字专用发票理由
  • 混凝土增值税发票税率
  • 注销时,其他应付款有余额,怎么冲减
  • 汇算清缴后补缴得企业所得税,计入哪年的税负
  • 诉讼财产保全保函
  • 付给销售人员的佣金会计分录
  • 分公司利润如何纳税
  • 公司的进账能打到私人卡上
  • 企业进行资产评估的目的可能是
  • 实收资本未到账减资要交税吗
  • 股权转让如何避免转让前债务
  • 自制原始凭证的填制
  • 开窗函数窗口范围
  • mysql 全量备份
  • winxp系统如何安装
  • win7 系统设置
  • win8的安全中心
  • win10大更新2020
  • win10怎么切任务管理
  • netfilter/iptables模块编译及应用
  • linux简单常用命令
  • 杂志内页广告
  • portainer集群管理
  • 动作手游排行榜2020前十名
  • nodejs image
  • unity5用什么语言
  • 安卓作业电量广播
  • 贵州省电子税务局操作手册
  • 18款凯美瑞中控屏
  • 买新房子需要交契税吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设