PesExtensions.cs 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. using Ips.Library.Basic;
  2. using Ips.Library.Entity;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace Ips.Sps.TskResults.Peses
  9. {
  10. public static class PesExtensions
  11. {
  12. public static double[] GetSigLLA(this Pes pes)
  13. {
  14. return new double[] { pes.SigLon, pes.SigLat, pes.SigAlt };
  15. }
  16. public static double[] GetMainAntLLA(this Pes pes)
  17. {
  18. double[] results = null;
  19. if (pes.MainSatId > 0)
  20. {
  21. results = new double[] { pes.MainAntLon, pes.MainAntLat, pes.MainAntAlt };
  22. }
  23. else
  24. {
  25. results = GetSigLLA(pes);
  26. }
  27. return results;
  28. }
  29. public static double[] GetAdjaAntLLA(this Pes pes)
  30. {
  31. return new double[] { pes.AdjaAntLon, pes.AdjaAntLat, pes.AdjaAntAlt };
  32. }
  33. public static double[] GetMainEphXYZ(this Pes pes)
  34. {
  35. double[] results = null;
  36. if (pes.MainSatId > 0)
  37. {
  38. results = new double[] { pes.MainEphX, pes.MainEphY, pes.MainEphZ, pes.MainEphVx, pes.MainEphVy, pes.MainEphVz };
  39. }
  40. else
  41. {
  42. var xyz = GeoUtil.LLA2XYZ(GetSigLLA(pes));
  43. results = new double[] { xyz[0], xyz[1], xyz[2], 0, 0, 0 };
  44. }
  45. return results;
  46. }
  47. public static double[] GetAdjaEphXYZ(this Pes pes)
  48. {
  49. return new double[] { pes.AdjaEphX, pes.AdjaEphY, pes.AdjaEphZ, pes.AdjaEphVx, pes.AdjaEphVy, pes.AdjaEphVz };
  50. }
  51. }
  52. }