CesiumJS 案例 P18:检测文本、删除所有文本、隐藏与显示文本、改变文本

CesiumJS


一、检测文本

html 复制代码
<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<title>Label - 检测文本</title>
		<link rel="stylesheet" href="../js/Cesium-1.112/Build/Cesium/Widgets/widgets.css" />
		<style>
			* {
				margin: 0;
				padding: 0;
				box-sizing: border-box;
			}

			html,
			body {
				width: 100%;
				height: 100%;
			}

			.container {
				width: 100%;
				height: 100%;
			}

			.btn-remove-text {
				position: fixed;
				left: 0px;
				top: 0px;
			}

			.btn-check-text {
				position: fixed;
				left: 0px;
				top: 50px;
			}
		</style>
	</head>

	<body>
		<div id="container"></div>
		<button class="btn-remove-text">删除文本</button>
		<button class="btn-check-text">检测文本</button>
	</body>

	<script src="../js/Cesium-1.112/Build/Cesium/Cesium.js"></script>
	<script>
		const viewer = new Cesium.Viewer("container");

		const labels = viewer.scene.primitives.add(new Cesium.LabelCollection());

		const label = labels.add({
			text: "Hello World",
			position: Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883),
		});

		const btnMoveText = document.querySelector(".btn-remove-text");
		const btnCheckText = document.querySelector(".btn-check-text");

		btnMoveText.addEventListener("click", () => {
			labels.remove(label);
		});

		btnCheckText.addEventListener("click", () => {
			console.log(labels.contains(label));
		});
	</script>
</html>

二、删除所有文本

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Label - 删除文本</title>
        <link rel="stylesheet" href="../js/Cesium-1.112/Build/Cesium/Widgets/widgets.css" />
        <style>
            * {
                margin: 0;
                padding: 0;
                box-sizing: border-box;
            }

            html,
            body {
                width: 100%;
                height: 100%;
            }

            .container {
                width: 100%;
                height: 100%;
            }

            .btn-all-remove {
                position: fixed;
                left: 0px;
                top: 0px;
            }
        </style>
    </head>

    <body>
        <div id="container"></div>
        <button class="btn-all-remove">删除所有文本</button>
    </body>

    <script src="../js/Cesium-1.112/Build/Cesium/Cesium.js"></script>
    <script>
        const viewer = new Cesium.Viewer("container");

        const labels = viewer.scene.primitives.add(new Cesium.LabelCollection());

        labels.add({
            text: "Hello World",
            position: Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883),
        });

        labels.add({
            text: "Hello World",
            position: Cesium.Cartesian3.fromDegrees(-75.59777, 41.03883),
        });

        const btnAllRemove = document.querySelector(".btn-all-remove");

        btnAllRemove.addEventListener("click", () => {
            labels.removeAll();
        });
    </script>
</html>

三、隐藏与显示文本

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Label - 隐藏与显示文本</title>
        <link rel="stylesheet" href="../js/Cesium-1.112/Build/Cesium/Widgets/widgets.css" />
        <style>
            * {
                margin: 0;
                padding: 0;
                box-sizing: border-box;
            }

            html,
            body {
                width: 100%;
                height: 100%;
            }

            .container {
                width: 100%;
                height: 100%;
            }

            .btn-hide-or-show {
                position: fixed;
                left: 0px;
                top: 0px;
            }
        </style>
    </head>

    <body>
        <div id="container"></div>
        <button class="btn-hide-or-show">隐藏 / 显示文本</button>
    </body>

    <script src="../js/Cesium-1.112/Build/Cesium/Cesium.js"></script>
    <script>
        const viewer = new Cesium.Viewer("container");

        const labels = viewer.scene.primitives.add(new Cesium.LabelCollection());

        const label = labels.add({
            text: "Hello World",
            position: Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883),
        });

		const btnHideOrShow = document.querySelector(".btn-hide-or-show");

        btnHideOrShow.addEventListener("click", () => {
            label.show = !label.show;
        });
    </script>
</html>

四、改变文本

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Label - 改变文本</title>
        <link rel="stylesheet" href="../js/Cesium-1.112/Build/Cesium/Widgets/widgets.css" />
        <style>
            * {
                margin: 0;
                padding: 0;
                box-sizing: border-box;
            }

            html,
            body {
                width: 100%;
                height: 100%;
            }

            .container {
                width: 100%;
                height: 100%;
            }

            .btn-change {
                position: fixed;
                left: 0px;
                top: 0px;
            }
        </style>
    </head>

    <body>
        <div id="container"></div>
        <button class="btn-change">改变文本</button>
    </body>

    <script src="../js/Cesium-1.112/Build/Cesium/Cesium.js"></script>
    <script>
        const viewer = new Cesium.Viewer("container");

        const labels = viewer.scene.primitives.add(new Cesium.LabelCollection());

        const label = labels.add({
            text: "Hello World 1",
            position: Cesium.Cartesian3.fromDegrees(-75.59777, 40.03883),
        });

        const btnChange = document.querySelector(".btn-change");

        btnChange.addEventListener("click", () => {
            label.text = "Hello World 2";
        });
    </script>
</html>
相关推荐
SouthRosefinch22 分钟前
一、HTML简介与开发环境
开发语言·前端·html
全栈小537 分钟前
【前端】Vue 组件开发中的枚举值验证:从一个Type属性错误说起
前端·javascript·vue.js
Joker Zxc40 分钟前
【前端基础(Javascript部分)】4、JavaScript的分支语句
开发语言·前端·javascript
IT_陈寒44 分钟前
JavaScript 性能优化的5个隐藏技巧:90%开发者都不知道的实战方案!
前端·人工智能·后端
꧁꫞꯭零꯭点꯭꫞꧂1 小时前
G6绘制机柜 以及机柜设备的demo
前端·javascript·vue.js
C澒1 小时前
供应链产研交付提效:前端多业务线新增样板间页面统计方案
前端·mr
可视之道1 小时前
低代码可视化平台的前端架构设计:从渲染引擎到插件系统
前端
南城书生1 小时前
Android Kotlin 协程原理分析
前端
Lee川1 小时前
🚀 JavaScript 内存大揭秘:从“栈堆搬家”到“闭包时空胶囊”
前端·javascript·面试
唐叔在学习1 小时前
TodoList应用:SPA应用首屏性能优化实践
前端·javascript·性能优化