Cesium教程(9)---编辑Entity图形控制点、拖拽Entity移动、删除Entity

本学习系列将以Cesium + Vue3 +Typescript+elementplus作为主要技术栈展开,后续会循序渐进,持续探索Cesium的高级功能,相关源码全部免费公开。详情请查看原文 Cesium教程9--编辑Entity图形控制点、拖拽Entity移动、删除Entity

上篇主要介绍如何使用Cesium标绘简单的点、线以及多边形。本篇在上篇的基础上增加图形编辑功能,比如拖动图形控制点、移动图形位置、删除图形等。先看效果 主要代码

Typescript 复制代码
import {
    Entity, Cartesian3, defined, ScreenSpaceEventHandler,
    ScreenSpaceEventType, Viewer
} from 'cesium';
import { EditHelper } from './EditHelper';
import EventDispatcher from '../EventDispatcher/EventDispatcher';
export class MultiEditManager {
    private viewer: Viewer;
    private handler: ScreenSpaceEventHandler;
    private activeEditor?: { entity: Entity; helper: EditHelper };
    private static instance: MultiEditManager;
    private dispatcher: EventDispatcher;
    constructor(viewer: Viewer,dispatcher: EventDispatcher) {
        this.viewer = viewer;
        this.handler = new ScreenSpaceEventHandler(viewer.canvas);
        this.bindClick();
        this.bindKeyDelete();
        this.dispatcher = dispatcher;
    }
    /** 绑定Delete键删除当前编辑entity */
    private bindKeyDelete() {
        window.addEventListener('keydown', (e) => {
            if (e.key === 'Delete' && this.activeEditor?.entity) {
                this.viewer.entities.remove(this.activeEditor.entity);                
                this.clear();
                this.dispatcher.dispatchEvent('EDITEND',{text:""});
            }
        });
    }
    // 获取单例实例
    public static getInstance(viewer?: Viewer, dispatcher?: EventDispatcher): MultiEditManager {
        if (!MultiEditManager.instance) {
            if (!viewer) throw new Error("MultiEditManager需要传入viewer实例");
            if (!dispatcher) throw new Error("MultiEditManager需要传入dispatcher实例");
            MultiEditManager.instance = new MultiEditManager(viewer, dispatcher);
        }
        return MultiEditManager.instance;
    }
    /** 把画好的 entity 登记进来(由外部调用) */
    register(entity: Entity, positions: Cartesian3[]) {
        (entity as any)._editPositions = positions.map(p => p.clone());
    }
    /** 销毁管理器 */
    destroy() {
        this.clear();
        this.handler.destroy();
    }
    /** 绑定单击 */
    private bindClick() {
        this.handler.setInputAction((e: any) => this.onClick(e), ScreenSpaceEventType.LEFT_CLICK);
    }
    /** 单击逻辑 */
    private onClick(e: any) {
        const picked = this.viewer.scene.pick(e.position);
        if (defined(picked) && defined(picked.id) && (picked.id as any)._editPositions) {
            // 点到了可编辑 entity
            const entity = picked.id as Entity;         
         
            if (this.activeEditor?.entity === entity) return; // 已经是它,忽略
            this.clear();               // 先关掉之前的
            this.startEdit(entity);     // 打开新的           
            this.dispatcher.dispatchEvent('EDITSTART',{text:"编辑开始,可拖动控制点编辑、可拖动图形移动位置,delete键删除当前图形;点击空白,结束编辑;"});
        } else {
            // 点到空白
            this.clear();
            this.dispatcher.dispatchEvent('EDITEND',{text:""});
        }
    }
    /** 启动某个 entity 的编辑 */
    private startEdit(entity: Entity) {
        const positions: Cartesian3[] = (entity as any)._editPositions;
        const helper = new EditHelper(this.viewer, entity, positions, (newP) => {           
            (entity as any)._editPositions = newP; // 其实引用没变,只是兜底
        });
        helper.start();
        this.activeEditor = { entity, helper };
    }
    /** 关闭当前编辑 */
    private clear() {
        if (!this.activeEditor) return;
        this.activeEditor.helper.destroy();
        this.activeEditor = undefined;
    }
}

更多源码请查看原文 Cesium教程9--编辑Entity图形控制点、拖拽Entity移动、删除Entity

相关推荐
ct9784 小时前
Cesium的Primitive API
gis·webgl·cesium
Irene19911 天前
OpenLayers 和 Cesium 都是流行的开源 JavaScript 库,用于在网页上构建地图和地理空间应用
openlayers·cesium
fxshy1 天前
前端直连模型 vs 完整 MCP:大模型驱动地图的原理与实践(技术栈Vue + Cesium + Node.js + WebSocket + MCP)
前端·vue.js·node.js·cesium·mcp
棋鬼王2 天前
Cesium(十) 动态修改白模颜色、白模渐变色、白模光圈特效、白模动态扫描光效、白模着色器
前端·javascript·vue.js·智慧城市·数字孪生·cesium
duansamve2 天前
Cesium快速入门到精通系列教程二十四:限制相机在特定的Level之间展示地图
cesium
sin°θ_陈3 天前
前馈式3D Gaussian Splatting 研究地图(路线二):几何优先的前馈式 3DGS——前馈式 3DGS 如何重新拥抱多视图几何
深度学习·3d·webgl·三维重建·空间计算·3dgs·空间智能
星河耀银海4 天前
3D效果:HTML5 WebGL结合AI实现智能3D场景渲染
前端·人工智能·深度学习·3d·html5·webgl
点量云实时渲染-小芹5 天前
Unity模型数字孪生虚拟仿真webgl推流卡实时云渲染推流
unity·webgl·数字孪生·实时云渲染·虚拟仿真·云推流
duansamve5 天前
Vue3的Vite项目中直接引入的方式使用Cesium
cesium
WebGISer_白茶乌龙桃6 天前
基于 Cesium 的 GLB 建筑模型分层分房间点击拾取技术实现
前端·javascript·vue.js·webgl·cesium