XlCalculateForm.cs 5.4 KB

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