基于cesiumn的标绘,支持VUE3
- 贴图类
- 红旗
- 地面贴图
- 3D模型
- 地面模型(地面站)
- 带有高度的参数的模型(卫星)
- 图钉
- 文本图钉
- 图标图钉
- 图片图钉
- 自定义图片图钉
- 点类型
- 单点
- 多边形
- 单箭头
- 圆形
- 圆弧面
- 椭圆
- 方型旗
- 三角旗
- 多段线
- 钳击箭头
- 多边形
- 矩形
- 扇形
- 平滑面
- 方箭头
- 线
- 2阶bezier曲线
- 3阶bezier曲线
- N阶bezier曲线
- bezier平滑线
- 圆弧线
- 带顶点的折线
- 带顶点的平滑线
- 多段线
- 线段
- 测量工具
- 距离测量
- 角度测量
- 面积测量
npm install cesium-plotting-symbol --save
注意: 需要将cesium的公共资源(cesium/Build/Cesium)复制到你的项目的public(或者static)目录下,保证下列路径正确:
/public/Cesium/Widgets/widgets.css
import {GraphManager} from 'cesium-plotting-symbol'
let gm = new GraphManager(viewer, {
layerId: 'testbh1',
editAfterCreate: true
}
viewer是cesium的 Cesium.Viewer的实例
可以使用内置的propEditor:
import PropEditor from 'cesium-plotting-symbol/PropEditor/index.vue'
<PropEditor ref="propEdit" /> <!-- 在html template 中插入prop-editor组件 -->
让propHandler响应Graph Select事件:
const propEdit = ref();
gm.value.setGraphSelectHandler( (ent: Graph) => {
if (ent) {
propEdit.value.show(true, ent)
let propDefs = ent.propDefs
let props = ent.props
console.log("handle select ent in top", propDefs, props)
} else {
propEdit.value.show(false, ent)
console.log("unselect")
}
})
也可以使用自定义的属性编辑功能,gm.value.setGraphSelectHandler 可以指定一个图形选择函数,当某个图形被选择时,会调用此方法。 ent.props 和 ent.propDefs 分别是此图形的属性值json和属性定义数据。当外部修改ent.props中的内容时,系统会根据新的数据更新当前图形。
通过鼠标和键盘控制图形的绘制过程
gm.create({obj: 'Polygon', color: '#00FF00'})
根据传入的参数直接绘制图形到地图上
gm.draw({obj: 'Point', color: '#00f', pixelSize: 12, alpha: 0.8, ctls: [{lon: 110, lat: 45}]})
在经纬度(110, 45)绘制一个大小为12, 蓝色,透明度0.8的点。
graph是gm.create()的返回值,用来持有图形对象,目前提供以下功能: graph.getCtlPositions() // 返回图形的所有控制点的坐标,
graph.getCtlPositions().map((po) => {
return gm.mapUtil.convertCartesian(po)
}))
观察模式下,不能对图形作任何操作,进入观察模式:
gm.finish()
选择模式下,鼠标经过图形时,图形会高亮,点击鼠标左键可以选择图形,并进入图形编辑模式,以下代码进入选择模式:
gm.start()
在图形编辑模式下,当前图形的控制点和辅助线是可见的,并且鼠标可以拾取控制点,放下控制点,通过对控制点的移动实现对图形的编辑。
删除当前选中的图形
gm.delete()
删除所有图形
gm.deleteAll()
保存当前所有标绘到一个json对象列表
let json = cps.save()
从json中获取标绘图形列表,并直接绘制在地图上
gm.load(json)
'ctrl+shift+d', 'shift+delete': 清除所有图形
'delete', 'ctrl+d': 删除当前正在编辑的图形
见(https://github.com/renshuo/cesium-plotting-symbol/tree/master/src/App.vue)