Cesium 加载geojson数据类型点线面

news2025/1/10 20:50:21

1.获取geojson数据,本地新建一个.ts文件放置数据导出,并引入

 获取geojson数据:

DataV.GeoAtlas地理小工具系列

import { scGeojson } from './geojson';

2.加载面

const addPolygonEvt = () => {
	viewer.dataSources.add(
		Cesium.GeoJsonDataSource.load(scGeojson, {
			clampToGround: true, // 贴地
			fill: Cesium.Color.AZURE.withAlpha(0.5),
		}),
	);
};

因为面数据贴地,边界线消失,所以,将面数据转为多线数据,加载一次边界线

3.加载边界线

import { polygonToLine, polygon } from '@turf/turf';
const addPolygonLine = () => {
	// 设置一个空数组,用来放置每个面的边界,geojson数据
	const lineArr: any[] = [];
	scGeojson.features.map((it) => {
		if (it.geometry && it.geometry.coordinates) {
			it.geometry.coordinates.map((item) => {
				let line = polygonToLine(polygon(item)); // 把多面转为多线
				lineArr.push(line);
			});
		}
	});
	// 1.遍历线数组,可以使用加载实体线方式,把每个面的边界线加载出来
	// 2.或则使用加载geojson数据方法,加载出来
	lineArr.map((it) => {
        // 加载实体方式
	    // viewer.entities.add({
		// 	polyline: {
		// 		positions: Cesium.Cartesian3.fromDegreesArray(
		// 			flatten(it.geometry.coordinates),
		// 		),
		// 		material: Cesium.Color.AQUA,
		// 		clampToGround: true,
		// 	},
		// });
        // 加载geojson方式
		viewer.dataSources.add(
			Cesium.GeoJsonDataSource.load(it, {
				clampToGround: true, // 贴地
				stroke: Cesium.Color.AQUA,
				strokeWidth: 1,
			}),
		);
	});
};

4.加载点

import { point, FeatureCollection } from '@turf/turf';
const addGeojsonPoint = () => {
	const pointGeoJson: FeatureCollection = {
		type: 'FeatureCollection',
		features: [],
	};
	scGeojson.features.map((it) => {
		pointGeoJson.features.push(point(it.properties.center, it.properties));
	});
	let data = viewer.dataSources.add(
		Cesium.GeoJsonDataSource.load(pointGeoJson, {}),
	);
	data.then((dataSource: any) => {
		const entities = dataSource.entities.values;
		for (const item in entities) {
			const entity = entities[item];
			// if (entity.point) {
			entity.billboard = {
				image: '/public/images/gg.png',
				color: Cesium.Color.AQUA,
				width: 40,
				height: 40,
				heightReference: Cesium.HeightReference.CLAMP_TO_GROUND, // 贴地
			};
			entity.label = {
				text: entity.name,
				font: '14px',
				pixelOffset: new Cesium.Cartesian3(0, 30, 0),
				fillColor: Cesium.Color.DARKGREEN,
			};
		}
	});
};

 效果:


hooks.ts代码:

import * as Cesium from 'cesium';
import { popInfo } from './config';
import { scGeojson } from './geojson';
import { polygonToLine, polygon, point, FeatureCollection } from '@turf/turf';
let viewer: any = {};
export function mountedEvt() {
	Cesium.Ion.defaultAccessToken =
		'';
	viewer = new Cesium.Viewer('cesiumContainer', {
		// baseLayerPicker: false,
	});
	mapFlyEvt(104.065735, 30.659462, 2000000);
	addPolygonEvt();
	addPolygonLine();
	addGeojsonPoint();
}
/**
 * @Description 加载geojson点位
 * @Author: wms
 * @Date: 2023-11-21 15:20:34
 */
const addGeojsonPoint = () => {
	const pointGeoJson: FeatureCollection = {
		type: 'FeatureCollection',
		features: [],
	};
	scGeojson.features.map((it) => {
		pointGeoJson.features.push(point(it.properties.center, it.properties));
	});
	let data = viewer.dataSources.add(
		Cesium.GeoJsonDataSource.load(pointGeoJson, {}),
	);
	data.then((dataSource: any) => {
		const entities = dataSource.entities.values;
		for (const item in entities) {
			const entity = entities[item];
			// if (entity.point) {
			entity.billboard = {
				image: '/public/images/gg.png',
				color: Cesium.Color.AQUA,
				width: 40,
				height: 40,
				heightReference: Cesium.HeightReference.CLAMP_TO_GROUND, // 贴地
			};
			entity.label = {
				text: entity.name,
				font: '14px',
				pixelOffset: new Cesium.Cartesian3(0, 30, 0),
				fillColor: Cesium.Color.DARKGREEN,
			};
		}
	});
	addPopEvt();
};
/**
 * @Description 弹窗
 * @Author: wms
 * @Date: 2023-11-17 11:02:33
 */
