CtrlHome.cs 55 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229
  1. using DevExpress.Utils;
  2. using DevExpress.Utils.Drawing;
  3. using DevExpress.Utils.Svg;
  4. using DevExpress.XtraEditors.ButtonsPanelControl;
  5. using DevExpress.XtraGrid.Views.Grid;
  6. using DxHelper;
  7. using Microsoft.Owin.Hosting;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.ComponentModel.DataAnnotations;
  11. using System.Data;
  12. using System.Data.Entity;
  13. using System.Drawing;
  14. using System.Linq;
  15. using System.Net;
  16. using System.Reflection;
  17. using System.Text;
  18. using System.Windows.Forms;
  19. using XdCxRhDW.App.Api;
  20. using XdCxRhDW.App.EditForms;
  21. using XdCxRhDW.Repostory.Model;
  22. using XdCxRhDW.Repostory.EFContext;
  23. using XdCxRhDW.WebApi;
  24. using XdCxRhDW.Core.ObServer;
  25. using ExtensionsDev;
  26. using DevExpress.XtraEditors;
  27. using System.Data.Entity.Migrations;
  28. using System.Threading;
  29. using System.Threading.Tasks;
  30. using System.IO;
  31. using XdCxRhDW.App.PopupControl;
  32. namespace XdCxRhDW.App.UserControl
  33. {
  34. public partial class CtrlHome : DevExpress.XtraEditors.XtraUserControl
  35. {
  36. List<TaskInfo> list = new List<TaskInfo>();
  37. TaskInfo tsk = new TaskInfo();
  38. List<CancellationTokenSource> listCts = new List<CancellationTokenSource>();
  39. public CtrlHome()
  40. {
  41. InitializeComponent();
  42. gridHomeTask.Init<TaskInfo>().UseFilter();
  43. gridHomePosRes.Init<PosRes>().UseMultiSelect().UseRowNumber().UseFilter();
  44. layoutControl1.UseDefault();
  45. txtStartTime.UseDefault();
  46. txtEndTime.UseDefault();
  47. btnDrawDto.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\DtoLine.svg");
  48. btnDrawDfo.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\DfoLine.svg");
  49. btnGDOP.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\GDOP.svg");
  50. var mapService = string.Empty;//http://ows.mundialis.de/services/service
  51. using (RHDWContext db = new RHDWContext())
  52. {
  53. mapService = db.SysSetings.FirstOrDefault()?.MapService;
  54. }
  55. mapControl1.UseDefalutOptions()
  56. //.UseCluster()//定位点使用内置聚合
  57. .UseClearAll()
  58. .UseDistanceLine()
  59. .UseMarkDot()
  60. .UseExportImg()
  61. .UseExportXlsx()
  62. .UseExportCsv()
  63. .SetMapLayerType(mapService)
  64. //.SetMapLayerType("")
  65. //.UseHJ(item =>
  66. //{
  67. // (double Lon, double Lat) = item;
  68. // PosRes pos = new PosRes();
  69. // pos.PosLon = Lon;
  70. // pos.PosLat = Lat;
  71. // pos.SigTime = DateTime.Now;
  72. // mapControl1.AddHJPosItem(pos);
  73. //})
  74. .UseDrawRect(rect =>
  75. {
  76. (double startLon, double startLat, double centerLon, double centerLat, double endLon, double endLat, double lonRange, double latRange) = rect;
  77. });
  78. PosObServer.Instance.Sub(PosSubEvent);
  79. }
  80. private void PosSubEvent(PosRes posRes)
  81. {
  82. var currentTask = gridView1.GetFocusedRow() as TaskInfo;
  83. if (currentTask.ID == posRes.TaskInfoID)
  84. {
  85. var ds = this.gridHomePosRes.DataSource as List<PosRes>;
  86. ds.Insert(0, posRes);
  87. this.Invoke(new Action(() =>
  88. {
  89. gridView2.RefreshData();
  90. mapControl1.AddPosItem(posRes);
  91. }));
  92. }
  93. }
  94. private async void CtrlHome_Load(object sender, EventArgs e)
  95. {
  96. gridView1.FocusedRowObjectChanged += GridView1_FocusedRowObjectChanged;
  97. gridView2.FocusedRowObjectChanged += GridView2_FocusedRowObjectChanged;
  98. try
  99. {
  100. List<TxInfo> txList = new List<TxInfo>();
  101. using (RHDWContext db = new RHDWContext())
  102. {
  103. var qq = db.TaskInfos.OrderByDescending(p => p.CreateTime).ToList();
  104. list.AddRange(qq);
  105. var runningList = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running).ToListAsync();
  106. foreach (var item in runningList)
  107. {
  108. item.TaskState = EnumTaskState.Stopped;
  109. }
  110. await db.SaveChangesAsync();
  111. var satres = db.SatInfos.OrderBy(p => p.SatName).OrderBy(p => p.SatName);
  112. var txres = await db.TxInfos.ToListAsync();
  113. txList.AddRange(txres);
  114. }
  115. mapControl1.AddRectMenu<PosRes>("删除定位点", SvgHelper.CreateClose(), items =>
  116. {
  117. DeletePosRes(items.ToList());
  118. });
  119. mapControl1.AddRectMenu<PosRes>("使用镜像点", SvgHelper.LoadFromFile("Image\\Pos.svg"), items =>
  120. {
  121. UseMirr(items.ToList());
  122. });
  123. mapControl1.AddRectMenu<PosRes>("编辑目标", SvgHelper.LoadFromFile("Image\\Edit.svg"), items =>
  124. {
  125. EditTarget(items.ToList());
  126. });
  127. mapControl1.AddRectMenu<PosRes>("转到列表", SvgHelper.LoadFromFile("Image\\To.svg"), items =>
  128. {
  129. ToPosList(items.ToList());
  130. });
  131. mapControl1.AddPosMenu<PosRes>("绘制时差线", SvgHelper.LoadFromFile("Image\\DtoLine.svg"), item =>
  132. {
  133. DrawDtoLine(item);
  134. }, p =>
  135. {
  136. switch (p.PosResType)
  137. {
  138. case EnumPosResType.X3TwoDfo:
  139. case EnumPosResType.RH:
  140. default:
  141. return false;
  142. case EnumPosResType.X1D1CX:
  143. case EnumPosResType.X2D1:
  144. case EnumPosResType.X2D1NoRef:
  145. case EnumPosResType.X3:
  146. case EnumPosResType.X3NoRef:
  147. case EnumPosResType.X2Dfo:
  148. return true;
  149. }
  150. })
  151. .AddPosMenu<PosRes>("绘制频差线", SvgHelper.LoadFromFile("Image\\DfoLine.svg"), item =>
  152. {
  153. DrawDfoLine(item);
  154. }, p =>
  155. {
  156. switch (p.PosResType)
  157. {
  158. case EnumPosResType.X3TwoDfo:
  159. case EnumPosResType.X2Dfo:
  160. return true;
  161. case EnumPosResType.X2D1:
  162. case EnumPosResType.X2D1NoRef:
  163. case EnumPosResType.RH:
  164. case EnumPosResType.X3:
  165. case EnumPosResType.X3NoRef:
  166. case EnumPosResType.X1D1CX:
  167. default:
  168. return false;
  169. }
  170. })
  171. .AddPosMenu<PosRes>("绘制GDOP", SvgHelper.LoadFromFile("Image\\GDOP.svg"), item =>
  172. {
  173. DrawGDOP(item);
  174. }, p =>
  175. {
  176. switch (p.PosResType)
  177. {
  178. case EnumPosResType.X3TwoDfo:
  179. case EnumPosResType.X2Dfo:
  180. case EnumPosResType.X2D1:
  181. case EnumPosResType.X2D1NoRef:
  182. case EnumPosResType.X3:
  183. case EnumPosResType.X3NoRef:
  184. case EnumPosResType.X1D1CX:
  185. return true;
  186. case EnumPosResType.RH:
  187. default:
  188. return false;
  189. }
  190. })
  191. .AddPosMenu<PosRes>("绘制测向线", btnDrawCX.ImageOptions.SvgImage, item =>
  192. {
  193. DrawCXLine(item);
  194. }, p =>
  195. {
  196. switch (p.PosResType)
  197. {
  198. case EnumPosResType.X1D1CX:
  199. return true;
  200. case EnumPosResType.RH:
  201. case EnumPosResType.X3TwoDfo:
  202. case EnumPosResType.X2Dfo:
  203. case EnumPosResType.X2D1:
  204. case EnumPosResType.X2D1NoRef:
  205. case EnumPosResType.X3:
  206. case EnumPosResType.X3NoRef:
  207. default:
  208. return false;
  209. }
  210. });
  211. }
  212. catch (Exception ex)
  213. {
  214. Serilog.Log.Error(ex, "加载任务信息异常");
  215. DxHelper.MsgBoxHelper.ShowError("加载任务信息异常");
  216. }
  217. gridHomeTask.DataSource = list;
  218. gridView1.Columns[nameof(TaskInfo.TaskName)].AppearanceCell.TextOptions.HAlignment = HorzAlignment.Near;
  219. this.svgImageCollection1.Add("Stopped", SvgHelper.CreateCycle("#1E8B58"));
  220. this.svgImageCollection1.Add("Running", SvgHelper.CreateCycle("#2E8B57"));
  221. gridView1.CustomDrawCell += GridView1_CustomDrawCell;
  222. gridView1.CustomColumnDisplayText += GridView1_CustomColumnDisplayText;
  223. gridView1.RowClick += GridView1_RowClick;
  224. using (RHDWContext db = new RHDWContext())
  225. {
  226. var settings = await db.SysSetings.FirstOrDefaultAsync();
  227. if (settings == null)
  228. {
  229. DxHelper.MsgBoxHelper.ShowWarning($"请在系统设置中配置IP端口信息");
  230. return;
  231. }
  232. try
  233. {
  234. StartOptions options = new StartOptions();
  235. options.Urls.Add($"http://+:{settings.HttpPort}");
  236. httpServer = WebApp.Start<Startup>(options);
  237. }
  238. catch (System.Reflection.TargetInvocationException ex)
  239. {
  240. httpServer = null;
  241. Serilog.Log.Error(ex, $"启动Http服务失败!");
  242. if (ex.InnerException is HttpListenerException)
  243. {
  244. DxHelper.MsgBoxHelper.ShowWarning($"{ex.InnerException.Message}");
  245. }
  246. else
  247. {
  248. DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!");
  249. }
  250. }
  251. catch (Exception ex)
  252. {
  253. httpServer = null;
  254. Serilog.Log.Error(ex, $"启动Http服务失败!");
  255. DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!");
  256. }
  257. }
  258. WaitHelper.CloseForm();
  259. }
  260. private void ToPosList(List<PosRes> items)
  261. {
  262. if (items == null || items.Count() == 0)
  263. {
  264. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要转到列表的定位数据信息!");
  265. return;
  266. }
  267. try
  268. {
  269. var ds = this.gridHomePosRes.DataSource as List<PosRes>;
  270. var ids = items.Select(p => p.ID).ToList();
  271. //删除地图
  272. var deleteItems = ds.Where(m => !ids.Contains(m.ID)).ToList();
  273. mapControl1.DelPosItem(deleteItems);
  274. //删除列表
  275. ds.RemoveAll(m => !ids.Contains(m.ID));
  276. gridView2.RefreshData();
  277. }
  278. catch (Exception ex)
  279. {
  280. Serilog.Log.Error(ex, "转到列表异常!");
  281. MsgBoxHelper.ShowError("转到列表异常!");
  282. }
  283. }
  284. private async void EditTarget(List<PosRes> items)
  285. {
  286. if (items == null || items.Count() == 0)
  287. {
  288. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要编辑目标的定位数据信息!");
  289. return;
  290. }
  291. try
  292. {
  293. var firstItem = items.First();
  294. EditorTar frm = new EditorTar(new TargetInfo() { ID = firstItem.TargetID.HasValue ? firstItem.TargetID.Value : 0, TargetName = firstItem.TarName });
  295. if (frm.ShowDialog() != DialogResult.OK) return;
  296. var tar = frm.info;
  297. var groupItems = items.GroupBy(p => p.SigTime.ToString("yyyyMMdd"));
  298. foreach (var groupItem in groupItems)
  299. {
  300. var ids = groupItem.Select(m => m.ID).ToList();
  301. using (RHDWPartContext db = RHDWPartContext.GetContext(groupItem.First().SigTime))
  302. {
  303. var array = await db.PosRes.Where(p => ids.Contains(p.ID)).ToArrayAsync();
  304. EditTarget(array, tar);
  305. await db.SaveChangesAsync();
  306. }
  307. }
  308. EditTarget(items, tar);
  309. gridView2.RefreshData();
  310. }
  311. catch (Exception ex)
  312. {
  313. Serilog.Log.Error(ex, "编辑定位目标异常!");
  314. MsgBoxHelper.ShowError("编辑定位目标异常!");
  315. }
  316. }
  317. private void EditTarget(IEnumerable<PosRes> pos, TargetInfo tar)
  318. {
  319. foreach (var item in pos)
  320. {
  321. item.TargetID = tar.ID;
  322. item.TarName = tar.TargetName;
  323. }
  324. }
  325. private async void UseMirr(List<PosRes> items)
  326. {
  327. if (items == null || items.Count() == 0)
  328. {
  329. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要使用镜像点的定位数据信息!");
  330. return;
  331. }
  332. try
  333. {
  334. if (XtraMessageBox.Show("确认使用镜像点?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
  335. {
  336. return;
  337. }
  338. var groupItems = items.GroupBy(p => p.SigTime.ToString("yyyyMMdd"));
  339. foreach (var groupItem in groupItems)
  340. {
  341. var ids = groupItem.Select(m => m.ID).ToList();
  342. using (RHDWPartContext db = RHDWPartContext.GetContext(groupItem.First().SigTime))
  343. {
  344. var array = await db.PosRes.Where(p => ids.Contains(p.ID)).ToArrayAsync();
  345. UseMirror(array);
  346. await db.SaveChangesAsync();
  347. }
  348. }
  349. UseMirror(items);
  350. mapControl1.UpdatePosItem(items);
  351. gridView2.RefreshData();
  352. }
  353. catch (Exception ex)
  354. {
  355. Serilog.Log.Error(ex, "使用镜像点失败!");
  356. MsgBoxHelper.ShowError("使用镜像点失败!");
  357. }
  358. }
  359. private async void DeletePosRes(List<PosRes> items)
  360. {
  361. if (items == null || items.Count() == 0)
  362. {
  363. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要删除的定位数据信息!");
  364. return;
  365. }
  366. try
  367. {
  368. if (XtraMessageBox.Show("确认删除定位点?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
  369. {
  370. return;
  371. }
  372. var groupItems = items.GroupBy(p => p.SigTime.ToString("yyyyMMdd"));
  373. foreach (var groupItem in groupItems)
  374. {
  375. var ids = groupItem.Select(m => m.ID).ToList();
  376. using (RHDWPartContext db = RHDWPartContext.GetContext(groupItem.First().SigTime))
  377. {
  378. List<PosRes> list = await db.PosRes.Where(p => ids.Contains(p.ID)).ToListAsync();
  379. db.PosRes.RemoveRange(list);
  380. await db.SaveChangesAsync();
  381. }
  382. }
  383. mapControl1.DelPosItem(items);
  384. var ds = this.gridHomePosRes.DataSource as List<PosRes>;
  385. ds.RemoveAll(m => items.Select(p => p.ID).Contains(m.ID));
  386. gridView2.RefreshData();
  387. }
  388. catch (Exception ex)
  389. {
  390. Serilog.Log.Error(ex, "删除定位点失败");
  391. MsgBoxHelper.ShowError("删除定位点失败!");
  392. }
  393. }
  394. private void UseMirror(IEnumerable<PosRes> pos)
  395. {
  396. foreach (var item in pos)
  397. {
  398. var mirrlon = item.MirrLon;
  399. var mirrLat = item.MirrLat;
  400. if (mirrlon == 999)
  401. {
  402. continue;
  403. }
  404. item.MirrLon = item.PosLon;
  405. item.MirrLat = item.PosLat;
  406. item.PosLon = mirrlon;
  407. item.PosLat = mirrLat;
  408. }
  409. }
  410. private async void GridView1_FocusedRowObjectChanged(object sender, DevExpress.XtraGrid.Views.Base.FocusedRowObjectChangedEventArgs e)
  411. {
  412. listCts.ForEach(t => t.Cancel());
  413. listCts.Clear();
  414. var cts = new CancellationTokenSource();
  415. listCts.Add(cts);
  416. mapControl1.DelFixedImg("Sat");
  417. mapControl1.DelFixedImg("Tx");
  418. tsk = (e.Row as TaskInfo);
  419. if (tsk == null) return;
  420. var btnEdit = (layoutControlGroup1.CustomHeaderButtons[1] as GroupBoxButton);
  421. var btnDel = (layoutControlGroup1.CustomHeaderButtons[2] as GroupBoxButton);
  422. btnDel.Enabled = btnEdit.Enabled = tsk.TaskState != EnumTaskState.Running;
  423. List<PosRes> listPos = await searchPos(cts.Token);
  424. this.gridHomePosRes.DataSource = listPos;
  425. using (RHDWContext db = new RHDWContext())
  426. {
  427. var sat1 = db.SatInfos.Where(p => p.SatCode == tsk.MainSat).FirstOrDefault();
  428. var sat2 = db.SatInfos.Where(p => p.SatCode == tsk.Adja1Sat).FirstOrDefault();
  429. var sat3 = db.SatInfos.Where(p => p.SatCode == tsk.Adja2Sat).FirstOrDefault();
  430. if (sat1 != null && sat1.SatLon != null)
  431. mapControl1.DrawFixedImg("Sat", 0, sat1.SatLon.Value, DxHelper.SvgHelper.CreateSat(), $"主星\r\n{sat1.Sat}");
  432. if (sat2 != null && sat2.SatLon != null)
  433. mapControl1.DrawFixedImg("Sat", 0, sat2.SatLon.Value, DxHelper.SvgHelper.CreateSat(), $"邻1星\r\n{sat2.Sat}");
  434. if (sat3 != null && sat3.SatLon != null)
  435. mapControl1.DrawFixedImg("Sat", 0, sat3.SatLon.Value, DxHelper.SvgHelper.CreateSat(), $"邻2星\r\n{sat3.Sat}");
  436. }
  437. mapControl1.SetPosDataSource(listPos);
  438. }
  439. private void GridView2_FocusedRowObjectChanged(object sender, DevExpress.XtraGrid.Views.Base.FocusedRowObjectChangedEventArgs e)
  440. {
  441. mapControl1.DelFixedImg("Tx");
  442. var posItem = (e.Row as PosRes);
  443. if (posItem == null) return;
  444. using (RHDWPartContext db = RHDWPartContext.GetContext(posItem.SigTime))
  445. {
  446. var station = db.StationRes.Where(p => p.ID == posItem.StationResID).FirstOrDefault();
  447. if (station != null)
  448. {
  449. mapControl1.DrawFixedImg("Tx", station.SatTxLat, station.SatTxLon, DxHelper.SvgHelper.CreateAnt(), $"[卫星接收天线]\r\n经度:{station.SatTxLon}°\r\n纬度:{station.SatTxLat}°");
  450. if (station.CdbTxLon != null)
  451. mapControl1.DrawFixedImg("Tx", station.CdbTxLat.Value, station.CdbTxLon.Value, DxHelper.SvgHelper.CreateAnt(), $"[超短接收天线]\r\n经度:{station.CdbTxLon.Value}°\r\n纬度:{station.CdbTxLat.Value}°");
  452. if (station.RefLon != null)
  453. mapControl1.DrawFixedImg("Tx", station.RefLat.Value, station.RefLon.Value, DxHelper.SvgHelper.CreatePentagram(), $"[参考站]\r\n经度:{station.RefLon.Value}°\r\n纬度:{station.RefLat.Value}°");
  454. if (station.CxLon != null)
  455. mapControl1.DrawFixedImg("Tx", station.CxLat.Value, station.CxLon.Value, DxHelper.SvgHelper.CreatePentagram(), $"[测向站]\r\n经度:{station.CxLon.Value}°\r\n纬度:{station.CxLat.Value}°");
  456. }
  457. }
  458. }
  459. private void GridView1_RowClick(object sender, RowClickEventArgs e)
  460. {
  461. if (e.Clicks > 1)
  462. {
  463. layoutControlGroup1_CustomButtonClick(null, new DevExpress.XtraBars.Docking2010.BaseButtonEventArgs(new GroupBoxButton() { Caption = "编辑任务" }));
  464. }
  465. }
  466. private void GridView1_CustomColumnDisplayText(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnDisplayTextEventArgs e)
  467. {
  468. if (e.Column.FieldName == nameof(TaskInfo.Freq))
  469. {
  470. e.DisplayText = $"{(long)e.Value / 1e6}MHz";
  471. }
  472. else if (e.Column.FieldName == nameof(TaskInfo.Band))
  473. {
  474. e.DisplayText = $"{(int)e.Value / 1e6}MHz";
  475. }
  476. }
  477. private void GridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e)
  478. {
  479. if (e.Column.FieldName == nameof(TaskInfo.TaskName) && (EnumTaskState)gridView1.GetRowCellValue(e.RowHandle, nameof(TaskInfo.TaskState)) == EnumTaskState.Running)
  480. {
  481. var palette = SvgPaletteHelper.GetSvgPalette(this.LookAndFeel, ObjectState.Normal);
  482. e.Cache.DrawSvgImage(svgImageCollection1[1], new Rectangle(new Point(e.Bounds.X + 4, e.Bounds.Y + (e.Bounds.Height - 16) / 2), new Size(16, 16)), palette);
  483. Rectangle txtBounds = e.Bounds;
  484. txtBounds.Width -= 24;
  485. txtBounds.X += 24;
  486. e.Appearance.DrawString(e.Cache, e.DisplayText, txtBounds);
  487. e.Handled = true;
  488. }
  489. }
  490. private void toolTipController1_GetActiveObjectInfo(object sender, DevExpress.Utils.ToolTipControllerGetActiveObjectInfoEventArgs e)
  491. {
  492. var hitInfo = gridView1.CalcHitInfo(e.ControlMousePosition);
  493. if (hitInfo.RowHandle < 0 || hitInfo.Column == null || hitInfo.HitTest != DevExpress.XtraGrid.Views.Grid.ViewInfo.GridHitTest.RowCell)
  494. {
  495. toolTipController1.HideHint();
  496. return;
  497. }
  498. if (hitInfo.Column.FieldName == nameof(TaskInfo.TaskName))
  499. {
  500. var state = (EnumTaskState)gridView1.GetRowCellValue(hitInfo.RowHandle, nameof(TaskInfo.TaskState));
  501. if (state == EnumTaskState.Running)
  502. e.Info = new ToolTipControlInfo(hitInfo.RowHandle, "执行中");
  503. }
  504. }
  505. private void gridView1_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
  506. {
  507. if (gridView1.FocusedRowHandle < 0) return;
  508. var state = (EnumTaskState)gridView1.GetFocusedRowCellValue(nameof(TaskInfo.TaskState));
  509. btnStart.Enabled = state == EnumTaskState.Stopped;
  510. btnStop.Enabled = state == EnumTaskState.Running;
  511. popupMenu1.ShowPopup(MousePosition);
  512. }
  513. private void gridView2_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
  514. {
  515. if (gridView2.FocusedRowHandle < 0) return;
  516. var posRes = GetPosRes("");
  517. switch (posRes.PosResType)
  518. {
  519. case EnumPosResType.X1D1CX:
  520. //一星一地 测向线 GDOP
  521. btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  522. btnDrawDto.Visibility = btnGDOP.Visibility = btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  523. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  524. break;
  525. case EnumPosResType.X2D1:
  526. case EnumPosResType.X2D1NoRef:
  527. //两星一地 GDOP 时差线
  528. btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  529. btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  530. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  531. break;
  532. case EnumPosResType.RH:
  533. //融合DW=
  534. btnDrawDto.Visibility = btnDrawCX.Visibility = btnGDOP.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  535. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  536. break;
  537. case EnumPosResType.X3:
  538. case EnumPosResType.X3NoRef:
  539. //三星双时差DW GDOP 时差线
  540. btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  541. btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  542. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  543. break;
  544. case EnumPosResType.X3TwoDfo:
  545. //三星双频差DW GDOP 频差线
  546. btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  547. btnDrawDto.Visibility = btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  548. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  549. break;
  550. case EnumPosResType.X2Dfo:
  551. //双星时频差DW GDOP 时频差线
  552. btnDrawDto.Visibility = btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  553. btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  554. btnShowCxRes.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  555. break;
  556. default:
  557. break;
  558. }
  559. popupMenu2.ShowPopup(MousePosition);
  560. }
  561. private async void layoutControlGroup1_CustomButtonClick(object sender, DevExpress.XtraBars.Docking2010.BaseButtonEventArgs e)
  562. {
  563. var txt = (e.Button as GroupBoxButton).Caption;
  564. if (txt == "新建任务")
  565. {
  566. try
  567. {
  568. TaskEditor frm = new TaskEditor();
  569. if (frm.ShowDialog() != DialogResult.OK) return;
  570. var addItem = frm.info;
  571. using (RHDWContext db = new RHDWContext())
  572. {
  573. if (await db.TaskInfos.AnyAsync(p => p.TaskName == addItem.TaskName))
  574. {
  575. DxHelper.MsgBoxHelper.ShowWarning("任务名称重复");
  576. return;
  577. }
  578. if (addItem.PosType == EnumPosType.X1D1CX)
  579. {
  580. addItem.Adja1Sat = null;
  581. addItem.Adja2Sat = null;
  582. }
  583. else if (addItem.PosType == EnumPosType.X2D1 || addItem.PosType == EnumPosType.X2Dfo || addItem.PosType == EnumPosType.RH)
  584. {
  585. addItem.Adja2Sat = null;
  586. }
  587. db.TaskInfos.Add(addItem);
  588. await db.SaveChangesAsync();
  589. }
  590. list.Insert(0, addItem);
  591. gridView1.RefreshData();
  592. gridView1.FocusedRowHandle = 0;
  593. }
  594. catch (Exception ex)
  595. {
  596. Serilog.Log.Error(ex, "保存任务异常");
  597. DxHelper.MsgBoxHelper.ShowError("保存任务异常");
  598. }
  599. }
  600. else if (txt == "编辑任务")
  601. {
  602. try
  603. {
  604. var editItem = gridView1.GetFocusedRow() as TaskInfo;
  605. TaskEditor frm = new TaskEditor(editItem);
  606. if (frm.ShowDialog() != DialogResult.OK) return;
  607. editItem = frm.info;
  608. using (RHDWContext db = new RHDWContext())
  609. {
  610. if (await db.TaskInfos.AnyAsync(p => p.ID != editItem.ID && p.TaskName == editItem.TaskName))
  611. {
  612. DxHelper.MsgBoxHelper.ShowWarning("任务名称重复");
  613. return;
  614. }
  615. var find = await db.TaskInfos.Where(p => p.ID == editItem.ID).FirstOrDefaultAsync();
  616. find.TaskName = editItem.TaskName;
  617. find.PosType = editItem.PosType;
  618. find.UpdateTime = DateTime.Now;
  619. find.Freq = editItem.Freq;
  620. find.Band = editItem.Band;
  621. find.MainSat = editItem.MainSat;
  622. if (find.PosType == EnumPosType.X1D1CX)
  623. {
  624. find.Adja1Sat = null;
  625. find.Adja2Sat = null;
  626. }
  627. else if (find.PosType == EnumPosType.X2D1 || find.PosType == EnumPosType.X2Dfo || find.PosType == EnumPosType.RH)
  628. {
  629. find.Adja2Sat = null;
  630. }
  631. else
  632. {
  633. find.Adja1Sat = editItem.Adja1Sat;
  634. find.Adja2Sat = editItem.Adja2Sat;
  635. }
  636. await db.SaveChangesAsync();
  637. }
  638. gridView1.RefreshData();
  639. }
  640. catch (Exception ex)
  641. {
  642. Serilog.Log.Error(ex, "保存任务异常");
  643. DxHelper.MsgBoxHelper.ShowError("保存任务异常");
  644. }
  645. }
  646. else
  647. {
  648. try
  649. {
  650. var tsk = gridView1.GetFocusedRow() as TaskInfo;
  651. if (tsk == null) return;
  652. if (!DxHelper.MsgBoxHelper.ShowConfirm($"删除任务[{tsk.TaskName}]?"))
  653. return;
  654. using (RHDWContext db = new RHDWContext())
  655. {
  656. var item = db.TaskInfos.FirstOrDefault(p => p.ID == tsk.ID);
  657. db.TaskInfos.Remove(item);
  658. db.SaveChanges();
  659. }
  660. gridView1.DeleteSelectedRows();
  661. }
  662. catch (Exception ex)
  663. {
  664. Serilog.Log.Error(ex, "删除任务异常");
  665. DxHelper.MsgBoxHelper.ShowError("删除任务异常");
  666. }
  667. }
  668. }
  669. IDisposable httpServer;
  670. private async void btn_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  671. {
  672. var tsk = gridView1.GetFocusedRow() as TaskInfo;
  673. if (e.Item.Caption == "启动任务")
  674. {
  675. try
  676. {
  677. using (RHDWContext db = new RHDWContext())
  678. {
  679. var find = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskState == EnumTaskState.Running && p.PosType == tsk.PosType);
  680. if (find != null)
  681. {
  682. var field = typeof(EnumPosType).GetField(Enum.GetName(typeof(EnumPosType), find.PosType));
  683. DxHelper.MsgBoxHelper.ShowWarning($"已经有一个[{field.GetCustomAttribute<DisplayAttribute>().Name}]任务正在执行,请先停止!");
  684. return;
  685. }
  686. var settings = await db.SysSetings.FirstOrDefaultAsync();
  687. if (settings == null)
  688. {
  689. DxHelper.MsgBoxHelper.ShowWarning($"请在系统设置中配置IP端口信息");
  690. return;
  691. }
  692. if (httpServer == null)
  693. {
  694. try
  695. {
  696. StartOptions options = new StartOptions();
  697. options.Urls.Add($"http://+:{settings.HttpPort}");
  698. httpServer = WebApp.Start<Startup>(options);
  699. }
  700. catch (Exception ex)
  701. {
  702. Serilog.Log.Error(ex, "启动任务异常,Http定位接口服务启动失败");
  703. DxHelper.MsgBoxHelper.ShowError($"启动任务异常,Http定位接口服务启动失败");
  704. }
  705. }
  706. var item = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == tsk.ID);
  707. item.TaskState = EnumTaskState.Running;
  708. await db.SaveChangesAsync();
  709. tsk.TaskState = EnumTaskState.Running;
  710. Serilog.Log.Information($"用户启动了任务,ID={tsk.ID}");
  711. }
  712. }
  713. catch (Exception ex)
  714. {
  715. Serilog.Log.Error(ex, "启动任务异常");
  716. DxHelper.MsgBoxHelper.ShowError($"启动任务异常.{ex.Message}");
  717. }
  718. }
  719. else
  720. {
  721. try
  722. {
  723. using (RHDWContext db = new RHDWContext())
  724. {
  725. var item = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == tsk.ID);
  726. item.TaskState = EnumTaskState.Stopped;
  727. await db.SaveChangesAsync();
  728. //if (!db.TaskInfos.Any(p => p.TaskState == EnumTaskState.Running))
  729. //{
  730. // server?.StopListening();
  731. // server = null;
  732. //}
  733. }
  734. tsk.TaskState = EnumTaskState.Stopped;
  735. Serilog.Log.Information($"用户停止了任务,ID={tsk.ID}");
  736. }
  737. catch (Exception ex)
  738. {
  739. Serilog.Log.Error(ex, "停止任务异常");
  740. DxHelper.MsgBoxHelper.ShowError($"停止任务异常.{ex.Message}");
  741. }
  742. }
  743. gridView1.RefreshData();
  744. var btnEdit = (layoutControlGroup1.CustomHeaderButtons[1] as GroupBoxButton);
  745. var btnDel = (layoutControlGroup1.CustomHeaderButtons[2] as GroupBoxButton);
  746. btnDel.Enabled = btnEdit.Enabled = tsk.TaskState != EnumTaskState.Running;
  747. }
  748. private void gridView1_CustomDrawEmptyForeground(object sender, DevExpress.XtraGrid.Views.Base.CustomDrawEventArgs e)
  749. {
  750. if (gridView1.RowCount == 0)
  751. {
  752. string txt = "点击+创建任务";
  753. var s = e.Appearance.CalcTextSize(e.Cache, txt, e.Bounds.Width).ToSize();
  754. var x = (e.Bounds.Width - s.Width) / 2;
  755. var y = (e.Bounds.Height - s.Height) / 2;
  756. //e.Appearance.DrawString(e.Cache, txt, new Rectangle(x,y,s.Width,s.Height));
  757. e.DrawHtml(htmlTemplate1);
  758. }
  759. }
  760. private void gridView2_RowClick(object sender, RowClickEventArgs e)
  761. {
  762. var p = gridView2.GetFocusedRow() as PosRes;
  763. p.Selected = true;
  764. mapControl1.UpdatePosItem(p);
  765. }
  766. private void btnDrawDto_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  767. {
  768. var info = GetPosRes("绘制时差");
  769. if (info == null) return;
  770. DrawDtoLine(info);
  771. }
  772. private PosRes GetPosRes(string msg)
  773. {
  774. var ids = gridView2.GetSelectedRows();
  775. if (ids.Length <= 0)
  776. {
  777. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要{msg}的定位数据信息!");
  778. return null;
  779. }
  780. var item = gridView2.GetRow(ids[0]) as PosRes;
  781. return item;
  782. }
  783. private void btnDrawDfo_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  784. {
  785. var info = GetPosRes("绘制频差");
  786. if (info == null) return;
  787. DrawDfoLine(info);
  788. }
  789. private void btnDrawCX_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  790. {
  791. var ids = gridView2.GetSelectedRows();
  792. if (ids.Length <= 0)
  793. {
  794. DxHelper.MsgBoxHelper.ShowWarning($"请选择需要绘制测向线的定位数据信息!");
  795. return;
  796. }
  797. var item = gridView2.GetRow(ids[0]) as PosRes;
  798. if (item.PosResType == EnumPosResType.X1D1CX)
  799. {
  800. DrawCXLine(item);
  801. }
  802. }
  803. private void btnGDOP_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  804. {
  805. var info = GetPosRes("绘制GDOP");
  806. if (info == null) return;
  807. DrawGDOP(info);
  808. }
  809. private void btnShowCgRes_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  810. {
  811. var item = gridView2.GetFocusedRow() as PosRes;
  812. DxHelper.PopupHelper.ShowPopup(new ShowCgCtrl(item), gridHomePosRes, gridHomePosRes.Height, EnumPopupDirection.Bottom, showCloseButton: true);
  813. }
  814. private void btnShowCxRes_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  815. {
  816. var item = gridView2.GetFocusedRow() as PosRes;
  817. DxHelper.PopupHelper.ShowPopup(new ShowCxCtrl(item), gridHomePosRes, gridHomePosRes.Height, EnumPopupDirection.Bottom, showCloseButton: true);
  818. }
  819. private void DrawGDOP(PosRes item)
  820. {
  821. try
  822. {
  823. switch (item.PosResType)
  824. {
  825. case EnumPosResType.X1D1CX:
  826. X1D1GDOPParam x1D1GdopParam = new X1D1GDOPParam(item);
  827. x1D1GdopParam.mapControl1 = mapControl1;
  828. DxHelper.PopupHelper.ShowPopup(x1D1GdopParam, layoutControl1, 400);
  829. break;
  830. case EnumPosResType.X2D1:
  831. case EnumPosResType.X2D1NoRef:
  832. X2D1GDOPParam x2D1GdopParam = new X2D1GDOPParam(item);
  833. x2D1GdopParam.mapControl1 = mapControl1;
  834. DxHelper.PopupHelper.ShowPopup(x2D1GdopParam, layoutControl1, 400);
  835. break;
  836. case EnumPosResType.X3:
  837. case EnumPosResType.X3NoRef:
  838. X3GDOPParam x3GdopParam = new X3GDOPParam(item);
  839. x3GdopParam.mapControl1 = mapControl1;
  840. DxHelper.PopupHelper.ShowPopup(x3GdopParam, layoutControl1, 400);
  841. break;
  842. case EnumPosResType.X3TwoDfo:
  843. X3DFGDOPParam x3DFGdopParam = new X3DFGDOPParam(item);
  844. x3DFGdopParam.mapControl1 = mapControl1;
  845. DxHelper.PopupHelper.ShowPopup(x3DFGdopParam, layoutControl1, 400);
  846. break;
  847. case EnumPosResType.X2Dfo:
  848. X2DFGDOPParam x2DFGdopParam = new X2DFGDOPParam(item);
  849. x2DFGdopParam.mapControl1 = mapControl1;
  850. DxHelper.PopupHelper.ShowPopup(x2DFGdopParam, layoutControl1, 400);
  851. break;
  852. default:
  853. break;
  854. }
  855. }
  856. catch (Exception ex)
  857. {
  858. DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}GDOP失败,{ex.Message}");
  859. }
  860. }
  861. private void DrawDtoLine(PosRes item)
  862. {
  863. switch (item.PosResType)
  864. {
  865. case EnumPosResType.X1D1CX:
  866. X1D1DTOParamEditor frm = new X1D1DTOParamEditor(item, mapControl1);
  867. frm.ShowDialog();
  868. break;
  869. case EnumPosResType.X2D1:
  870. case EnumPosResType.X2D1NoRef:
  871. DrawXDtoLine(item);
  872. break;
  873. case EnumPosResType.X3:
  874. case EnumPosResType.X3NoRef:
  875. DrawX3toLine(item);
  876. break;
  877. case EnumPosResType.X2Dfo:
  878. X2DTOParamEditor frm2 = new X2DTOParamEditor(item, mapControl1);
  879. frm2.ShowDialog();
  880. break;
  881. default:
  882. break;
  883. }
  884. }
  885. private void DrawXDtoLine(PosRes item)
  886. {
  887. try
  888. {
  889. X2D1DTOParamEditor frm = new X2D1DTOParamEditor(item, mapControl1);
  890. frm.ShowDialog();
  891. }
  892. catch (Exception ex)
  893. {
  894. Serilog.Log.Error(ex, $"绘制{item.PosResType.GetEnumDisplayName()}时差线失败.PosID={item.ID},SigTime={item.SigTime}");
  895. DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败");
  896. }
  897. }
  898. private void DrawX3toLine(PosRes item)
  899. {
  900. try
  901. {
  902. X3DTOParamEditor frm = new X3DTOParamEditor(item, mapControl1);
  903. frm.ShowDialog();
  904. }
  905. catch (Exception ex)
  906. {
  907. Serilog.Log.Error(ex, $"绘制{item.PosResType.GetEnumDisplayName()}时差线失败.PosID={item.ID},SigTime={item.SigTime}");
  908. DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败");
  909. }
  910. }
  911. private void DrawDfoLine(PosRes item)
  912. {
  913. switch (item.PosResType)
  914. {
  915. case EnumPosResType.X3TwoDfo:
  916. case EnumPosResType.X2Dfo:
  917. DrawX3DfoLine(item);
  918. break;
  919. default:
  920. break;
  921. }
  922. }
  923. private async void DrawX3DfoLine(PosRes item)
  924. {
  925. try
  926. {
  927. StationRes station;
  928. CgRes cg;
  929. using (RHDWPartContext db = RHDWPartContext.GetContext(item.SigTime))
  930. {
  931. cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync();
  932. station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync();
  933. }
  934. if (cg == null)
  935. {
  936. Serilog.Log.Error($"绘制三星频差线错误,未找到定位关联的参估计信息.PosID={item.ID},SigTime={item.SigTime}");
  937. DxHelper.MsgBoxHelper.ShowError($"未找到定位关联的参估计信息");
  938. return;
  939. }
  940. if (station == null)
  941. {
  942. Serilog.Log.Error($"绘制三星频差线错误,未找到定位关联的站点信息.PosID={item.ID},SigTime={item.SigTime}");
  943. DxHelper.MsgBoxHelper.ShowError($"未找到定位关联的站点信息");
  944. return;
  945. }
  946. if (station.SatTxLon == 0 || station.SatTxLat == 0)
  947. {
  948. Serilog.Log.Error($"绘制三星频差线错误,天线信息为空.PosID={item.ID},SigTime={item.SigTime}");
  949. DxHelper.MsgBoxHelper.ShowError($"天线信息为空!");
  950. return;
  951. }
  952. if (station.RefLon == 0 || station.RefLat == 0)
  953. {
  954. Serilog.Log.Error($"绘制三星频差线错误,参考站信息为空.PosID={item.ID},SigTime={item.SigTime}");
  955. DxHelper.MsgBoxHelper.ShowError($"参考站信息为空!");
  956. return;
  957. }
  958. DfoLineTwoStartOption twoStartOption = new DfoLineTwoStartOption();
  959. twoStartOption.Freq = cg.TarFreqUp.HasValue ? cg.TarFreqUp.Value : 0;
  960. twoStartOption.RefFreq = cg.RefFreqUp.HasValue ? cg.RefFreqUp.Value : 0;
  961. twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, cg.MainVx.Value, cg.MainVy.Value, cg.MainVz.Value };
  962. twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, cg.Adja1Vx.Value, cg.Adja1Vy.Value, cg.Adja1Vz.Value };
  963. twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 };
  964. twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 };
  965. twoStartOption.RefGeod = new double[] { station.RefLon.Value, station.RefLat.Value, 0 };
  966. twoStartOption.TargetDfo = cg.Dfo1.Value;
  967. twoStartOption.Turn1 = Math.Abs(twoStartOption.Freq - (cg.TarFreqDown.HasValue ? cg.TarFreqDown.Value : 0));
  968. twoStartOption.Turn2 = Math.Abs(twoStartOption.RefFreq - (cg.RefFreqDown.HasValue ? cg.RefFreqDown.Value : 0));
  969. twoStartOption.RefDfo = cg.YbMainDfo.Value - cg.YbAdja1Dfo.Value;
  970. var tsDtoLine = DrawDfoLineHelper.DfoLineTwoStart(twoStartOption);
  971. List<SatInfo> listSat = null;
  972. using (RHDWContext db = new RHDWContext())
  973. {
  974. listSat = await db.SatInfos.ToListAsync();
  975. }
  976. var msat = listSat?.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; ;
  977. var ad1sat = listSat?.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat;
  978. if (msat == null) msat = cg.MainCode.ToString();
  979. if (ad1sat == null) ad1sat = cg.Adja1Code.ToString();
  980. mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad1sat}]频差线", tsDtoLine);
  981. if (item.PosResType == EnumPosResType.X3TwoDfo)
  982. {
  983. twoStartOption.NsEph = new double[] { cg.Adja2X.Value, cg.Adja2Y.Value, cg.Adja2Z.Value, cg.Adja2Vx.Value, cg.Adja2Vy.Value, cg.Adja2Vz.Value };
  984. twoStartOption.TargetDfo = cg.Dfo2.Value;
  985. twoStartOption.RefDfo = cg.YbMainDfo.Value - cg.YbAdja2Dfo.Value;
  986. var tsDtoLine1 = DrawDfoLineHelper.DfoLineTwoStart(twoStartOption);
  987. string ad2sat = string.Empty;
  988. if (cg.Adja2Code.HasValue)
  989. {
  990. ad2sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat;
  991. }
  992. mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad2sat}]频差线", tsDtoLine1);
  993. }
  994. }
  995. catch (Exception ex)
  996. {
  997. Serilog.Log.Error(ex, $"绘制{item.PosResType.GetEnumDisplayName()}频差线失败.PosID={item.ID},SigTime={item.SigTime}");
  998. DxHelper.MsgBoxHelper.ShowError($"绘制{item.PosResType.GetEnumDisplayName()}频差线失败");
  999. }
  1000. }
  1001. private async void DrawCXLine(PosRes item)
  1002. {
  1003. try
  1004. {
  1005. CxRes cx;
  1006. StationRes station;
  1007. using (RHDWPartContext db = RHDWPartContext.GetContext(item.SigTime))
  1008. {
  1009. cx = await db.CxRes.Where(m => m.ID == item.CxResID.Value).FirstOrDefaultAsync();
  1010. station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync();
  1011. }
  1012. if (cx == null)
  1013. {
  1014. Serilog.Log.Error($"绘制测向线错误,未找到定位关联的测向信息.PosID={item.ID},SigTime={item.SigTime}");
  1015. DxHelper.MsgBoxHelper.ShowError($"未找到定位关联的测向信息");
  1016. return;
  1017. }
  1018. if (station == null)
  1019. {
  1020. Serilog.Log.Error($"绘制测向线错误,未找到定位关联的站点信息.PosID={item.ID},SigTime={item.SigTime}");
  1021. DxHelper.MsgBoxHelper.ShowError($"未找到定位关联的站点信息!");
  1022. return;
  1023. }
  1024. if (station.CxLon == 0 || station.CxLat == 0)
  1025. {
  1026. Serilog.Log.Error($"绘制测向线错误,测向站信息为空.PosID={item.ID},SigTime={item.SigTime}");
  1027. DxHelper.MsgBoxHelper.ShowError($"测向站信息为空!");
  1028. return;
  1029. }
  1030. double deg = cx.Fx;//向北顺时针方向为夹角
  1031. //计算测向站到定位点之间的距离
  1032. var km = MapControlEx.CalcLineKm(station.CxLon.Value, station.CxLat.Value, item.PosLon, item.PosLat);
  1033. var endpoint = MapControlEx.CalcSituation(station.CxLon.Value, station.CxLat.Value, deg, (km + 100) * 1000);
  1034. List<(double, double)> points = new List<(double, double)>();
  1035. points.Add((station.CxLon.Value, station.CxLat.Value));
  1036. points.Add((endpoint.Item1, endpoint.Item2));
  1037. mapControl1.DrawCXLine($"测向线角度:{cx.Fx}°\t\n", points, true);
  1038. }
  1039. catch (Exception ex)
  1040. {
  1041. Serilog.Log.Error(ex, $"绘制测向线失败.PosID={item.ID},SigTime={item.SigTime}");
  1042. DxHelper.MsgBoxHelper.ShowWarning($"绘制测向线失败");
  1043. }
  1044. }
  1045. private async void txtTimeCho_SelectedIndexChanged(object sender, EventArgs e)
  1046. {
  1047. listCts.ForEach(t => t.Cancel());
  1048. listCts.Clear();
  1049. this.gridHomePosRes.DataSource = new List<PosRes>();//先设为空,数据相同时便于观察结果有没有变化
  1050. if (tsk == null)
  1051. {
  1052. return;
  1053. }
  1054. var cts = new CancellationTokenSource();
  1055. listCts.Add(cts);
  1056. switch (txtTimeCho.Text)
  1057. {
  1058. case "最近1小时":
  1059. case "最近6小时":
  1060. case "最近12小时":
  1061. case "最近1天":
  1062. case "最近3天":
  1063. layoutControlItemStartTime.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  1064. layoutControlItemEndTime.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  1065. layoutControlItemSearch.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
  1066. this.gridHomePosRes.DataSource = await searchPos(cts.Token);
  1067. break;
  1068. case "自定义":
  1069. layoutControlItemStartTime.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  1070. layoutControlItemEndTime.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  1071. layoutControlItemSearch.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
  1072. break;
  1073. }
  1074. }
  1075. private async void btnSearch_Click(object sender, EventArgs e)
  1076. {
  1077. if (txtStartTime.EditValue == null)
  1078. {
  1079. DxHelper.MsgBoxHelper.ShowError($"请选择信号开始时间!");
  1080. return;
  1081. }
  1082. if (txtEndTime.EditValue == null)
  1083. {
  1084. DxHelper.MsgBoxHelper.ShowError($"请选择信号结束时间!");
  1085. return;
  1086. }
  1087. if (txtStartTime.DateTime > txtEndTime.DateTime)
  1088. {
  1089. DxHelper.MsgBoxHelper.ShowError($"开始时间不能大于结束时间!");
  1090. return;
  1091. }
  1092. if ((txtEndTime.DateTime - txtStartTime.DateTime).TotalDays > 10)
  1093. {
  1094. MsgBoxHelper.ShowWarning("时间跨度不能超过10天!");
  1095. return;
  1096. }
  1097. listCts.ForEach(t => t.Cancel());
  1098. listCts.Clear();
  1099. var cts = new CancellationTokenSource();
  1100. listCts.Add(cts);
  1101. var listPos = await searchPos(cts.Token);
  1102. this.gridHomePosRes.DataSource = listPos;
  1103. }
  1104. private async Task<List<PosRes>> searchPos(CancellationToken ct = default)
  1105. {
  1106. try
  1107. {
  1108. DateTime start, end = DateTime.MinValue;
  1109. if (txtTimeCho.SelectedText == "自定义")
  1110. {
  1111. start = txtStartTime.DateTime;
  1112. end = txtEndTime.DateTime;
  1113. }
  1114. else
  1115. {
  1116. if (!Directory.Exists("DbPart")) return new List<PosRes>();
  1117. var yearDirs = Directory.EnumerateDirectories(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart")).OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name));//年目录,倒叙排列
  1118. foreach (var yearDir in yearDirs)
  1119. {
  1120. //每一天的db文件,倒序排列
  1121. var dayFiles = Directory.EnumerateFiles(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, yearDir), "*.db").OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name.Substring(0, 4)));
  1122. foreach (var dayFile in dayFiles)
  1123. {
  1124. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  1125. {
  1126. if (db.PosRes.Any(p => p.TaskInfoID == tsk.ID))
  1127. end = await db.PosRes.Where(p => p.TaskInfoID == tsk.ID).MaxAsync(p => p.SigTime);
  1128. }
  1129. if (end != DateTime.MinValue)
  1130. {
  1131. goto skip;
  1132. }
  1133. }
  1134. }
  1135. }
  1136. skip:
  1137. if (end == DateTime.MinValue)
  1138. {
  1139. return new List<PosRes>();//没有数据不查询
  1140. }
  1141. start = end.AddHours(-(int)txtTimeCho.EditValue);
  1142. DateTime endDay = new DateTime(end.Year, end.Month, end.Day);
  1143. DateTime startDay = new DateTime(start.Year, start.Month, start.Day);
  1144. List<PosRes> list = new List<PosRes>();
  1145. while (endDay >= startDay)
  1146. {
  1147. using (RHDWPartContext db = RHDWPartContext.GetContext(endDay))
  1148. {
  1149. var posRes = await db.PosRes
  1150. .Where(w => w.SigTime >= start && w.SigTime <= end && w.TaskInfoID == tsk.ID)
  1151. .OrderByDescending(o => o.SigTime).ToListAsync(ct);
  1152. list.AddRange(posRes);
  1153. }
  1154. endDay = endDay.AddDays(-1);
  1155. }
  1156. return list;
  1157. }
  1158. catch (TaskCanceledException) { }//屏蔽掉取消查询的异常
  1159. catch (Exception ex)
  1160. {
  1161. Serilog.Log.Error(ex, "定位结果查询异常");
  1162. MsgBoxHelper.ShowError("定位结果查询异常");
  1163. }
  1164. return new List<PosRes>();
  1165. }
  1166. }
  1167. }