GdopParamSetCtrl.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. using DevExpress.XtraEditors;
  2. using DevExpress.XtraLayout.Utils;
  3. using Ips.Library.Basic;
  4. using Ips.Library.DxpLib;
  5. using Ips.Library.Entity;
  6. using Ips.LocAlgorithm;
  7. using Ips.Sps.Com.Ephs;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.ComponentModel;
  11. using System.Data;
  12. using System.Drawing;
  13. using System.Linq;
  14. using System.Text;
  15. using System.Threading.Tasks;
  16. using System.Windows.Forms;
  17. namespace Ips.Sps.Com.Gdops
  18. {
  19. public partial class GdopParamSetCtrl : DevExpress.XtraEditors.XtraUserControl
  20. {
  21. public GdopParamSetCtrl()
  22. {
  23. InitializeComponent();
  24. SigTimeDateEdit.UseTimeEdit();
  25. }
  26. private GdopAnalyseViewModel _viewModel;
  27. public event EventHandler<QueryEphEventArgs> QueryEph;
  28. public IList<AntInfo> AntList { get; set; }
  29. public IList<RefSiteInfo> RefSiteList { get; set; }
  30. public IList<SatInfo> SatList { get; set; }
  31. public void SetViewModel(GdopAnalyseViewModel viewModel)
  32. {
  33. _viewModel = viewModel;
  34. bsGdopModel.DataSource = _viewModel;
  35. if (_viewModel.AntId > 0) antEdit.EditValue = AntList.Where(m => m.Id == _viewModel.AntId).FirstOrDefault();
  36. if (_viewModel.RefId > 0) refEdit.EditValue = RefSiteList.Where(m => m.Id == _viewModel.RefId).FirstOrDefault();
  37. if (_viewModel.MsId > 0) mainSatEdit.EditValue = _viewModel.MsId;
  38. if (_viewModel.As1Id > 0) adja1SatEdit.EditValue = _viewModel.As1Id;
  39. if (_viewModel.As2Id > 0) adja2SatEdit.EditValue = _viewModel.As2Id;
  40. SetFormDisplay(_viewModel.HasRef);
  41. }
  42. private void GdopParamSetCtrl_Load(object sender, EventArgs e)
  43. {
  44. BindList();
  45. }
  46. private void BindList()
  47. {
  48. if (AntList.IsNotNullOrEmpty())
  49. {
  50. bsAntList.DataSource = AntList;
  51. }
  52. else
  53. {
  54. itemForAnt.Visibility = LayoutVisibility.Never;
  55. }
  56. if (RefSiteList.IsNotNullOrEmpty())
  57. {
  58. bsRefSiteList.DataSource = RefSiteList;
  59. }
  60. else
  61. {
  62. itemForRefSite.Visibility = LayoutVisibility.Never;
  63. }
  64. if (SatList.IsNotNullOrEmpty())
  65. {
  66. bsSatList.DataSource = SatList;
  67. }
  68. else
  69. {
  70. itemForMainSat.Visibility = LayoutVisibility.Never;
  71. itemForAdja1Sat.Visibility = LayoutVisibility.Never;
  72. itemForAdja2Sat.Visibility = LayoutVisibility.Never;
  73. itemForCalcEph.Visibility = LayoutVisibility.Never;
  74. }
  75. }
  76. private void btnEphCalc_Click(object sender, EventArgs e)
  77. {
  78. if (mainSatEdit.EditValue == null)
  79. {
  80. MsgHelper.ShowError("请选择主星");
  81. return;
  82. }
  83. if (adja1SatEdit.EditValue == null)
  84. {
  85. MsgHelper.ShowError("请选择邻星1");
  86. return;
  87. }
  88. if (adja2SatEdit.EditValue == null)
  89. {
  90. MsgHelper.ShowError("请选择邻星2");
  91. return;
  92. }
  93. if (QueryEph == null) return;
  94. var ephTime = SigTimeDateEdit.DateTime;
  95. QuerySatEph(ephTime, mainSatEdit, MsXTextEdit, MsYTextEdit, MsZTextEdit);
  96. QuerySatEph(ephTime, adja1SatEdit, AsX1TextEdit, AsY1TextEdit, AsZ1TextEdit);
  97. QuerySatEph(ephTime, adja2SatEdit, AsX2TextEdit, AsY2TextEdit, AsZ2TextEdit);
  98. }
  99. private async void btnGdopCalc_Click(object sender, EventArgs e)
  100. {
  101. btnGdopCalc.Enabled = false;
  102. try
  103. {
  104. await _viewModel.CalcGdop();
  105. }
  106. catch (AggregateException aggEx)
  107. {
  108. aggEx.Flatten().Handle(ex =>
  109. {
  110. MsgHelper.ShowError(ex.Message);
  111. return true;
  112. });
  113. }
  114. finally
  115. {
  116. btnGdopCalc.Enabled = true;
  117. }
  118. }
  119. private void QuerySatEph(DateTime ephTime, BaseEdit satEdit, BaseEdit xEdit, BaseEdit yEdit, BaseEdit zEdit)
  120. {
  121. var satNum = (int)satEdit.EditValue;
  122. var arg = new QueryEphEventArgs(satNum, ephTime);
  123. QueryEph.Invoke(this, arg);
  124. if (arg.Result != null)
  125. {
  126. xEdit.EditValue = arg.Result.X;
  127. yEdit.EditValue = arg.Result.Y;
  128. zEdit.EditValue = arg.Result.Z;
  129. }
  130. }
  131. private void antEdit_EditValueChanged(object sender, EventArgs e)
  132. {
  133. var ant = antEdit.EditValue as AntInfo;
  134. if (ant == null) return;
  135. AntLonTextEdit.EditValue = ant.Lon;
  136. AntLatTextEdit.EditValue = ant.Lat;
  137. AntAltTextEdit.EditValue = ant.Alt;
  138. }
  139. private void refEdit_EditValueChanged(object sender, EventArgs e)
  140. {
  141. var refSite = refEdit.EditValue as RefSiteInfo;
  142. if (refSite == null) return;
  143. RefLonTextEdit.EditValue = refSite.Lon;
  144. RefLatTextEdit.EditValue = refSite.Lat;
  145. RefAltTextEdit.EditValue = refSite.Alt;
  146. }
  147. private void HasRefCheckEdit_CheckedChanged(object sender, EventArgs e)
  148. {
  149. SetFormDisplay(HasRefCheckEdit.Checked);
  150. }
  151. private void SetFormDisplay(bool hasRef)
  152. {
  153. if (HasRefCheckEdit.Checked)
  154. {
  155. grpAntInfo.Visibility = LayoutVisibility.Never;
  156. grpRefSiteInfo.Visibility = LayoutVisibility.Always;
  157. }
  158. else
  159. {
  160. grpAntInfo.Visibility = LayoutVisibility.Always;
  161. grpRefSiteInfo.Visibility = LayoutVisibility.Never;
  162. }
  163. }
  164. }
  165. }