12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217 |
- 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<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 =>
- {
- 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<PosRes>("绘制频差线", 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<PosRes>("绘制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<PosRes>("绘制测向线", 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<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.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<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<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("绘制时差");
- 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<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.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<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.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<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.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<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.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<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.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}");
- }
- }
- }
- }
|