XlCalculateForm.cs 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. using DevExpress.XtraEditors;
  2. using DevExpress.XtraTreeList.Data;
  3. using ExtensionsDev;
  4. using Newtonsoft.Json;
  5. using PosResAnalysis;
  6. using System;
  7. using System.Collections;
  8. using System.Collections.Generic;
  9. using System.ComponentModel;
  10. using System.Data;
  11. using System.Data.Entity;
  12. using System.Drawing;
  13. using System.IO;
  14. using System.Linq;
  15. using System.Net.Http;
  16. using System.Text;
  17. using System.Threading.Tasks;
  18. using System.Windows.Controls;
  19. using System.Windows.Documents;
  20. using System.Windows.Forms;
  21. using XdCxRhDW.App.Basic;
  22. using XdCxRhDW.App.EFContext;
  23. using XdCxRhDW.App.Model;
  24. using static XdCxRhDW.App.WebAPI.BaseController;
  25. namespace XdCxRhDW.App.CorTools
  26. {
  27. public partial class XlCalculateForm : DevExpress.XtraEditors.XtraForm
  28. {
  29. List<string> resXl = new List<string>();
  30. List<SatEphDto> list = new List<SatEphDto>();
  31. public XlCalculateForm()
  32. {
  33. InitializeComponent();
  34. }
  35. private async void XlCalculateForm_Load(object sender, EventArgs e)
  36. {
  37. gridControl.Init().UseSort().UseFilter().UseMultiSelect().UseRowNumber();
  38. gridControl.DataSource = list;
  39. LoadData();
  40. txtTle.UseDoubleClickToSelectAll();
  41. txtTle.UseDefault().SetStringData(resXl);
  42. }
  43. public async Task LoadData()
  44. {
  45. try
  46. {
  47. resXl.Clear();
  48. using (RHDWContext db = new RHDWContext())
  49. {
  50. var res = await db.XlInfos.OrderBy(p => p.SatName).OrderByDescending(p => p.TimeBJ).ToListAsync();
  51. resXl.AddRange(res.Select(s => $"{s.Line1};{s.Line2}"));
  52. }
  53. }
  54. catch (Exception ex)
  55. {
  56. Serilog.Log.Error(ex, "加载星历信息异常");
  57. DxHelper.MsgBoxHelper.ShowError("加载星历信息异常");
  58. }
  59. }
  60. private async void btnCalculate_Click(object sender, EventArgs e)
  61. {
  62. //HttpClient httpClient = new HttpClient();
  63. //HttpResponseMessage response = await httpClient.GetAsync(string.Format("http://192.168.254.249:8091/Api/Xl/Calc?tleStr={0}&dt={1}",txtTle.Text,txtStartTime.EditValue));
  64. //string responseBody = await response.Content.ReadAsStringAsync();
  65. if (!string.IsNullOrEmpty(txtEndTime.Text) && string.IsNullOrEmpty(txtSpanSeconds.Text))
  66. {
  67. DxHelper.MsgBoxHelper.ShowInfo("请填写推算间隔");
  68. return;
  69. }
  70. if (!string.IsNullOrEmpty(txtStartTime.Text) && !string.IsNullOrEmpty(txtEndTime.Text))
  71. {
  72. var startTime = Convert.ToDateTime(txtStartTime.EditValue);
  73. var endTime = Convert.ToDateTime(txtEndTime.EditValue);
  74. if (endTime < startTime)
  75. {
  76. DxHelper.MsgBoxHelper.ShowInfo("结束时间不能大于开始时间");
  77. return;
  78. }
  79. if ((endTime-startTime).TotalHours > 24)
  80. {
  81. DxHelper.MsgBoxHelper.ShowInfo("开始时间和结束时间不能相差超过24小时");
  82. return;
  83. }
  84. }
  85. list.Clear();
  86. var settings = new SysSetings();
  87. using (RHDWContext db = new RHDWContext())
  88. {
  89. settings = await db.SysSetings.FirstOrDefaultAsync();
  90. }
  91. using (var client = new HttpClient())
  92. {
  93. try
  94. {
  95. string url = string.Format("http://{0}:{1}/Api/", IpHelper.GetLocalIp(), settings.HttpPort);
  96. if (!string.IsNullOrEmpty(txtEndTime.Text) && !string.IsNullOrEmpty(txtSpanSeconds.Text))
  97. {
  98. url += string.Format("Xl/CalcMult?tleStr={0}&start={1}&end={2}&spanSeconds={3}", txtTle.Text, txtStartTime.EditValue, txtEndTime.EditValue, txtSpanSeconds.EditValue);
  99. var response = await client.GetAsync(url);
  100. if (response.IsSuccessStatusCode) // 处理成功响应
  101. {
  102. var content = await response.Content.ReadAsStringAsync();
  103. var ajaxResult = JsonConvert.DeserializeObject<AjaxResult<List<SatEphDto>>>(content);
  104. list.AddRange(ajaxResult.data);
  105. gridView.RefreshData();
  106. }
  107. }
  108. else
  109. {
  110. url += string.Format("Xl/Calc?tleStr={0}&dt={1}", txtTle.Text, txtStartTime.EditValue);
  111. var response = await client.GetAsync(url);
  112. if (response.IsSuccessStatusCode) // 处理成功响应
  113. {
  114. var content = await response.Content.ReadAsStringAsync();
  115. var ajaxResult = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content);
  116. list.Add(ajaxResult.data);
  117. gridView.RefreshData();
  118. }
  119. }
  120. }
  121. catch (Exception ex)
  122. {
  123. Serilog.Log.Error(ex, "请求星历推算Api出错");
  124. DxHelper.MsgBoxHelper.ShowError("星历推算错误");
  125. }
  126. }
  127. Console.ReadLine();
  128. }
  129. }
  130. }