three.js绘制地图(平面、曲面)

news/2024/5/19 5:27:31/文章来源:https://www.cnblogs.com/huangchun/p/16661275.html

加载中国地图json数据

let loader = new THREE.FileLoader();
loader.load('model/chinaJson.json', function (data) {let jsonData = JSON.parse(data);initMap(jsonData); // 解析并绘制地图
});

绘制曲面地图
image

function initMap( chinaJson ) {//创建一个空对象存放对象map = new THREE.Object3D();map.name = "china";// 遍历省份构建模型chinaJson.features.forEach( elem => {// 新建一个省份容器:用来存放省份对应的模型和轮廓线const province = new THREE.Object3D();const coordinates = elem.geometry.coordinates;coordinates.forEach( multiPolygon => {multiPolygon.forEach( polygon => {const lineMaterial = new THREE.LineBasicMaterial( { color: 0XF19553 } ); //0x3BFA9Econst positions = [];const linGeometry = new THREE.BufferGeometry();for (let i = 0; i < polygon.length; i ++) {var pos = lglt2xyz( polygon[i][0], polygon[i][1] );//将经纬度转为3D坐标positions.push( pos.x, pos.y, pos.z );}linGeometry.setAttribute( 'position', new THREE.Float32BufferAttribute( positions, 3 ) );const line = new THREE.Line( linGeometry, lineMaterial );province.add( line );} );} );map.add( province );map.scale.set(5,5,5);map.rotation.y = Math.PI;} );chinaGroup.add(map);chinaGroup.rotation.set(0.594, -0.348,-0.062);scene.add(chinaGroup);}

绘制平面地图
image

/*** 描绘中国边界(平面)需要传入Json数据*/function initMap(chinaJson){//创建一个空对象存放对象map = new THREE.Object3D();map.name = "china";//定义一个球体//墨卡托投影转换  将经纬度转为3D坐标值const projection = d3.geoMercator().center([104.0,37.5]).scale(80).translate([0,0]);chinaJson.features.forEach((elem,index) => {//定义一个省份3D对象const province = new THREE.Object3D();//每个的 坐标 数组const coordinates = elem.geometry.coordinates;//循环坐标数组coordinates.forEach(multiPolygon =>{multiPolygon.forEach( polygon =>{const shape = new THREE.Shape();const  lineMaterial = new THREE.MeshBasicMaterial({color:'white'})const lineGeometry = new THREE.Geometry();for(let i = 0; i< polygon.length; i++){const [x,y] = projection(polygon[i]);if(i === 0){shape.moveTo(x,-y);}shape.lineTo(x,-y);lineGeometry.vertices.push(new THREE.Vector3(x,-y,4.01));}//拉伸厚度const extrudeSettings = {depth:4,bevelEnabled:false};const geometry = new THREE.ExtrudeGeometry(shape,extrudeSettings);const material = new THREE.MeshBasicMaterial({color:'#02A1E2',transparent:true,opacity:0.6});const material1 = new THREE.MeshBasicMaterial({color:'#3480C4',transparent:true,opacity:0.5});//this.mesh = new THREE.Mesh(geometry,[material,material1]);const line = new THREE.Line(lineGeometry,lineMaterial);// // 设置高度将省区分开来// if (index % 2 === 0) {//     this.mesh.scale.set(1, 1, 1.2);// }// province.add(this.mesh);province.add(line);})})//将geo的属性放到省份模型中province.properties = elem.properties;if(elem.properties.contorid){const [ x,y] = projection(elem.properties.contorid);province.properties._centroid =[x,y];}map.add(province);map.scale.set(0.2,0.2,0.2);})chinaGroup.add(map);scene.add(chinaGroup);}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_5726.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue指令

Vue指令分为内置指令和自定义指令 内置指令 v-bind 单向绑定解析表达式&#xff0c; 简写&#xff1a; &#xff1a;xxx <div id"root">单项数据绑定&#xff1a;<input type"text" v-bind:value"name"><br></div> v…

2023秋招——快手数据研发一、二面面经

&#x1f33c;今天来总结一下快手数据研发的一、二面&#xff0c;在面试中进步&#xff0c;在总结中成长&#xff01;对往期内容感兴趣的小伙伴可以参考下面&#x1f447;&#xff1a; 链接: 2022暑期实习字节跳动数据研发面试经历-基础数仓.链接: 2022百度大数据开发工程师实…

three.js实现鼠标拾取例子

基本思路 <script> var renderer,scene,camera; var light; var raycaster,//相机->鼠标的射线mouse,//鼠标所在位置actionObject;//选中的物体 init(); animation();function init(){//渲染器//场景//相机//方向光//创建2000个立方体//创建射线//创建鼠标二维向量(圆…

epoll实现异步请求数据---以UDP为例

文章目录同步UDP请求数据的问题异步请求的模型具体的代码同步UDP请求数据的问题 不管是请求DNS资源还是其他资源。如果以串行的方式请求数据&#xff0c;也就是send以后recv阻塞等待获取数据&#xff0c;这样做的效率非常低效&#xff0c;网络延迟、服务器处理请求、再加上rec…

【C# 学习笔记 ②】C#基本语法(数组、判断和循环、字符串、枚举、结构体)

由于在自己的工作和学习过程中&#xff0c;只查看某个大佬的教程或文章无法满足自己的学习需求和解决遇到的问题&#xff0c;所以自己在追赶大佬们步伐的基础上&#xff0c;又自己总结、整理、汇总了一些资料&#xff0c;方便自己理解和后续回顾&#xff0c;同时也希望给大家带…

【我不熟悉的css】07. css命名,bem规范,跟着组件库element-ui学习组件命名

在去年&#xff0c;我总结了一篇文章&#xff0c;跟着element-ui学习css命名 【系统学习css】跟着element-ui学习css的命名_我有一棵树的博客-CSDN博客每日鸡汤&#xff0c;每一个你想要学习的念头都是未来的你向自己求救写css 最烦人的就是给class起名字了&#xff0c;这里不…

这一次,我们把AI自治数据库带到了世界人工智能大会上

9月3日,2022世界人工智能大会(WAIC)在上海圆满落幕。WAIC2022 秉持“智联世界”理念,通过线上线下联动的会展形式,汇聚顶级科学家、企业家、政府官员、专家学者、国际组织、投资人、创新团队一同探讨科技前沿话题,推动全球“共创、共建、共融、共治、共享、共赢”。WAIC …

【Python刷题篇】——Python入门 09 字典(上)

&#x1f935;‍♂️ 个人主页: 北极的三哈 个人主页 &#x1f468;‍&#x1f4bb; 作者简介&#xff1a;Python领域新星创作者。 &#x1f4d2; 系列专栏&#xff1a;《牛客题库-Python篇》 &#x1f310;推荐《牛客网》——找工作神器|笔试题库|面试经验|实习经验内推&am…

【数据结构与算法】之深入解析“乘法表中第K小的数”的求解思路与算法示例

一、题目要求 几乎每一个人都用乘法表,但是你能在乘法表中快速找到第 k 小的数字吗?乘法表是大小为 m x n 的一个整数矩阵,其中 mat[i][j] == i * j(下标从 1 开始)。给你三个整数 m、n 和 k,请你在大小为 m x n 的乘法表中,找出并返回第 k 小的数字。示例 1:输入:m =…

MATLAB | 全网唯一,三元相映射图绘制(三元相分级统计地图)

示例 对上期的补充 本期文章名叫三元相映射图绘制&#xff0c;但不单单讲这一点&#xff0c;同时会对上一篇多元映射地图做出补充https://slandarer.blog.csdn.net/article/details/126702967&#xff1a; 上篇中可以绘制这样的三变量映射地图&#xff1a; 但这只是对多边形…

Vue学习之--------路由(Router)的基本使用(1)(2022/9/5)

理解&#xff1a; 一个路由&#xff08;route&#xff09;就是一组映射关系&#xff08;key - value&#xff09;&#xff0c;多个路由需要路由器&#xff08;router&#xff09;进行管理。前端路由&#xff1a;key是路径&#xff0c;value是组件。控制页面的跳转 文章目录1、基…

01-linux基础命令

1、常用命令 常用Linux命令的基本使用序号命令对应英文作用01 ls list 查看当前目录下的内容02 pwd print working derectory 查看当前所在文件夹03 cd [目录名] change directory 切换文件夹04 touch [文件名] touch 如果文件不存在, 新建文件05 mkdir [目录名] make director…

【JavaSE】多线程篇(三)用户线程、守护线程与线程的7大状态

&#x1f481; 个人主页&#xff1a;黄小黄的博客主页 ❤️ 支持我&#xff1a;&#x1f44d; 点赞 &#x1f337; 收藏 &#x1f918;关注 &#x1f38f; 格言&#xff1a;All miracles start from sometime somewhere, make it right now. 本文来自专栏&#xff1a;JavaSE从入…

关于使用@Scheduled()注解造成的多任务冲突问题解决

问题描述&#xff1a; 2022-08-18 01:59:00.001 INFO [irms-transfer-service,,,] 15 --- [ scheduling-1] c.s.i.t.service.impl.ProjectManageSvc : -------定时扫描导出任务开启------- 2022-08-18 01:59:00.004 INFO [irms-transfer-service,,,] 15 --- [ schedu…

如何查看navicat已连接用户的密码

1:从注册表中查看加密后的密码。1.1:windows键+r,输入 regedit1.2:在注册表中找到 \HKEY_CURRENT_USER\SOFTWARE\PremiumSoft\navicat\servers 并找到 UserName 即 账号1.3:从上面步骤中,打开注册表、并找到如下图片中的密码栏:Pwd(加密的密码)2:解密密码,打开在线工…

React 应用程序中的简单路由

React 应用程序中的简单路由一个简单的、可扩展的路由解决方案可以满足您的应用程序的所有需求,而不会引入像 React-Router 这样的工具所提供的复杂性。 进入: 浏览器的 窗口位置 目的。 它提供了为您的应用程序创建一个简单的“路由”系统所需的一切。例如,这里是什么 窗口…

【Selenium Other】一键杀死进程 进程清理大师

前言 有位读者留言&#xff0c;遇到了一件两难全的事儿。在关闭Python使用os模块执行cmd命令调用的chromedriver驱动打开的chrome浏览器时&#xff0c;有以下问题~ 使用driver.quit()退出浏览器&#xff0c;chromedriver.exe进程退出&#xff0c;关闭没有窗口使用driver.close(…

2021年中青杯B题港珠澳大桥桥梁设计与安全策略数学建模全过程文档及程序

港珠澳大桥桥梁设计与安全策略 原题再现 “港珠澳大桥是国家工程、国之重器&#xff0c;其建设创下多项世界之最&#xff0c;非常了不起&#xff0c;体现了一个国家逢山开路、遇水架桥的奋斗精神&#xff0c;体现了我国综合国力、自主创新能力&#xff0c;体现了勇创世界一流的…

nuxt vue 按住鼠标左右滑动方案收集

目录前言vue-dragscrollvuescroll自己写个指令参考前言 最近在做PC端网页左右滑动&#xff0c;找到以下3种方案&#xff0c;做个记录。 vue-dragscroll 官方文档&#xff1a;https://vue-dragscroll.donfalcon.com/安装&#xff08;注意版本&#xff09; npm install vue-d…

VUE 如何将父组件中的数据传递到子组件中

在我们的项目中我们使用 axios 进行异步调用。 因为异步调用的问题,如果我不采取手段,子页面没有办法获得父页面中的数据,页面将会显示为 没有数据。问题和解决 这个问题的原因就是子组件在初始化的时候,父组件还没有获得数据。 可以使用的方法是 v-if 进行判断。 对比上面…