Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

EditCircle.js 2.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /**
  2. * @Author: Caven
  3. * @Date: 2020-08-31 10:54:38
  4. */
  5. import { Cesium } from '@dc-modules/namespace'
  6. import { PlotEventType } from '@dc-modules/event'
  7. import { Transform } from '@dc-modules/transform'
  8. import Edit from './Edit'
  9. class EditCircle extends Edit {
  10. constructor(overlay) {
  11. super(overlay)
  12. this._center = undefined
  13. this._radius = 0
  14. }
  15. /**
  16. *
  17. * @private
  18. */
  19. _mountedHook() {
  20. this._radius = this._overlay.radius
  21. this._center = Transform.transformWGS84ToCartesian(this._overlay.center)
  22. this._positions = [].concat([
  23. this._center,
  24. this._computeCirclePoints(this._center, this._radius)[0]
  25. ])
  26. this._delegate.polygon.hierarchy = new Cesium.CallbackProperty(time => {
  27. if (this._positions.length > 1) {
  28. this._radius = Cesium.Cartesian3.distance(
  29. this._positions[0],
  30. this._positions[1]
  31. )
  32. if (this._radius <= 0) {
  33. return null
  34. }
  35. let pnts = this._computeCirclePoints(this._positions[0], this._radius)
  36. pnts.push(pnts[0])
  37. return new Cesium.PolygonHierarchy(pnts)
  38. } else {
  39. return null
  40. }
  41. }, false)
  42. this._layer.entities.add(this._delegate)
  43. }
  44. /**
  45. *
  46. * @param center
  47. * @param radius
  48. * @returns {*[]}
  49. * @private
  50. */
  51. _computeCirclePoints(center, radius) {
  52. let pnts = []
  53. let cep = Cesium.EllipseGeometryLibrary.computeEllipsePositions(
  54. {
  55. center: center,
  56. semiMajorAxis: radius,
  57. semiMinorAxis: radius,
  58. rotation: 0,
  59. granularity: 0.005
  60. },
  61. false,
  62. true
  63. )
  64. if (cep && cep.outerPositions) {
  65. pnts = Cesium.Cartesian3.unpackArray(cep.outerPositions)
  66. }
  67. return pnts
  68. }
  69. /**
  70. *
  71. * @private
  72. */
  73. _stopedHook() {
  74. this._overlay.center = Transform.transformCartesianToWGS84(
  75. this._positions[0]
  76. )
  77. this._overlay.radius = this._radius
  78. this._overlay.show = true
  79. this._options.onEditStop && this._options.onEditStop(this._overlay)
  80. }
  81. /**
  82. *
  83. * @private
  84. */
  85. _mountAnchor() {
  86. this._positions.forEach((item, index) => {
  87. this.editTool.fire(PlotEventType.CREATE_ANCHOR, {
  88. position: item,
  89. index: index,
  90. isCenter: index % 2 === 0
  91. })
  92. })
  93. }
  94. }
  95. export default EditCircle