You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

heading.js 1.0KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /**
  2. * @Author: Caven
  3. * @Date: 2020-04-11 00:41:47
  4. */
  5. import { Transform } from '@dc-modules/transform'
  6. import Parse from '@dc-modules/parse/Parse'
  7. const { Cesium } = DC.Namespace
  8. export default function heading(start, end) {
  9. let heading = 0
  10. let startPosition = Parse.parsePosition(start)
  11. let endPosition = Parse.parsePosition(end)
  12. startPosition = Transform.transformWGS84ToCartesian(startPosition)
  13. endPosition = Transform.transformWGS84ToCartesian(endPosition)
  14. let v = Cesium.Cartesian3.subtract(
  15. endPosition,
  16. startPosition,
  17. new Cesium.Cartesian3()
  18. )
  19. if (v) {
  20. Cesium.Cartesian3.normalize(v, v)
  21. let up = Cesium.Ellipsoid.WGS84.geodeticSurfaceNormal(
  22. startPosition,
  23. new Cesium.Cartesian3()
  24. )
  25. let east = Cesium.Cartesian3.cross(
  26. Cesium.Cartesian3.UNIT_Z,
  27. up,
  28. new Cesium.Cartesian3()
  29. )
  30. let north = Cesium.Cartesian3.cross(up, east, new Cesium.Cartesian3())
  31. heading = Math.atan2(
  32. Cesium.Cartesian3.dot(v, east),
  33. Cesium.Cartesian3.dot(v, north)
  34. )
  35. }
  36. return heading
  37. }