DEJA_VU3D - Cesium功能集 -完整地图标绘及编辑功能系列预告

这篇具有很好参考价值的文章主要介绍了DEJA_VU3D - Cesium功能集 -完整地图标绘及编辑功能系列预告。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码,尽可能把代码简洁一些)。博文内容如存在错误或者有可改进之处,也希望在这里和各位大佬交流提高一下。

介绍

在之前我有写过 DEJA_VU3D - Cesium功能集 之 完整军标组件系列 ,其中基本囊括了项目所需的态势标绘功能。最近有不少同学私聊反馈了一些问题,我总结了一下,大致包括:

① 功能集中的标绘在不添加地形时正常,添加地形偶尔会出现现实问题;

② 功能集中只有标绘,能否更新一下标绘后的对象的编辑功能

③ 有没有TS版本的标绘功能组件

针对这些问题,对之前的态势标绘功能集进行了更新和优化,博主准备重新更新一个新的地图标绘(态势标绘)系列,新的功能集基本实现了大多数(25+种几何类型)的地图标绘和态势标绘功能,并且对于所有标绘的对象都可以实现自由编辑,代码框架Vite+Vue3+TypeScript。接下来的几篇博文,每篇去实现一种或一类地图(态势)标绘和编辑功能,最后会整合所有编写成一个统一的地图(态势)组件,新的功能系列依旧会奉上所有的源代码!组件大致实现如图:

wangjianlei cesium,DEJA_VU3D - Cesium功能集(附源码),javascript,Cesium,VUE,态势标绘,标绘编辑,Powered by 金山文档

系列更新如下:

(持续更新)

地图标绘及编辑主文件

001 - 点(标绘+编辑)

002 - 广告版Billboard(标绘+编辑)

003 - 折线(标绘+编辑)

004 - 曲线(标绘+编辑)

005 - 自由线(标绘)

006 - 多边形(标绘+编辑)

007 - 正多边形(标绘+编辑)

组件基础形式:

/*
 * 地图-态势标绘主类
 * @Author: Wang jianLei
 * @Date: 2023-01-13 14:47:20
 * @Last Modified by: Wang JianLei
 * @Last Modified time: 2023-01-17 16:12:12
 */
import * as Creator from "./create/index";
import CreateRemindertip from "./thirdPart/ReminderTip";
import ObjectEdit from "./edit/index";
const Cesium = window.Cesium;
interface PlotObject {
  [key: string]: any[];
}
class MilitaryPlotting {
  viewer: any; //三维场景
  resultObject: PlotObject; //标绘结果
  handler: any;
  edit: ObjectEdit;
  constructor(viewer: any) {
    if (!viewer) throw new Error("no viewer object!");
    this.viewer = viewer;
    this.resultObject = {
      point: [], //点Entity集合
      billboard: [], //广告牌Entity集合
      lineArrow: [], //简单箭头Entity集合
      swallowtailArrow: [], //燕尾箭头Entity集合
      rightAngleArrow: [], //直角箭头Entity集合
      roundRectangle: [], //圆角矩形Entity集合
      sector: [], //扇形Entity集合
      bow: [], //弓形Entity集合
      pincerArrow: [], //钳击箭头Entity集合
      attackArrow: [], //进攻箭头Entity集合
      stagingArea: [], //集结地Entity集合
      flag: [], //旗标Entity集合
      freeLine: [], //自由线Entity集合
      polyline: [], //折线Entity集合
      curve: [], //圆滑曲线Entity集合
      freePolygon: [], //自由面Entity集合
      polygon: [], //多边形Entity集合
      regularPolygon: [], //正多边形Entity集合
    };
    this.handler = undefined;
    this.edit = new ObjectEdit(viewer);
  }
  /**
   * 绘制点
   * @param options - 参数,不传参为{}
   * @param callback - 回调函数
   */
  DrawPoint(options: any, callback?: Function) {
    this.initHandler();
    Creator.CreatePoint(
      this.viewer,
      this.handler,
      this.resultObject.point,
      options,
      callback
    );
  }
  /**
   * 绘制折线
   * @param options - 参数,不传参为{}
   * @param callback  回调函数
   */
  DrawPolyline(options: any, callback?: Function) {
    this.initHandler();
    Creator.CreatePolyline(
      this.viewer,
      this.handler,
      this.resultObject.polyline,
      options,
      callback
    );
  }
  /**
   * 绘制多边形
   * @param options - 参数,不传参为{}
   * @param callback  回调函数
   */
  DrawPolygon(options: any, callback?: Function) {
    this.initHandler();
    Creator.CreatePolygon(
      this.viewer,
      this.handler,
      this.resultObject.polygon,
      options,
      callback
    );
  }
  /**
   * 绘制广告版
   * @param options - 参数,不传参为{}
   * @param callback  回调函数
   */
  DrawBillboard(options: any, callback?: Function) {
    this.initHandler();
    Creator.CreateBillboard(
      this.viewer,
      this.handler,
      this.resultObject.billboard,
      options,
      callback
    );
  }
  /**
   * 绘制圆滑曲线
   * @param options - 参数,不传参为{}
   * @param callback  回调函数
   */
  DrawCurve(options: any, callback?: Function) {
    this.initHandler();
    Creator.CreateCurve(
      this.viewer,
      this.handler,
      this.resultObject.curve,
      options,
      callback
    );
  }
  /**
   * 初始化handler句柄
   */
  initHandler() {
    if (this.handler) {
      CreateRemindertip(window.toolTip, null, false);
      this.handler.destroy();
    }
    this.handler = new Cesium.ScreenSpaceEventHandler(this.viewer.canvas);
  }
  /**
   * 清除所有创建的对象
   */
  clearAll() {
    for (const key in this.resultObject) {
      if (Object.hasOwnProperty.call(this.resultObject, key)) {
        const element = this.resultObject[key];
        for (let index = 0; index < element.length; index++) {
          const el = element[index];
          this.viewer.entities.remove(el);
          element.splice(index, 1);
          index -= 1;
        }
      }
    }
  }
  /**
   * 注销
   */
  destroy() {
    this.initHandler();
    this.handler.destroy();
    this.clearAll();
  }
}
export default MilitaryPlotting;

