| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- /**
- * @Author: Caven
- * @Date: 2020-08-30 23:12:09
- */
-
- import Edit from './Edit'
-
- const { Transform } = DC
-
- const { Cesium } = DC.Namespace
-
- class EditPolygon extends Edit {
- constructor(overlay) {
- super()
- this._overlay = overlay
- this._positions = []
- }
-
- _mountEntity() {
- this._delegate = new Cesium.Entity()
- this._delegate.merge(this._overlay.delegate)
- this._overlay.show = false
- this._delegate.polygon.hierarchy = new Cesium.CallbackProperty(time => {
- if (this._positions.length > 2) {
- return new Cesium.PolygonHierarchy(this._positions)
- } else {
- return null
- }
- }, false)
- this._layer.add(this._delegate)
- }
-
- _mountAnchor() {
- let positions = [].concat(
- this._overlay.delegate.polygon.hierarchy.getValue(Cesium.JulianDate.now())
- .positions
- )
- positions.push(positions[0])
- for (let i = 0; i < positions.length - 1; i++) {
- let mid = this.computeMidPosition(positions[i], positions[i + 1])
- this._positions.push(positions[i])
- this._positions.push(mid)
- }
- this._positions.forEach((item, index) => {
- this.createAnchor(item, index, index % 2 !== 0)
- })
- }
-
- _onClick(e) {
- if (this._isMoving) {
- this._isMoving = false
- if (this._pickedAnchor && this._pickedAnchor.position) {
- let position = this._clampToGround ? e.surfacePosition : e.position
- this._pickedAnchor.position.setValue(position)
- let properties = this._pickedAnchor.properties.getValue(
- Cesium.JulianDate.now()
- )
- let currentIndex = properties.index
- if (properties.isMid) {
- let preMidPosition
- let nextMidPosition
- let len = this._positions.length
- if (currentIndex === len - 1) {
- preMidPosition = this.computeMidPosition(
- this._positions[currentIndex],
- this._positions[currentIndex - 1]
- )
- nextMidPosition = this.computeMidPosition(
- this._positions[currentIndex],
- this._positions[0]
- )
- } else {
- preMidPosition = this.computeMidPosition(
- this._positions[currentIndex],
- this._positions[currentIndex - 1]
- )
- nextMidPosition = this.computeMidPosition(
- this._positions[currentIndex],
- this._positions[currentIndex + 1]
- )
- }
- this._positions.splice(
- properties.index,
- 1,
- preMidPosition,
- position,
- nextMidPosition
- )
- this._anchorLayer.removeAll()
- this._anchors = []
- this._positions.forEach((item, index) => {
- this.createAnchor(item, index, index % 2 !== 0)
- })
- }
- }
- } else {
- this._isMoving = true
- if (!e.target.id) {
- return false
- }
- this._pickedAnchor = e.target.id
- }
- }
-
- _onMouseMove(e) {
- this._tooltip.showAt(e.windowPosition, '点击锚点移动,右击结束编辑')
- if (!this._isMoving) {
- return
- }
- if (this._pickedAnchor && this._pickedAnchor.position) {
- let properties = this._pickedAnchor.properties.getValue(
- Cesium.JulianDate.now()
- )
- let position = this._clampToGround ? e.surfacePosition : e.position
- let currentIndex = properties.index
- this._pickedAnchor.position.setValue(position)
- this._positions[currentIndex] = position
- let len = this._positions.length
- if (!properties.isMid) {
- let preAnchorIndex = -1
- let preMidAnchorIndex = -1
- let nextAnchorIndex = -1
- let nextMidAnchorIndex = -1
- if (currentIndex === 0) {
- preAnchorIndex = len - 2
- preMidAnchorIndex = len - 1
- nextAnchorIndex = currentIndex + 2
- nextMidAnchorIndex = currentIndex + 1
- } else if (currentIndex === len - 2) {
- preAnchorIndex = currentIndex - 2
- preMidAnchorIndex = currentIndex - 1
- nextAnchorIndex = 0
- nextMidAnchorIndex = len - 1
- } else {
- preAnchorIndex = currentIndex - 2
- preMidAnchorIndex = currentIndex - 1
- nextAnchorIndex = currentIndex + 2
- nextMidAnchorIndex = currentIndex + 1
- }
- let preMidPosition = this.computeMidPosition(
- this._positions[preAnchorIndex],
- this._positions[currentIndex]
- )
- let nextMidPosition = this.computeMidPosition(
- this._positions[nextAnchorIndex],
- this._positions[currentIndex]
- )
- this._positions[preMidAnchorIndex] = preMidPosition
- this._positions[nextMidAnchorIndex] = nextMidPosition
- this._anchors[preMidAnchorIndex].position.setValue(preMidPosition)
- this._anchors[nextMidAnchorIndex].position.setValue(nextMidPosition)
- }
- }
- }
-
- _onRightClick(e) {
- this.unbindEvent()
- this._overlay.positions = Transform.transformCartesianArrayToWGS84Array(
- this._positions
- )
- this._overlay.show = true
- this._plotEvent.raiseEvent(this._overlay)
- }
- }
-
- export default EditPolygon
|