using DevExpress.Utils; using DevExpress.Utils.Drawing; using DevExpress.Utils.Svg; using DevExpress.XtraEditors.ButtonsPanelControl; using DevExpress.XtraGrid.Views.Grid; using DevExpress.XtraGrid.Views.Grid.ViewInfo; using DxHelper; using Microsoft.Owin.Hosting; using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Data; using System.Data.Entity; using System.Drawing; using System.Linq; using System.Net; using System.Reflection; using System.Text; using System.Windows.Forms; using XdCxRhDW.App.Api; using XdCxRhDW.App.EditForms; using XdCxRhDW.Repostory.Model; using System.Windows.Documents; using XdCxRhDW.Repostory.EFContext; using XdCxRhDW.Core.Api; using XdCxRhDW.WebApi; using XdCxRhDW.Core.ObServer; namespace XdCxRhDW.App.UserControl { public partial class CtrlHome : DevExpress.XtraEditors.XtraUserControl { List list = new List(); public CtrlHome() { InitializeComponent(); gridHomeTask.Init(); gridHomePosRes.Init().UseMultiSelect().UseRowNumber(); btnDrawDto.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\DtoLine.svg"); btnDrawDfo.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\DfoLine.svg"); btnGDOP.ImageOptions.SvgImage = SvgHelper.LoadFromFile("Image\\GDOP.svg"); var mapService = string.Empty;//http://ows.mundialis.de/services/service using (RHDWContext db = new RHDWContext()) { mapService = db.SysSetings.FirstOrDefault()?.MapService; } mapControl1.UseDefalutOptions() //.UseCluster()//定位点使用内置聚合 .UseClearAll() .UseDistanceLine() .UseMarkDot() .UseExportImg() .UseExportXlsx() .UseExportCsv() .SetMapLayerType(mapService) //.SetMapLayerType("") //.UseHJ(item => //{ // (double Lon, double Lat) = item; // PosRes pos = new PosRes(); // pos.PosLon = Lon; // pos.PosLat = Lat; // pos.SigTime = DateTime.Now; // mapControl1.AddHJPosItem(pos); //}) .UseDrawRect(rect => { (double startLon, double startLat, double centerLon, double centerLat, double endLon, double endLat, double lonRange, double latRange) = rect; }); PosObServer.Instance.Sub(PosSubEvent); } private void PosSubEvent(PosRes posRes) { var currentTask = gridView1.GetFocusedRow() as TaskInfo; if (currentTask.ID == posRes.TaskInfoID) { var ds = this.gridHomePosRes.DataSource as List; ds.Insert(0, posRes); this.Invoke(new Action(() => { gridView2.RefreshData(); mapControl1.AddPosItem(posRes); })); } } private async void GridView1_FocusedRowObjectChanged(object sender, DevExpress.XtraGrid.Views.Base.FocusedRowObjectChangedEventArgs e) { var tsk = (e.Row as TaskInfo); var btnEdit = (layoutControlGroup1.CustomHeaderButtons[1] as GroupBoxButton); var btnDel = (layoutControlGroup1.CustomHeaderButtons[2] as GroupBoxButton); btnDel.Enabled = btnEdit.Enabled = tsk.TaskState != EnumTaskState.Running; List listPos = new List(); using (RHDWContext db = new RHDWContext()) { var items = await db.PosRes.Where(p => p.TaskInfoID == tsk.ID).OrderByDescending(p => p.SigTime).ToListAsync(); listPos.AddRange(items); } this.gridHomePosRes.DataSource = listPos; mapControl1.SetPosDataSource(listPos.Where(p => p.PosLon <= 180), false); } private async void CtrlHome_Load(object sender, EventArgs e) { gridView1.FocusedRowObjectChanged += GridView1_FocusedRowObjectChanged; try { List satList = new List(); List txList = new List(); using (RHDWContext db = new RHDWContext()) { var qq = db.TaskInfos.OrderByDescending(p => p.CreateTime).ToList(); list.AddRange(qq); var runningList = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running).ToListAsync(); foreach (var item in runningList) { item.TaskState = EnumTaskState.Stopped; } await db.SaveChangesAsync(); var satres = db.SatInfos.OrderBy(p => p.SatName).OrderBy(p => p.SatName); satList.AddRange(await satres.ToListAsync()); var txres = await db.TxInfos.ToListAsync(); txList.AddRange(txres); } foreach (var sat in satList) { if (!sat.SatLon.HasValue) continue; mapControl1.Invoke(new Action(() => { mapControl1.DrawFixedImg("sat", 10, sat.SatLon.Value, DxHelper.SvgHelper.CreateSat(), new Size(24, 24), $"{sat.Sat}\r\n"); })); } foreach (var txitem in txList) { if ((txitem.Lon >= 180 || txitem.Lon <= 180) && txitem.Lat >= -90 || txitem.Lat <= 90)//画天线 { mapControl1.Invoke(new Action(() => { switch (txitem.TxType) { #warning 天线图片需要邹大哥给 case EnumTxType.MainSat: mapControl1.DrawFixedImg("MainSatTx", txitem.Lat, txitem.Lon, DxHelper.SvgHelper.CreatePentagram(), new Size(24, 24), $"[{txitem.Name}]\r\n主星天线经度:{txitem.Lon}°\r\n主星天线纬度:{txitem.Lat}°\r\n"); break; case EnumTxType.AdjaSat: mapControl1.DrawFixedImg("AdjaSatTx", txitem.Lat, txitem.Lon, DxHelper.SvgHelper.CreatePentagram(), new Size(24, 24), $"[{txitem.Name}]\r\n邻星天线经度:{txitem.Lon}°\r\n邻星天线纬度:{txitem.Lat}°\r\n"); break; case EnumTxType.Cdb: mapControl1.DrawFixedImg("CdbStation", txitem.Lat, txitem.Lon, DxHelper.SvgHelper.CreatePentagram(), new Size(24, 24), $"[{txitem.Name}]\r\n超短站经度:{txitem.Lon}°\r\n超短站纬度:{txitem.Lat}°\r\n"); break; case EnumTxType.Cx: mapControl1.DrawFixedImg("CxStation", txitem.Lat, txitem.Lon, DxHelper.SvgHelper.CreatePentagram(), new Size(24, 24), $"[{txitem.Name}]\r\n测向站经度:{txitem.Lon}°\r\n测向站纬度:{txitem.Lat}°\r\n"); break; case EnumTxType.Ref: mapControl1.DrawFixedImg("RefStation", txitem.Lat, txitem.Lon, DxHelper.SvgHelper.CreatePentagram(), new Size(24, 24), $"参考站经度:{txitem.Lon}°\r\n参考站纬度:{txitem.Lat}°\r\n"); break; default: break; } })); } } mapControl1.AddPosMenu("绘制时差线", SvgHelper.LoadFromFile("Image\\DtoLine.svg"), item => { DrawDtoLine(item); }, p => { switch (p.PosResType) { case EnumPosResType.X1D1CX: case EnumPosResType.X3TwoDfo: case EnumPosResType.RH: default: return false; case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: case EnumPosResType.X3: case EnumPosResType.X3NoRef: case EnumPosResType.X2Dfo: return true; } }) .AddPosMenu("绘制频差线", SvgHelper.LoadFromFile("Image\\DfoLine.svg"), item => { DrawDfoLine(item); }, p => { switch (p.PosResType) { case EnumPosResType.X3TwoDfo: case EnumPosResType.X2Dfo: return true; case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: case EnumPosResType.RH: case EnumPosResType.X3: case EnumPosResType.X3NoRef: case EnumPosResType.X1D1CX: default: return false; } }) .AddPosMenu("绘制GDOP", SvgHelper.LoadFromFile("Image\\GDOP.svg"), item => { DrawGDOP(item); }, p => { switch (p.PosResType) { case EnumPosResType.X3TwoDfo: case EnumPosResType.X2Dfo: case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: case EnumPosResType.X3: case EnumPosResType.X3NoRef: case EnumPosResType.X1D1CX: return true; case EnumPosResType.RH: default: return false; } }) .AddPosMenu("绘制测向线", btnDrawCX.ImageOptions.SvgImage, item => { DrawCXLine(item); }, p => { switch (p.PosResType) { case EnumPosResType.X1D1CX: return true; case EnumPosResType.RH: case EnumPosResType.X3TwoDfo: case EnumPosResType.X2Dfo: case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: case EnumPosResType.X3: case EnumPosResType.X3NoRef: default: return false; } }); } catch (Exception ex) { Serilog.Log.Error(ex, "加载任务信息异常"); DxHelper.MsgBoxHelper.ShowError("加载任务信息异常"); } gridHomeTask.DataSource = list; gridView1.Columns["TaskName"].AppearanceCell.TextOptions.HAlignment = HorzAlignment.Near; this.svgImageCollection1.Add("Stopped", SvgHelper.CreateCycle("#1E8B58")); this.svgImageCollection1.Add("Running", SvgHelper.CreateCycle("#2E8B57")); gridView1.CustomDrawCell += GridView1_CustomDrawCell; using (RHDWContext db = new RHDWContext()) { var settings = await db.SysSetings.FirstOrDefaultAsync(); if (settings == null) { DxHelper.MsgBoxHelper.ShowWarning($"请在系统设置中配置IP端口信息"); return; } try { StartOptions options = new StartOptions(); options.Urls.Add($"http://+:{settings.HttpPort}"); httpServer = WebApp.Start(options); } catch (System.Reflection.TargetInvocationException ex) { httpServer = null; Serilog.Log.Error(ex, $"启动Http服务失败!"); if (ex.InnerException is HttpListenerException) { DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败,请以管理员身份运行程序!"); } else { DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!"); } } catch (Exception ex) { httpServer = null; Serilog.Log.Error(ex, $"启动Http服务失败!"); DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!"); } } WaitHelper.CloseForm(); } private void GridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e) { if (e.Column.FieldName == "TaskName" && (EnumTaskState)gridView1.GetRowCellValue(e.RowHandle, "TaskState") == EnumTaskState.Running) { var palette = SvgPaletteHelper.GetSvgPalette(this.LookAndFeel, ObjectState.Normal); 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); Rectangle txtBounds = e.Bounds; txtBounds.Width -= 24; txtBounds.X += 24; e.Appearance.DrawString(e.Cache, e.DisplayText, txtBounds); e.Handled = true; } } //public void SetEnumColumnImage(GridView gv, string columnFieldName, object imageCollection) //{ // var repositoryItemImageComboBoxStatus = new RepositoryItemImageEdit(); // var col = gv.Columns[columnFieldName]; // col.MaxWidth = 40; // repositoryItemImageComboBoxStatus.Images = imageCollection; // col.ColumnEdit = repositoryItemImageComboBoxStatus; //} private void toolTipController1_GetActiveObjectInfo(object sender, DevExpress.Utils.ToolTipControllerGetActiveObjectInfoEventArgs e) { GridHitInfo hitInfo = gridView1.CalcHitInfo(e.ControlMousePosition); if (hitInfo.RowHandle < 0 || hitInfo.Column == null || hitInfo.HitTest != GridHitTest.RowCell) { toolTipController1.HideHint(); return; } if (hitInfo.Column.FieldName == "TaskName") { var state = (EnumTaskState)gridView1.GetRowCellValue(hitInfo.RowHandle, "TaskState"); if (state == EnumTaskState.Running) e.Info = new ToolTipControlInfo(hitInfo.RowHandle, "执行中"); } } private void gridView1_PopupMenuShowing(object sender, PopupMenuShowingEventArgs e) { if (gridView1.FocusedRowHandle < 0) return; var state = (EnumTaskState)gridView1.GetFocusedRowCellValue("TaskState"); btnStart.Enabled = state == EnumTaskState.Stopped; btnStop.Enabled = state == EnumTaskState.Running; popupMenu1.ShowPopup(MousePosition); } private void gridView2_PopupMenuShowing(object sender, PopupMenuShowingEventArgs e) { if (gridView2.FocusedRowHandle < 0) return; if (!gridView2.GetSelectedRows().Any()) { btnDelPos.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; } else { btnDelPos.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; } var posRes = GetPosRes(""); switch (posRes.PosResType) { case EnumPosResType.X1D1CX: //一星一地 测向线 GDOP btnDrawDto.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; btnGDOP.Visibility = btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; break; case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: //两星一地 GDOP 时差线 btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; break; case EnumPosResType.RH: //融合DW= btnDrawDto.Visibility = btnDrawCX.Visibility = btnGDOP.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; break; case EnumPosResType.X3: case EnumPosResType.X3NoRef: //三星双时差DW GDOP 时差线 btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; break; case EnumPosResType.X3TwoDfo: //三星双频差DW GDOP 频差线 btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; btnDrawDto.Visibility = btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; break; case EnumPosResType.X2Dfo: //双星时频差DW GDOP 时频差线 btnDrawDto.Visibility = btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always; btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Never; break; default: break; } popupMenu2.ShowPopup(MousePosition); } private async void layoutControlGroup1_CustomButtonClick(object sender, DevExpress.XtraBars.Docking2010.BaseButtonEventArgs e) { var txt = (e.Button as GroupBoxButton).Caption; if (txt == "新建任务") { try { TaskEditor frm = new TaskEditor(); if (frm.ShowDialog() != DialogResult.OK) return; var addItem = frm.info; using (RHDWContext db = new RHDWContext()) { if (await db.TaskInfos.AnyAsync(p => p.TaskName == addItem.TaskName)) { DxHelper.MsgBoxHelper.ShowWarning("任务名称重复"); return; } db.TaskInfos.Add(addItem); await db.SaveChangesAsync(); } list.Insert(0, addItem); gridView1.RefreshData(); gridView1.FocusedRowHandle = 0; } catch (Exception ex) { Serilog.Log.Error(ex, "保存任务异常"); DxHelper.MsgBoxHelper.ShowError("保存任务异常"); } } else if (txt == "编辑任务") { try { var editItem = gridView1.GetFocusedRow() as TaskInfo; TaskEditor frm = new TaskEditor(editItem); if (frm.ShowDialog() != DialogResult.OK) return; editItem = frm.info; using (RHDWContext db = new RHDWContext()) { if (await db.TaskInfos.AnyAsync(p => p.ID != editItem.ID && p.TaskName == editItem.TaskName)) { DxHelper.MsgBoxHelper.ShowWarning("任务名称重复"); return; } var find = await db.TaskInfos.Where(p => p.ID == editItem.ID).FirstOrDefaultAsync(); find.TaskName = editItem.TaskName; find.PosType = editItem.PosType; await db.SaveChangesAsync(); } gridView1.RefreshData(); } catch (Exception ex) { Serilog.Log.Error(ex, "保存任务异常"); DxHelper.MsgBoxHelper.ShowError("保存任务异常"); } } else { try { var tsk = gridView1.GetFocusedRow() as TaskInfo; if (tsk == null) return; if (!DxHelper.MsgBoxHelper.ShowConfirm($"删除任务[{tsk.TaskName}]?")) return; using (RHDWContext db = new RHDWContext()) { var item = db.TaskInfos.FirstOrDefault(p => p.ID == tsk.ID); db.TaskInfos.Remove(item); db.SaveChanges(); } gridView1.DeleteSelectedRows(); } catch (Exception ex) { Serilog.Log.Error(ex, "删除任务异常"); DxHelper.MsgBoxHelper.ShowError("删除任务异常"); } } } IDisposable httpServer; private async void btn_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var tsk = gridView1.GetFocusedRow() as TaskInfo; if (e.Item.Caption == "启动任务") { try { using (RHDWContext db = new RHDWContext()) { var find = await db.TaskInfos.FirstOrDefaultAsync(p => p.TaskState == EnumTaskState.Running && p.PosType == tsk.PosType); if (find != null) { var field = typeof(EnumPosType).GetField(Enum.GetName(typeof(EnumPosType), find.PosType)); DxHelper.MsgBoxHelper.ShowWarning($"已经有一个[{field.GetCustomAttribute().Name}]任务正在执行,请先停止!"); return; } var settings = await db.SysSetings.FirstOrDefaultAsync(); if (settings == null) { DxHelper.MsgBoxHelper.ShowWarning($"请在系统设置中配置IP端口信息"); return; } if (httpServer == null) { try { StartOptions options = new StartOptions(); options.Urls.Add($"http://+:{settings.HttpPort}"); httpServer = WebApp.Start(options); } catch (Exception ex) { Serilog.Log.Error(ex, "启动任务异常,Http定位接口服务启动失败"); DxHelper.MsgBoxHelper.ShowError($"启动任务异常,Http定位接口服务启动失败"); } } var item = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == tsk.ID); item.TaskState = EnumTaskState.Running; await db.SaveChangesAsync(); tsk.TaskState = EnumTaskState.Running; Serilog.Log.Information($"用户启动了任务,ID={tsk.ID}"); } } catch (Exception ex) { Serilog.Log.Error(ex, "启动任务异常"); DxHelper.MsgBoxHelper.ShowError($"启动任务异常.{ex.Message}"); } } else { try { using (RHDWContext db = new RHDWContext()) { var item = await db.TaskInfos.FirstOrDefaultAsync(p => p.ID == tsk.ID); item.TaskState = EnumTaskState.Stopped; await db.SaveChangesAsync(); //if (!db.TaskInfos.Any(p => p.TaskState == EnumTaskState.Running)) //{ // server?.StopListening(); // server = null; //} } tsk.TaskState = EnumTaskState.Stopped; Serilog.Log.Information($"用户停止了任务,ID={tsk.ID}"); } catch (Exception ex) { Serilog.Log.Error(ex, "停止任务异常"); DxHelper.MsgBoxHelper.ShowError($"停止任务异常.{ex.Message}"); } } gridView1.RefreshData(); var btnEdit = (layoutControlGroup1.CustomHeaderButtons[1] as GroupBoxButton); var btnDel = (layoutControlGroup1.CustomHeaderButtons[2] as GroupBoxButton); btnDel.Enabled = btnEdit.Enabled = tsk.TaskState != EnumTaskState.Running; } private void gridView1_CustomDrawEmptyForeground(object sender, DevExpress.XtraGrid.Views.Base.CustomDrawEventArgs e) { if (gridView1.RowCount == 0) { string txt = "点击+创建任务"; var s = e.Appearance.CalcTextSize(e.Cache, txt, e.Bounds.Width).ToSize(); var x = (e.Bounds.Width - s.Width) / 2; var y = (e.Bounds.Height - s.Height) / 2; //e.Appearance.DrawString(e.Cache, txt, new Rectangle(x,y,s.Width,s.Height)); e.DrawHtml(htmlTemplate1); } } private async void btnDelPos_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { try { var ids = gridView2.GetSelectedRows(); using (RHDWContext db = new RHDWContext()) { foreach (var id in ids) { var item = gridView2.GetRow(id) as PosRes; var delItem = await db.PosRes.Where(p => p.ID == item.ID).FirstOrDefaultAsync(); if (delItem != null) { db.PosRes.Remove(delItem); mapControl1.DelPosItem(item); } } await db.SaveChangesAsync(); } gridView2.DeleteSelectedRows(); } catch (Exception ex) { Serilog.Log.Error(ex, "删除定位结果异常"); DxHelper.MsgBoxHelper.ShowError("删除定位结果异常"); } } private void gridView2_RowClick(object sender, RowClickEventArgs e) { var p = gridView2.GetFocusedRow() as PosRes; p.Selected = true; mapControl1.UpdatePosItem(p); } private async void btnTar_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { try { var ids = gridView2.GetSelectedRows(); if (ids.Length <= 0) return; var fisrtitem = gridView2.GetRow(ids[0]) as PosRes; EditorTar frm = new EditorTar(new TargetInfo() { ID = fisrtitem.TargetID.HasValue ? fisrtitem.TargetID.Value : 0, TargetName = fisrtitem.TarName }); if (frm.ShowDialog() != DialogResult.OK) return; var tar = frm.info; using (RHDWContext db = new RHDWContext()) { foreach (var id in ids) { var item = gridView2.GetRow(id) as PosRes; var tarItem = await db.PosRes.Where(p => p.ID == item.ID).FirstOrDefaultAsync(); if (tarItem != null) { item.TargetID = tarItem.TargetID = tar.ID; item.TarName = tarItem.TarName = tar.TargetName; } } await db.SaveChangesAsync(); } } catch (Exception ex) { Serilog.Log.Error(ex, "编辑定位目标异常"); DxHelper.MsgBoxHelper.ShowError("编辑定位目标异常"); } } private void btnDrawDto_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var info = GetPosRes("绘制时差"); if (info == null) return; DrawDtoLine(info); } private PosRes GetPosRes(string msg) { var ids = gridView2.GetSelectedRows(); if (ids.Length <= 0) { DxHelper.MsgBoxHelper.ShowWarning($"请选择需要{msg}的定位数据信息!"); return null; } var item = gridView2.GetRow(ids[0]) as PosRes; return item; } private void btnDrawDfo_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var info = GetPosRes("绘制频差"); if (info == null) return; DrawDfoLine(info); } private void btnDrawCX_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var ids = gridView2.GetSelectedRows(); if (ids.Length <= 0) { DxHelper.MsgBoxHelper.ShowWarning($"请选择需要绘制测向线的定位数据信息!"); return; } var item = gridView2.GetRow(ids[0]) as PosRes; if (item.PosResType == EnumPosResType.X1D1CX) { DrawCXLine(item); } } private void btnGDOP_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e) { var info = GetPosRes("绘制GDOP"); if (info == null) return; DrawGDOP(info); } private void DrawGDOP(PosRes item) { try { switch (item.PosResType) { case EnumPosResType.X1D1CX: X1D1GDOPParam x1D1GdopParam = new X1D1GDOPParam(item); x1D1GdopParam.mapControl1 = mapControl1; DxHelper.PopupHelper.ShowPopup(x1D1GdopParam, mapControl1, mapControl1.Width / 4); break; case EnumPosResType.X2D1: case EnumPosResType.X2D1NoRef: X2D1GDOPParam x2D1GdopParam = new X2D1GDOPParam(item); x2D1GdopParam.mapControl1 = mapControl1; DxHelper.PopupHelper.ShowPopup(x2D1GdopParam, mapControl1, mapControl1.Width / 4); break; case EnumPosResType.X3: case EnumPosResType.X3NoRef: X3GDOPParam x3GdopParam = new X3GDOPParam(item); x3GdopParam.mapControl1 = mapControl1; DxHelper.PopupHelper.ShowPopup(x3GdopParam, mapControl1, mapControl1.Width / 4); break; case EnumPosResType.X3TwoDfo: X3DFGDOPParam x3DFGdopParam = new X3DFGDOPParam(item); x3DFGdopParam.mapControl1 = mapControl1; DxHelper.PopupHelper.ShowPopup(x3DFGdopParam, mapControl1, mapControl1.Width / 4); break; case EnumPosResType.X2Dfo: X2DFGDOPParam x2DFGdopParam = new X2DFGDOPParam(item); x2DFGdopParam.mapControl1 = mapControl1; DxHelper.PopupHelper.ShowPopup(x2DFGdopParam, mapControl1, mapControl1.Width / 4); break; default: break; } } catch (Exception ex) { DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}GDOP失败,{ex.Message}"); } } private void DrawDtoLine(PosRes item) { switch (item.PosResType) { case EnumPosResType.X1D1CX: case EnumPosResType.X2D1: DrawXDtoLine(item); break; case EnumPosResType.X2D1NoRef: DrawXDNoRefDtoLine(item); break; case EnumPosResType.X3: case EnumPosResType.X2Dfo: DrawX3toLine(item); break; case EnumPosResType.X3NoRef: DrawX3NoReftoLine(item); break; default: break; } } private async void DrawXDtoLine(PosRes item) { try { StationRes station; List listSat = new List(); CgRes cg; using (RHDWContext db = new RHDWContext()) { listSat = db.SatInfos.ToList(); cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cg == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的计算[{item.CgResID}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.SatTxLon == 0 || station.SatTxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"天线信息为空!"); return; } if (station.CdbTxLon == 0 || station.CdbTxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"超短波信息为空!"); return; } if (station.RefLon == 0 || station.RefLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"参考站信息为空!"); return; } DtoLineXdOption dtoLineXd = new DtoLineXdOption(); dtoLineXd.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; dtoLineXd.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; dtoLineXd.CDBAnt = new double[] { station.CdbTxLon.Value, station.CdbTxLat.Value, 0 }; dtoLineXd.RefGeod = new double[] { station.RefLon.Value, station.RefLat.Value, 0 }; dtoLineXd.xdDto = cg.DtoCdb.Value; dtoLineXd.RefDto = cg.YbMainDto.Value; dtoLineXd.PosLon = item.PosLon; dtoLineXd.PosLat = item.PosLat; string msat = string.Empty; if (cg.MainCode.HasValue) { msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; } var xdDtoLine = DrawDtoLineHelper.DtoLineXd(dtoLineXd); mapControl1.DrawDtoPonit($"星地[{msat},[{station.CdbTxLon}°]]时差线", xdDtoLine); if (item.PosResType == EnumPosResType.X2D1) { DtoLineTwoStartOption twoStartOption = new DtoLineTwoStartOption(); twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, 0, 0, 0 }; twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.RefGeod = new double[] { station.RefLon.Value, station.RefLat.Value, 0 }; twoStartOption.TargetDto = cg.Dto1.Value; twoStartOption.RefDto = cg.YbMainDto.Value - cg.YbAdja1Dto.Value; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; var tsDtoLine = DrawDtoLineHelper.DtoLine2XStart(twoStartOption); string nsat = string.Empty; if (cg.Adja1Code.HasValue) { nsat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat; } mapControl1.DrawDtoPonit($"双星[{msat},{nsat}]时差线", tsDtoLine); } } catch (Exception ex) { Serilog.Log.Error($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}"); } } private async void DrawXDNoRefDtoLine(PosRes item) { try { StationRes station; List listSat = new List(); CgRes cg; using (RHDWContext db = new RHDWContext()) { listSat = db.SatInfos.ToList(); cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cg == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的计算[{item.CgResID}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.SatTxLon == 0 || station.SatTxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"天线信息为空!"); return; } if (station.CdbTxLon == 0 || station.CdbTxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"超短波信息为空!"); return; } DtoLineXdOption dtoLineXd = new DtoLineXdOption(); dtoLineXd.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; dtoLineXd.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; dtoLineXd.CDBAnt = new double[] { station.CdbTxLon.Value, station.CdbTxLat.Value, 0 }; dtoLineXd.xdDto = cg.DtoCdb.Value; dtoLineXd.PosLon = item.PosLon; dtoLineXd.PosLat = item.PosLat; string msat = string.Empty; if (cg.MainCode.HasValue) { msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; } var xdDtoLine = DrawDtoLineHelper.DtoLineXdNoRef(dtoLineXd); mapControl1.DrawDtoPonit($"星地[{msat},[{station.CdbTxLon}°]]时差线", xdDtoLine); DtoLineTwoStartOption twoStartOption = new DtoLineTwoStartOption(); twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, 0, 0, 0 }; twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.TargetDto = cg.Dto1.Value; twoStartOption.RefDto = 0; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; string ad1sat = string.Empty; if (cg.Adja1Code.HasValue) { ad1sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat; } var tsDtoLine = DrawDtoLineHelper.DtoLine2XNoRefStart(twoStartOption); mapControl1.DrawDtoPonit($"双星[{msat},{ad1sat}]时差线", tsDtoLine); } catch (Exception ex) { Serilog.Log.Error($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}"); } } private async void DrawX3toLine(PosRes item) { try { StationRes station; List listSat = new List(); CgRes cg; using (RHDWContext db = new RHDWContext()) { listSat = db.SatInfos.ToList(); cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cg == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的计算[{item.CgResID}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.RefLon == 0 || station.RefLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"参考站信息为空!"); return; } DtoLineTwoStartOption twoStartOption = new DtoLineTwoStartOption(); twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, 0, 0, 0 }; twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.RefGeod = new double[] { station.RefLon.Value, station.RefLat.Value, 0 }; twoStartOption.TargetDto = cg.Dto1.Value; twoStartOption.RefDto = cg.YbMainDto.Value - cg.YbAdja1Dto.Value; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; string msat = string.Empty; string ad1sat = string.Empty; if (cg.MainCode.HasValue) { msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; } if (cg.Adja1Code.HasValue) { ad1sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat; } var tsDtoLine = DrawDtoLineHelper.DtoLine2XStart(twoStartOption); mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad1sat}]时差线", tsDtoLine); if (item.PosResType == EnumPosResType.X3) { twoStartOption.NsEph = new double[] { cg.Adja2X.Value, cg.Adja2Y.Value, cg.Adja2Z.Value, 0, 0, 0 }; twoStartOption.TargetDto = cg.Dto2.Value; twoStartOption.RefDto = cg.YbMainDto.Value - cg.YbAdja2Dto.Value; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; var tsDtoLine1 = DrawDtoLineHelper.DtoLine2XStart(twoStartOption); string ad2sat = string.Empty; if (cg.Adja2Code.HasValue) { ad2sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat; } mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad2sat}]时差线", tsDtoLine1); } } catch (Exception ex) { Serilog.Log.Error($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}"); } } private async void DrawX3NoReftoLine(PosRes item) { try { StationRes station; List listSat = new List(); CgRes cg; using (RHDWContext db = new RHDWContext()) { listSat = db.SatInfos.ToList(); cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cg == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的计算[{item.CgResID}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.RefLon == 0 || station.RefLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"参考站信息为空!"); return; } DtoLineTwoStartOption twoStartOption = new DtoLineTwoStartOption(); twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, 0, 0, 0 }; twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, 0, 0, 0 }; twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.RefGeod = new double[] { 0, 0, 0 }; twoStartOption.TargetDto = cg.Dto1.Value; twoStartOption.RefDto = 0; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; string msat = string.Empty; string ad1sat = string.Empty; if (cg.MainCode.HasValue) { msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; } if (cg.Adja1Code.HasValue) { ad1sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat; } var tsDtoLine = DrawDtoLineHelper.DtoLine2XNoRefStart(twoStartOption); mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad1sat}]时差线", tsDtoLine); twoStartOption.NsEph = new double[] { cg.Adja2X.Value, cg.Adja2Y.Value, cg.Adja2Z.Value, 0, 0, 0 }; twoStartOption.TargetDto = cg.Dto2.Value; twoStartOption.RefDto = 0; twoStartOption.PosLon = item.PosLon; twoStartOption.PosLat = item.PosLat; var tsDtoLine1 = DrawDtoLineHelper.DtoLine2XNoRefStart(twoStartOption); string ad2sat = string.Empty; if (cg.Adja2Code.HasValue) { ad2sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat; } mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad2sat}]时差线", tsDtoLine1); } catch (Exception ex) { Serilog.Log.Error($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}"); } } private void DrawDfoLine(PosRes item) { switch (item.PosResType) { case EnumPosResType.X3TwoDfo: case EnumPosResType.X2Dfo: DrawX3DfoLine(item); break; default: break; } } private async void DrawX3DfoLine(PosRes item) { try { StationRes station; List listSat = new List(); CgRes cg; using (RHDWContext db = new RHDWContext()) { listSat = db.SatInfos.ToList(); cg = await db.CgRes.Where(m => m.ID == item.CgResID).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cg == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的计算[{item.CgResID}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.SatTxLon == 0 || station.SatTxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"天线信息为空!"); return; } if (station.RefLon == 0 || station.RefLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"参考站信息为空!"); return; } DfoLineTwoStartOption twoStartOption = new DfoLineTwoStartOption(); twoStartOption.Freq = cg.TarFreqUp.HasValue ? cg.TarFreqUp.Value : 0; twoStartOption.RefFreq = cg.RefFreqUp.HasValue ? cg.RefFreqUp.Value : 0; twoStartOption.MsEph = new double[] { cg.MainX.Value, cg.MainY.Value, cg.MainZ.Value, cg.MainVx.Value, cg.MainVy.Value, cg.MainVz.Value }; twoStartOption.NsEph = new double[] { cg.Adja1X.Value, cg.Adja1Y.Value, cg.Adja1Z.Value, cg.Adja1Vx.Value, cg.Adja1Vy.Value, cg.Adja1Vz.Value }; twoStartOption.MsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.NsAnt = new double[] { station.SatTxLon, station.SatTxLat, 0 }; twoStartOption.RefGeod = new double[] { station.RefLon.Value, station.RefLat.Value, 0 }; twoStartOption.TargetDfo = cg.Dfo1.Value; twoStartOption.Turn1 = Math.Abs(twoStartOption.Freq - (cg.TarFreqDown.HasValue ? cg.TarFreqDown.Value : 0)); twoStartOption.Turn2 = Math.Abs(twoStartOption.RefFreq - (cg.RefFreqDown.HasValue ? cg.RefFreqDown.Value : 0)); twoStartOption.RefDfo = cg.YbMainDfo.Value - cg.YbAdja1Dfo.Value; var tsDtoLine = DrawDfoLineHelper.DfoLineTwoStart(twoStartOption); string msat = string.Empty; string ad1sat = string.Empty; if (cg.MainCode.HasValue) { msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat; ; } if (cg.Adja1Code.HasValue) { ad1sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat; } mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad1sat}]频差线", tsDtoLine); if (item.PosResType == EnumPosResType.X3TwoDfo) { twoStartOption.NsEph = new double[] { cg.Adja2X.Value, cg.Adja2Y.Value, cg.Adja2Z.Value, cg.Adja2Vx.Value, cg.Adja2Vy.Value, cg.Adja2Vz.Value }; twoStartOption.TargetDfo = cg.Dfo2.Value; twoStartOption.RefDfo = cg.YbMainDfo.Value - cg.YbAdja2Dfo.Value; var tsDtoLine1 = DrawDfoLineHelper.DfoLineTwoStart(twoStartOption); string ad2sat = string.Empty; if (cg.Adja2Code.HasValue) { ad2sat = listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat; } mapControl1.DrawDtoPonit($"{item.PosResType.GetEnumDisplayName()}[{msat},{ad2sat}]频差线", tsDtoLine1); } } catch (Exception ex) { Serilog.Log.Error($"绘制{item.PosResType.GetEnumDisplayName()}频差线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制{item.PosResType.GetEnumDisplayName()}频差线失败,失败信息:{ex.Message}"); } } private async void DrawCXLine(PosRes item) { if (!item.CxResID.HasValue) { DxHelper.MsgBoxHelper.ShowWarning($"绘制测向线未有测向编号!"); return; } try { CxRes cx; StationRes station; using (RHDWContext db = new RHDWContext()) { cx = await db.CxRes.Where(m => m.ID == item.CxResID.Value).FirstOrDefaultAsync(); station = await db.StationRes.Where(m => m.ID == item.StationResID).FirstOrDefaultAsync(); } if (cx == null) { DxHelper.MsgBoxHelper.ShowWarning($"未找到定位相关的测向[{item.CxResID.Value}]信息"); return; } if (station == null) { DxHelper.MsgBoxHelper.ShowWarning($"站点信息为空!"); return; } if (station.CxLon == 0 || station.CxLat == 0) { DxHelper.MsgBoxHelper.ShowWarning($"测向站信息为空!"); return; } double deg = cx.Fx;//向北顺时针方向为夹角 //计算测向站到定位点之间的距离 var km = MapControlEx.CalcLineKm(station.CxLon.Value, station.CxLat.Value, item.PosLon, item.PosLat); var endpoint = MapControlEx.CalcSituation(station.CxLon.Value, station.CxLat.Value, deg, (km + 100) * 1000); List<(double, double)> points = new List<(double, double)>(); points.Add((station.CxLon.Value, station.CxLat.Value)); points.Add((endpoint.Item1, endpoint.Item2)); mapControl1.DrawCXLine($"测向线角度:{cx.Fx}°\t\n", points, true); } catch (Exception ex) { Serilog.Log.Error($"绘制测向线失败", ex); DxHelper.MsgBoxHelper.ShowWarning($"绘制测向线失败,失败信息:{ex.Message}"); } } } }