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

相关推荐
GISBox10 小时前
BIM+GIS协同:RVT文件转3DTiles的技术路径与场景落地
cesium·3dtiles·gisbox·服务分发·gis server·切片转换·rvt
GISBox1 天前
高斯泼溅转3DTiles:GISBox高效转换全流程指南
免费·cesium·ply·3dtiles·高斯泼溅·gisbox·切片转换
王将近3 天前
Cesium 山洪流体模拟
前端·cesium
qiao若huan喜4 天前
7、webgl 基本概念 + 前置数学知识点(向量 + 矩阵)
线性代数·矩阵·webgl
GisCoder4 天前
Cesium+Vue3学习教程系列(6)---实时显示鼠标三维坐标数据、实时显示相机姿态heading、pitch、roll数据
cesium
GIS瞧葩菜5 天前
【无标题】
开发语言·前端·javascript·cesium
qiao若huan喜6 天前
6、webgl 基本概念 + 四边形纹理
前端·javascript·信息可视化·webgl
GisCoder6 天前
Cesium+Vue3学习教程系列(2)---添加天地图影像、添加地形
cesium
爱看书的小沐7 天前
【小沐杂货铺】基于Three.js绘制三维管道Pipe(WebGL、vue、react)
javascript·vue.js·webgl·three.js·管道·pipe·三维管道