export const addPopEvt = () => {
	const dom = document.getElementById('popBox');
	let popBox: any = new Cesium.InfoBox(dom as string | Element);
	viewer.screenSpaceEventHandler.setInputAction(function onLeftClick(
		movement: any,
	) {
		let pickedObject = viewer.scene.pick(movement.position);

		if (
			Cesium.defined(pickedObject) &&
			pickedObject.id instanceof Cesium.Entity
		) {
			var entity = pickedObject.id;
			if (entity.position) {
				// 显示弹窗
				popBox.container.style.visibility = 'visible';
				// 获取位置信息
				let entityPosition = entity.position.getValue(
					viewer.clock.currentTime,
				);
				// 传递数据,由于我定义了一个map.js文件,所以没办法把点位数据直接传递给页面,只能用eventBus传递两个文件的数据
				popInfo.value = entity.properties;
				// 监听 Viewer 的 postRender 事件,在地图移动时更新弹窗位置
				viewer.scene.postRender.addEventListener(function () {
					try {
						if (entityPosition !== null) {
							let screenPosition =
								Cesium.SceneTransforms.wgs84ToWindowCoordinates(
									viewer.scene,
									entityPosition,
								);
							if (screenPosition) {
								let leftOffset =
									screenPosition.x -
									popBox.container.clientWidth / 2;
								let topOffset =
									screenPosition.y -
									popBox.container.clientHeight -
									18;
								popBox.container.style.left = leftOffset + 'px';
								popBox.container.style.top = topOffset + 'px';
							}
						}
					} catch (error) {
						console.log(error);
					}
				});
			} else {
				popBox.container.style.visibility = 'hidden';
			}
		} else {
			// 隐藏弹窗
			popBox.container.style.visibility = 'hidden';
		}
	}, Cesium.ScreenSpaceEventType.LEFT_CLICK);
};
/**
 * @Description 加载面数据
 * @Author: wms
 * @Date: 2023-11-21 09:36:22
 */
export const addPolygonEvt = () => {
	viewer.dataSources.add(
		Cesium.GeoJsonDataSource.load(scGeojson, {
			clampToGround: true, // 贴地
			fill: Cesium.Color.AZURE.withAlpha(0.5),
		}),
	);
};
/**
 * @Description 加载面边界
 * @Author: wms
 * @Date: 2023-11-21 14:59:04
 */
const addPolygonLine = () => {
	// 设置一个空数组,用来放置每个面的边界,geojson数据
	const lineArr: any[] = [];
	scGeojson.features.map((it) => {
		if (it.geometry && it.geometry.coordinates) {
			it.geometry.coordinates.map((item) => {
				let line = polygonToLine(polygon(item)); // 把多面转为多线
				lineArr.push(line);
			});
		}
	});
	// 遍历线数组,使用加载实体线方式,把每个面的边界线加载出来
	// 或则使用加载geojson数据方法,加载出来
	lineArr.map((it) => {
		// viewer.entities.add({
		// 	polyline: {
		// 		positions: Cesium.Cartesian3.fromDegreesArray(
		// 			flatten(it.geometry.coordinates),
		// 		),
		// 		material: Cesium.Color.AQUA,
		// 		clampToGround: true,
		// 	},
		// });
		viewer.dataSources.add(
			Cesium.GeoJsonDataSource.load(it, {
				clampToGround: true, // 贴地
				stroke: Cesium.Color.AQUA,
				strokeWidth: 1,
			}),
		);
	});
};
/**
 * @Description 数组扁平化处理
 * @Author: wms
 * @Date: 2023-11-21 14:50:59
 */
