Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

heading.js 1.1KB

12345678910111213141516171819202122232425262728293031323334353637
  1. /**
  2. * @Author: Caven
  3. * @Date: 2020-04-11 00:41:47
  4. */
  5. import { Cesium } from '@dc-modules/namespace'
  6. import { Transform } from '@dc-modules/transform'
  7. import Parse from '@dc-modules/parse/Parse'
  8. export default function heading(start, end) {
  9. let startPosition = start
  10. let endPosition = end
  11. if (!(start instanceof Cesium.Cartesian3)) {
  12. startPosition = Parse.parsePosition(start)
  13. startPosition = Transform.transformWGS84ToCartesian(startPosition)
  14. }
  15. if (!(end instanceof Cesium.Cartesian3)) {
  16. endPosition = Parse.parsePosition(end)
  17. endPosition = Transform.transformWGS84ToCartesian(endPosition)
  18. }
  19. let ff = Cesium.Transforms.eastNorthUpToFixedFrame(startPosition)
  20. let v = Cesium.Cartesian3.subtract(
  21. endPosition,
  22. startPosition,
  23. new Cesium.Cartesian3()
  24. )
  25. let vector = Cesium.Matrix4.multiplyByPointAsVector(
  26. Cesium.Matrix4.inverse(ff, new Cesium.Matrix4()),
  27. v,
  28. new Cesium.Cartesian3()
  29. )
  30. Cesium.Cartesian3.normalize(vector, vector)
  31. let heading = Math.atan2(vector.y, vector.x) - Cesium.Math.PI_OVER_TWO
  32. return Cesium.Math.TWO_PI - Cesium.Math.zeroToTwoPi(heading)
  33. }