CtrlHome.cs 54 KB

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