const flatten = (arr: any[]) => {
	let result: number[] = [];
	for (let i = 0; i < arr.length; i++) {
		if (Array.isArray(arr[i])) {
			result = result.concat(flatten(arr[i]));
		} else {
			result.push(arr[i]);
		}
	}
	return result;
};
/**
 * @Description 地图飞行动画
 * @Author: wms
 * @Date: 2023-11-21 15:11:14
 */
const mapFlyEvt = (lon: number, lat: number, height: number) => {
	const position = Cesium.Cartesian3.fromDegrees(lon, lat, height);
	// flyTo快速切换视角,带飞行动画,可以设置飞行时长
	viewer.camera.flyTo({
		destination: position,

		orientation: {
			heading: Cesium.Math.toRadians(0),

			pitch: Cesium.Math.toRadians(-90),

			roll: Cesium.Math.toRadians(0),
		},

		duration: 3, // 单位秒
	});
};

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue中data属性为什么是一个函数?

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;Vue篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来vue篇专栏内容:vue-data属性 目录 为什么data属性是一个函数而不是一个对象&#xff1f; 一、实例和组件定义dat…

golang指针学习

package mainimport "fmt"func main() {name:"飞雪无情"nameP:&name//取地址fmt.Println("name变量的内存地址为:",&name)fmt.Println("name变量的值为:",name)fmt.Println("name变量的内存地址为:",nameP)fmt.Prin…

【CSH 入门基础 9 -- 输出 csh 脚本中每一句命令】

文章目录 输出csh脚本中每一句命令 输出csh脚本中每一句命令 在 csh 或 tcsh 脚本中&#xff0c;如果你想要输出脚本中的每一句执行&#xff0c;你可以在脚本的开头使用 -v&#xff08;verbose&#xff09;选项。这个选项会使得 shell 在执行命令前先打印出来。 要在脚本中使…

Macs Fan Control Pro:掌握您的Mac风扇,提升散热效率

在Mac的世界里&#xff0c;每一个细节都显得格外重要。而其中&#xff0c;风扇的控制与调节则显得尤为重要。然而&#xff0c;原生的Mac系统并不提供直观的风扇控制工具&#xff0c;这使得许多Mac用户在处理高负荷任务时&#xff0c;风扇无法有效地进行散热&#xff0c;导致机器…

HugeGraph安装与使用

1、HugeGraph-Server与HugeGraph-Hubble下载 HugeGraph官方地址&#xff1a;https://hugegraph.apache.org/ 环境为&#xff1a;linux 官网是有模块版本对应关系,尽量下载较新版本,hubble1.5.0之前是studio功能比较少。官网已经下架server,其他模块下载也比较慢。可以在网上找…

Android13 新增 Stable AIDL接口

问题描述&#xff1a; 我需要在netd aidl 中添加新的接口&#xff1a; 设置网卡MAC地址&#xff1a; void setHardwareAddress(in utf8InCpp String iface, in utf8InCpp String hwAddr); 背景&#xff1a; Android 10 添加了对稳定的 Android 接口定义语言 (AIDL) 的支持&…

ros2机器人上位机与下位机连接方式(转载)

从硬件连接、通信协议和软件设计开发&#xff0c;上位机如何控制下位机&#xff1f; 由你创科技2023-09-07 10:38广东 随着科技的不断发展&#xff0c;自动化控制系统已经广泛应用于各个行业。在自动化控制系统中&#xff0c;上位机和下位机是两个重要的组成部分。上位机主要…

海外IP代理科普——API代理

随着互联网的不断发展&#xff0c;越来越多的企业开始使用API&#xff08;应用程序接口&#xff09;来实现数据的共享和交流。而在API使用中&#xff0c;海外代理IP也逐渐普及。那么&#xff0c;什么是API代理IP呢&#xff1f;它有什么作用&#xff1f;API接口有何用处&#xf…

Vue 3实战:打造交互丰富的任务管理应用

Vue 3实战&#xff1a;打造交互丰富的任务管理应用 前言搭建Vue 3项目步骤 1: 安装Vue CLI 3步骤 2: 创建Vue 3项目步骤 3: 进入项目目录步骤 4: 启动项目步骤 5: 查看项目结构 组件设计与复用1. **组件的职责单一化:**2. **Props传递:**3. **插槽&#xff08;Slots&#xff09…

虚拟机里为什么桥接模式可以广播,NAT模式不能广播?

在虚拟机网络配置中&#xff0c;桥接模式&#xff08;Bridged mode&#xff09;允许虚拟机在与主机相同的网络上作为一个独立的设备出现。这意味着虚拟机可以接收和发送广播消息&#xff0c;就像物理机器一样&#xff0c;因为它们处于同一个物理网络上。 相反&#xff0c;NAT模…

合肥中科深谷嵌入式项目实战——基于ARM语音识别的智能家居系统(三)

基于ARM语音识别的智能家居系统 我们上一篇&#xff0c;我们实现在Linux系统下编译程序&#xff0c;我们首先通过两个小练习来熟悉一下如何去编译。今天&#xff0c;我们来介绍一下LCD屏幕基本使用。 一、LCD屏幕基本使用 如何使用LCD屏幕&#xff1f; 1、打开开发板LCD设…

(02)vite环境变量配置

文章目录 将开发环境和生产环境区分开环境变量vite处理环境变量loadEnv 业务代码需要使用环境变量.env.env.development.env.test修改VITE_前缀 将开发环境和生产环境区分开 分别创建三个vite 的配置文件&#xff0c;并将它们引入vite.config.js vite.base.config.js import…

阿里云oss存储文件上传功能实现(保姆级教程)

先登录&#xff1a; 点击进入控制台 点击左上角导航栏按钮 搜索oss&#xff0c;点击进入 进入之后点击立即开通oss按钮&#xff0c;开通之后点击下图立即创建&#xff0c;弹出创建Bucket 填上Bucket名称&#xff0c;读写权限改为公共读。其他不变点击确定创建&#xff0c;完成…

SpringBoot中使用注解的方式创建队列和交换机

SpringBoot中使用注解的方式创建队列和交换机 前言 最开始蘑菇博客在进行初始化配置的时候&#xff0c;需要手动的创建交换机&#xff0c;创建队列&#xff0c;然后绑定交换机&#xff0c;这个步骤是非常繁琐的&#xff0c;而且一不小心的话&#xff0c;还可能就出了错误&…

【C++进阶之路】第七篇:异常

文章目录 一、C语言传统的处理错误的方式二、 C异常概念三、异常的使用1.异常的抛出和捕获2.异常的重新抛出3.异常安全4.异常规范 四、自定义异常体系五、C标准库的异常体系&#xff08;了解&#xff09;六、异常的优缺点 一、C语言传统的处理错误的方式 传统的错误处理机制&am…

2021秋招-算法-递归

算法-递归 教程: ⭐告别递归&#xff0c;谈谈我的一些经验 LeetCode刷题总结-递归篇 基础框架 leetcode刷题 1.leetcode-101. 对称二叉树-简单 101. 对称二叉树 给定一个二叉树&#xff0c;检查它是否是镜像对称的。 例如&#xff0c;二叉树 [1,2,2,3,4,4,3] 是对称的。…

docker通过挂载conf文件启动redis

初衷&#xff1a;之前直接在启动脚本中没有挂载配置文件&#xff0c;并且直接设置了密码等&#xff0c;后续要使用集群&#xff0c;苦于无法修改配置&#xff0c;进入redis容器也找不到redis.conf&#xff0c;所以写这个文章用来使用redis的配置&#xff0c;来达到后续都可动态…

Spring Boot要如何学习?【云驻共创】

Spring Boot 是由 Pivotal 团队提供的全新框架&#xff0c;其设计目的是用来简化新 Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置&#xff0c;从而使开发人员不再需要定义样板化的配置。我这里会分享一些学习Spring Boot的方法和干货&#xff0c;包括…

文章系列2:Unraveling the functional dark matter through global metagenomics

这篇文章发布于2023年10月nature。通讯作者是来自于 DOE Joint Genome Institute, Lawrence Berkeley National Laboratory, Berkeley, CA, USA. 背景介绍&目标 作者首先背景介绍了两种主流宏基因组分析方法&#xff0c;包括reads-based reference mapping&#xff08;eg…

PyTorch 之 Dataset 类入门学习

PyTorch 之 Dataset 类入门学习 Dataset 类简介 PyTorch 中的 Dataset 类是一个抽象类&#xff0c;用来表示数据集。通过继承 Dataset 类可以进行自定义数据集的格式、大小和其它属性&#xff0c;供后续使用&#xff1b; 可以看到官方封装好的数据集也是直接或间接的继承自 …