123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980 |
- using DevExpress.Utils;
- using DevExpress.Utils.Drawing;
- using DevExpress.Utils.Drawing.Helpers;
- using DevExpress.Utils.Svg;
- using DevExpress.XtraEditors.ButtonsPanelControl;
- using DevExpress.XtraGrid.Views.Grid;
- using DevExpress.XtraGrid.Views.Grid.ViewInfo;
- using DevExpress.XtraTreeList.Data;
- 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.Api.时差线;
- using XdCxRhDW.App.EditForms;
- using XdCxRhDW.App.EFContext;
- using XdCxRhDW.App.Model;
- using System.Windows.Documents;
- using XdCxRhDW.App.ObServer;
- namespace XdCxRhDW.App.UserControl
- {
- public partial class CtrlHome : DevExpress.XtraEditors.XtraUserControl
- {
- List<TaskInfo> list = new List<TaskInfo>();
- 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<PosRes>;
- 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<PosRes> listPos = new List<PosRes>();
- 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<SatInfo> satList = new List<SatInfo>();
- List<TxInfo> txList = new List<TxInfo>();
- 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<PosRes>("绘制时差线", SvgHelper.LoadFromFile("Image\\DtoLine.svg"), item =>
- {
- var posType = GetPosRes(item, "绘制时差线");
- DrawDtoLine(item, posType);
- })
- .AddPosMenu<PosRes>("绘制频差线", SvgHelper.LoadFromFile("Image\\DfoLine.svg"), item =>
- {
- var posType = GetPosRes(item, "绘制频差线");
- DrawDfoLine(item, posType);
- })
- //.AddPosMenu<PosRes>("绘制GDOP", SvgHelper.LoadFromFile("Image\\GDOP.svg"), item =>
- // {
- // var posType = GetPosRes(item, "绘制GDOP");
- // DrawGDOP(item.SigTime, posType);
- // })
- .AddPosMenu<PosRes>("绘制测向线", btnDrawCX.ImageOptions.SvgImage, item =>
- {
- DrawCXLine(item);
- });
- }
- 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<WebAPI.Startup>(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.Item2)
- {
- case EnumPosType.X1D1CX:
- //一星一地 测向线
- btnDrawDto.Visibility = btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
- btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
- break;
- case EnumPosType.X2D1:
- //两星一地 GDOP 时差线
- btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
- btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
- break;
- case EnumPosType.RH:
- //融合DW GDOP 时差线 测向线
- btnDrawDto.Visibility = btnDrawCX.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
- btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
- break;
- case EnumPosType.X3TwoDto:
- //三星双时差DW GDOP 时差线
- btnDrawDto.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
- btnDrawCX.Visibility = btnDrawDfo.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
- break;
- case EnumPosType.X3TwoDfo:
- //三星双频差DW GDOP 频差线
- btnDrawDfo.Visibility = btnGDOP.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
- btnDrawDto.Visibility = btnDrawCX.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
- break;
- case EnumPosType.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<DisplayAttribute>().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<WebAPI.Startup>(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<PosRes>(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("绘制时差");
- var posRes = info.Item1;
- if (posRes == null) return;
- var posType = info.Item2;
- DrawDtoLine(posRes, posType);
- }
- private (PosRes, EnumPosType) GetPosRes(string msg)
- {
- var ids = gridView2.GetSelectedRows();
- if (ids.Length <= 0)
- {
- DxHelper.MsgBoxHelper.ShowWarning($"请选择需要{msg}的定位数据信息!");
- return (null, default);
- }
- var item = gridView2.GetRow(ids[0]) as PosRes;
- var taskInfo = list.Find(m => m.ID == item.TaskInfoID);
- if (taskInfo == null)
- {
- DxHelper.MsgBoxHelper.ShowWarning($"{msg}未找到任务[{item.TaskInfoID}]!");
- return (null, default);
- }
- return (item, taskInfo.PosType);
- }
- private EnumPosType GetPosRes(PosRes posRes, string msg)
- {
- var taskInfo = list.Find(m => m.ID == posRes.TaskInfoID);
- if (taskInfo == null)
- {
- DxHelper.MsgBoxHelper.ShowWarning($"{msg}未找到任务[{posRes.TaskInfoID}]!");
- return default;
- }
- return taskInfo.PosType;
- }
- private void btnDrawDfo_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
- {
- var info = GetPosRes("绘制频差");
- var posRes = info.Item1;
- if (posRes == null) return;
- var posType = info.Item2;
- DrawDfoLine(posRes, posType);
- }
- 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;
- DrawCXLine(item);
- }
- private void btnGDOP_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
- {
- var info = GetPosRes("绘制GDOP");
- var posRes = info.Item1;
- if (posRes == null) return;
- var posType = info.Item2;
- DrawGDOP(posRes, posType);
- }
- private void DrawGDOP(PosRes item, EnumPosType posType)
- {
- try
- {
- switch (posType)
- {
- case EnumPosType.X1D1CX:
- //X1D1GDOPParam x1D1GdopParam = new X1D1GDOPParam(sigTime);
- //x1D1GdopParam.mapControl1 = mapControl1;
- //DxHelper.PopupHelper.ShowPopup(x1D1GdopParam, mapControl1, mapControl1.Width / 4);
- break;
- case EnumPosType.X2D1:
- case EnumPosType.RH:
- X2D1GDOPParam x2D1GdopParam = new X2D1GDOPParam(item);
- x2D1GdopParam.mapControl1 = mapControl1;
- DxHelper.PopupHelper.ShowPopup(x2D1GdopParam, mapControl1, mapControl1.Width / 4);
- break;
- //case EnumPosType.RH:
- // GDOPParam gdopParam = new GDOPParam(sigTime);
- // gdopParam.mapControl1 = mapControl1;
- // DxHelper.PopupHelper.ShowPopup(gdopParam, mapControl1, mapControl1.Width / 4);
- // break;
- default:
- break;
- }
- }
- catch (Exception ex)
- {
- DxHelper.MsgBoxHelper.ShowWarning($"绘制{posType.GetEnumDisplayName()}GDOP失败,{ex.Message}");
- }
- }
- private void DrawDtoLine(PosRes item, EnumPosType posType)
- {
- switch (posType)
- {
- case EnumPosType.X1D1CX:
- case EnumPosType.X2D1:
- DrawXDtoLine(item, posType);
- break;
- case EnumPosType.RH:
- DrawXDtoLine(item, EnumPosType.X1D1CX);
- DrawXDtoLine(item, EnumPosType.X2D1);
- break;
- case EnumPosType.X3TwoDto:
- case EnumPosType.X2Dfo:
- DrawX3toLine(item, posType);
- break;
- default:
- break;
- }
- }
- private async void DrawXDtoLine(PosRes item, EnumPosType posType)
- {
- try
- {
- StationRes station;
- List<SatInfo> listSat = new List<SatInfo>();
- 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.CgResID).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;
- var msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat;
- var xdDtoLine = DrawDtoLineHelper.DtoLineXd(dtoLineXd);
- mapControl1.DrawDtoPonit($"星地[{msat},[{station.CdbTxLon}°]]时差线", xdDtoLine);
- if (posType == EnumPosType.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.DtoLineXDTwoStart(twoStartOption);
- mapControl1.DrawDtoPonit($"双星[{msat},{listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat}]时差线", tsDtoLine);
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error($"绘制{posType.GetEnumDisplayName()}时差线失败", ex);
- DxHelper.MsgBoxHelper.ShowWarning($"绘制{posType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}");
- }
- }
- private async void DrawX3toLine(PosRes item, EnumPosType posType)
- {
- try
- {
- StationRes station;
- List<SatInfo> listSat = new List<SatInfo>();
- 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.CgResID).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;
- var msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat;
- var tsDtoLine = DrawDtoLineHelper.DtoLineXDTwoStart(twoStartOption);
- mapControl1.DrawDtoPonit($"{posType.GetEnumDisplayName()}[{msat},{listSat.FirstOrDefault(m => m.SatCode == cg.Adja1Code.Value)?.Sat}]时差线", tsDtoLine);
- if (posType == EnumPosType.X3TwoDto)
- {
- 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.DtoLineXDTwoStart(twoStartOption);
- mapControl1.DrawDtoPonit($"{posType.GetEnumDisplayName()}[{msat},{listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat}]时差线", tsDtoLine1);
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error($"绘制{posType.GetEnumDisplayName()}时差线失败", ex);
- DxHelper.MsgBoxHelper.ShowWarning($"绘制{posType.GetEnumDisplayName()}时差线失败,失败信息:{ex.Message}");
- }
- }
- private void DrawDfoLine(PosRes item, EnumPosType posType)
- {
- switch (posType)
- {
- case EnumPosType.X3TwoDfo:
- case EnumPosType.X2Dfo:
- DrawX3DfoLine(item, posType);
- break;
- default:
- break;
- }
- }
- private async void DrawX3DfoLine(PosRes item, EnumPosType posType)
- {
- try
- {
- StationRes station;
- List<SatInfo> listSat = new List<SatInfo>();
- 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.CgResID).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 msat = listSat.FirstOrDefault(m => m.SatCode == cg.MainCode.Value)?.Sat;
- var tsDtoLine = DrawDfoLineHelper.DfoLineTwoStart(twoStartOption);
- mapControl1.DrawDtoPonit($"{posType.GetEnumDisplayName()}[{msat},{listSat.FirstOrDefault(m => m.SatCode == cg.Adja1X.Value)?.Sat}]频差线", tsDtoLine);
- if (posType == EnumPosType.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);
- mapControl1.DrawDtoPonit($"{posType.GetEnumDisplayName()}[{msat},{listSat.FirstOrDefault(m => m.SatCode == cg.Adja2Code.Value)?.Sat}]频差线", tsDtoLine1);
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error($"绘制{posType.GetEnumDisplayName()}频差线失败", ex);
- DxHelper.MsgBoxHelper.ShowWarning($"绘制{posType.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.CgResID).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 startdeg = 360;
- double deg = startdeg - 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);
- }
- catch (Exception ex)
- {
- Serilog.Log.Error($"绘制测向线失败", ex);
- DxHelper.MsgBoxHelper.ShowWarning($"绘制测向线失败,失败信息:{ex.Message}");
- }
- }
- }
- }
|