综上!

如果客官您有问题,可以在本文下留言!

如果客官您有什么建议意见,可以在本文下留言!

如果客官您有批评指正,可以在本文下沟通讨论!

如果实例demo有数据缺失,评论留下您的邮箱地址!

如果客官您有其他的功能需求,可以在本文下留言,不管能不能实现,总会给出回复!文章来源地址https://www.toymoban.com/news/detail-802907.html

到了这里,关于DEJA_VU3D - Cesium功能集 -完整地图标绘及编辑功能系列预告的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • DEJA_VU3D - Cesium功能集 之 114-雷达效果(基础效果)

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代

    2024年02月02日
    浏览(53)
  • DEJA_VU3D - Cesium功能集 之 113-获取圆节点(2)

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代

    2024年01月22日
    浏览(43)
  • DEJA_VU3D - Cesium功能集 之 090-台风过境实时动画

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小130个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(尽可能把代码简洁一些)。博文

    2023年04月23日
    浏览(41)
  • DEJA_VU3D - Cesium功能集 之 108-如何提升浏览性能

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代

    2024年02月17日
    浏览(42)
  • DEJA_VU3D - Cesium功能集 之 079-对象材质:动态扩散圆

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有实现120个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码,尽可

    2024年02月02日
    浏览(36)
  • DEJA_VU3D - Cesium功能集 之 078-对象材质:图片轨迹线

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有实现120个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码,尽可

    2024年02月02日
    浏览(62)
  • DEJA_VU3D - Cesium功能集 之 034-可视域分析(纯前端)完整版

    编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有实现130个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码,尽可

    2024年02月14日
    浏览(52)
  • Cesium态势标绘专题-辅助文件

    本专题没有废话,只有代码,撸!

    2024年02月16日
    浏览(37)
  • cesium添加点、线、面、文字、图标、模型等标绘

    Cesium Entity是可以与样式化图形表示配对并定位在空间和时间上的数据对象,或者说Cesium 提供 Entity API 来绘制控件数据。所以我们添加的所有标绘都是entity Entity API简介 Cesium提供两类API: 面向图形开发人员的底层API,通常称为“Primitive API”。该API暴露最小限度的抽象,使用

    2024年02月09日
    浏览(36)
  • Cesium 3D中的通视分析功能

    通视分析是一种在地理空间中确定两个位置之间是否存在可见线的技术。在Cesium 3D中,我们可以利用其强大的功能集来进行通视分析。本文将介绍如何使用Cesium 3D进行通视分析,并提供相应的源代码。 在开始之前,我们需要确保已经正确加载了Cesium 3D库。接下来,我们将介绍

    2024年04月13日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包