cesium文字实现避让功能

2024-03-07 23:30

本文主要是介绍cesium文字实现避让功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介:

cesium项目上,当文字特别多的时候,互相遮挡比较严重

这个时候,可以通过“文字避让”来解决

原始文字如下图:

使用避让功能后

实现思路:

1、把文字加载到cesium中

2、声明一个矩形集合,存储避让后的label的外包矩形,并提供了矩形相交的判断方法

3、获取每个文字对象在像素坐标系下的中心点、宽和高,并组装成矩形对象

4、对于步骤3中得到的矩形结果,与矩形集合的所有矩形进行相交判断

5、如果相交,则隐藏文字,并计算下一个;如果不相交,则加入到矩形集合,并显示文字

6、绑定相关事件,在每次camera改变的时候,重新计算

代码实现:

1、使用LabelCollection类来加载所有文字

const labelCol = scene.primitives.add(new Cesium.LabelCollection());
let oneLabel = labelCol.add({position: Cesium.Cartesian3.fromDegrees(-75.1641667, 39.9522222),text: "Philadelphia",
});

2、创建矩形集合对象

let rectangleCollisionCheck = new Cesium.RectangleCollisionChecker();

3、获取每个“文字对象”在像素坐标系下的宽和高

注意:这里说的宽和高,是指label对象中所有文字占用的宽和高,不是单个字母的宽和高

比如:“abc”这个文字对象,是指abc三个字母共同占有的范围,而不是对单个a、b、c的分别计算

//1、
//oneLabel的中心点,在屏幕坐标系下的坐标
//其中,默认中心点是在文字左下角
//可以通过horizontalOrigin、verticalOrigin这2个参数来改变中心点在文字的左下角还是右上角
let ssPos = oneLabel.computeScreenSpacePosition(viewer.scene);//2、
//拿到label对象中所有文字,在屏幕坐标系中占据的矩形大小
let boundingRectangle = Cesium.Label.getScreenSpaceBoundingBox(
oneLabel,ssPos
);//3、
//boundingRectangle转换为Rectangle
//此时计算的Rectangle,并不是真实的wgs84坐标系
//其本质还是屏幕坐标系,只是在形式上转换为Rectangle类型
//这样方便rectangleCollisionCheck类的使用
let { x, y, width, height } = boundingRectangle;
const west = x;
const south = y;
const east = x + width;
const north = y + height;
const rectangle = new Cesium.Rectangle(west, south, east, north);

4、相交判断

//判断步骤3中计算的矩形,与“矩形集合”中的其他矩形是否相交
let isCollide = rectangleCollisionCheck.collides(rectangle)

5、相交结果处理

if (isCollide) {//和集合中的其他rectangle有交集    oneLabel.show = false;continue;
} else {//和集合中的其他rectangle没有交集oneLabel.show = true;rectangleCollisionCheck.insert(id, rectanglePretend);//当前rectangle添加进矩形集合
}

6、绑定事件

viewer.camera.moveEnd.addEventListener(function () {//rectangleCollisionCheck._tree.clear();//重新进行上述3、4、5的步骤
})

这篇关于cesium文字实现避让功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/785196

相关文章

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超