|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- /**
- * @Author: Caven
- * @Date: 2020-08-29 21:24:55
- */
-
- import { Cesium } from '@dc-modules/namespace'
- import { PlotEventType } from '@dc-modules/event'
- import { Transform } from '@dc-modules/transform'
- import { Circle } from '@dc-modules/overlay'
- import Draw from './Draw'
-
- const DEF_STYLE = {
- material: Cesium.Color.YELLOW.withAlpha(0.6),
- fill: true
- }
-
- class DrawCircle extends Draw {
- constructor(style) {
- super()
- this._maxAnchorSize = 2
- this._radius = 0
- this._style = {
- ...DEF_STYLE,
- ...style
- }
- }
-
- /**
- *
- * @private
- */
- _mountedHook() {
- this.drawTool.tooltipMess = '单击选择点位'
- this._delegate = new Cesium.Entity({
- polygon: {
- ...this._style,
- hierarchy: new Cesium.CallbackProperty(() => {
- if (this._positions.length > 1) {
- this._radius = Cesium.Cartesian3.distance(
- this._positions[0],
- this._positions[1]
- )
- if (this._radius <= 0) {
- return null
- }
- let cep = Cesium.EllipseGeometryLibrary.computeEllipsePositions(
- {
- center: this._positions[0],
- semiMajorAxis: this._radius,
- semiMinorAxis: this._radius,
- rotation: 0,
- granularity: 0.005
- },
- false,
- true
- )
- let pnts = Cesium.Cartesian3.unpackArray(cep.outerPositions)
- pnts.push(pnts[0])
- return new Cesium.PolygonHierarchy(pnts)
- } else {
- return null
- }
- }, false)
- }
- })
- this._layer.entities.add(this._delegate)
- }
-
- /**
- *
- * @private
- */
- _stopdHook() {
- let circle = new Circle(
- Transform.transformCartesianToWGS84(this._positions[0]),
- this._radius
- ).setStyle(this._style)
- this._options.onDrawStop && this._options.onDrawStop(circle)
- }
-
- /**
- *
- * @param position
- * @private
- */
- _onDrawAnchor(position) {
- let len = this._positions.length
- this._positions.push(position)
- this.drawTool.fire(PlotEventType.CREATE_ANCHOR, {
- position,
- isCenter: len === 1
- })
- if (len >= this._maxAnchorSize) {
- this._positions.pop()
- this.drawTool.fire(PlotEventType.DRAW_STOP)
- }
- }
- }
-
- export default DrawCircle
|