Cesium 设置空白处菜单和右键菜单

本文展示了如何在Cesium中添加右键菜单,包括在空白处和三维场景中的右键事件监听,通过HTML样式定义菜单,并结合JavaScript实现菜单显示与交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、先看效果

二、代码实现

1. 先在html页面中实现两个右键菜单的样式。

2. 设置ceisum中的鼠标右键监听事件

//鼠标右键事件监听
function EventListener_MouseRightClick (handler) {
    handler.setInputAction(function (evt) {

        
        //设置监听方法
        var scene = viewer.scene;
        pick = scene.pick(evt.position);

        // cartesian = scene.pickPosition(evt.position);    // 获取鼠标位置
        // cameraHeight = Math.ceil(viewer.camera.positionCartographic.height);     // 获取相机高度

        if (pick == undefined) {
            console.log("空白处右键菜单");
            document.getElementById("hamburger_example").style.display = ""; //显示div
            //调用页面菜单
            $(document).ready(function () {
                $("body").gizmoMenu({
                menu: "gizmoBurger",
                });
            });
        } else {
            console.log("实体处右键菜单,实体ID为:",pick.id.id);
            document.getElementById("modelRightMenu").innerHTML = "XX" + (pick.id.id).substring(0, 6);
            //显示模型菜单
            document.getElementById("gizmo").style.display = ""; //显示div
            //调用模型菜单
            $(document).ready(function () {
                // MODEL的菜单
                $("body").gizmoMenu({
                menu: "gizmoDropDown",
                });
            });
            viewer.trackedEntity = undefined;
        }

    }, Cesium.ScreenSpaceEventType.RIGHT_CLICK);
}

let handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
EventListener_MouseRightClick(handler);

### 绘制二维或三维坐标系的方法 #### 使用 Cesium 绘制三维坐标系 Cesium 是一种强大的 JavaScript 库,用于创建基于 WebGL 的地球空间可视化效果。要绘制三维坐标系,可以通过定义原点以及三个轴的方向向量来实现。以下是具体方法: 1. **初始化场景** 创建一个 Cesium Viewer 实例并加载默认的地图视图。 2. **定义坐标轴实体** 利用 `viewer.entities.add` 方法分别添加 X 轴、Y 轴 Z 轴的线段实体,并为其指定不同的颜色以便区分。 3. **设置坐标轴长度与方向** 坐标轴通常以单位向量表示其方向,例如 `(1, 0, 0)` 表示正 X 方向,`(0, 1, 0)` 表示正 Y 方向,`(0, 0, 1)` 表示正 Z 方向。 下面是完整的代码示例: ```javascript // 初始化 Cesium 场景 var viewer = new Cesium.Viewer('cesiumContainer'); // 添加 X 轴 (红色) viewer.entities.add({ name : 'X Axis', position : Cesium.Cartesian3.fromDegrees(0, 0, 0), model : { uri : './Assets/models/Cesium_Air/Cesium_Air.glb', // 可选模型资源路径 scale : 1, minimumPixelSize : 128 }, polyline : { positions : Cesium.Cartesian3.fromDegreesArrayHeights([0, 0, 0, 90, 0, 0]), width : 5, material : Cesium.Color.RED } }); // 添加 Y 轴 (绿色) viewer.entities.add({ polyline : { positions : Cesium.Cartesian3.fromDegreesArrayHeights([0, 0, 0, 0, 90, 0]), width : 5, material : Cesium.Color.GREEN } }); // 添加 Z 轴 (蓝色) viewer.entities.add({ polyline : { positions : Cesium.Cartesian3.fromDegreesArrayHeights([0, 0, 0, 0, 0, 90]), width : 5, material : Cesium.Color.BLUE } }); ``` 以上代码展示了如何利用 Cesium 来构建三维坐标系[^1]。 --- #### 使用 Python Matplotlib 绘制二维圆圈在三维坐标系中的表现 Matplotlib 提供了丰富的绘图功能,能够轻松地将二维图形嵌入到三维环境中。以下是一个简单的例子展示如何在一个三维坐标系中绘制二维圆形: ```python import matplotlib.pyplot as plt from matplotlib.patches import Circle import mpl_toolkits.mplot3d.art3d as art3d fig = plt.figure() ax = fig.add_subplot(111, projection='3d') # 定义二维圆形对象 p = Circle((5, 5), 3, facecolor="yellow") # 将二维圆形转换为三维对象 ax.add_patch(p) art3d.pathpatch_2d_to_3d(p, z=0, zdir="z") # 设置标题坐标轴标签 ax.set_title("2D circle in 3D", size=20) ax.set_xlabel("x") ax.set_ylabel("y") ax.set_zlabel("z") # 设定坐标范围 ax.set_xlim(0, 10) ax.set_ylim(0, 10) ax.set_zlim(0, 10) plt.show() ``` 上述脚本实现了在三维空间中放置一个黄色的二维圆形的效果[^2]。 --- #### Excel 中绘制二维坐标图表 Excel 并不直接支持三维坐标系的绘制,但它可以用来制作各种类型的二维图表,比如折线图、散点图等。如果希望模拟三维效果,则需借助透视或其他高级技巧完成。 对于普通的二维坐标表绘制流程如下: 1. 准备好两列数据作为横纵坐标; 2. 插入选项卡下的“散点图”或者“折线图”命令; 3. 自定义样式及格式化选项直至满足需求为止; 另外值得注意的是,在某些特殊情况下(如饼状统计图),还可以进一步美化数值显示方式——只需右键单击目标区域内的任意一处空白处调出快捷菜单,“设置数据标签格式”,再切换至‘数字’分类页签调整百分比例精度即可[^3]。 --- ### 总结 无论是采用专门针对地理信息系统设计的强大框架像 cesium.js 进行复杂的空间建模操作还是单纯依靠 python 结合第三方库matplotlib快速搭建基础几何形状演示平台亦或是日常办公软件 excel处理简单任务都各有千秋各有所长。根据实际应用场景选取合适的解决方案至关重要。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值