123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608 |
- using System;
- using System.Collections.Generic;
- using System.Data.Entity;
- using System.Data.SqlClient;
- using System.Data.SQLite;
- using System.Linq;
- using System.Net.Http;
- using System.Text;
- using System.Threading.Tasks;
- using System.Web.Http;
- using Newtonsoft.Json;
- using Serilog;
- using Swashbuckle.Swagger;
- using XdCxRhDw.Dto;
- using XdCxRhDW.App.Api;
- using XdCxRhDW.Core.Api;
- using XdCxRhDW.Core.ObServer;
- using XdCxRhDW.Core;
- using XdCxRhDW.Dto;
- using XdCxRhDW.Repostory.EFContext;
- using XdCxRhDW.Repostory.Model;
- using XdCxRhDW.WebApi.Controllers;
- using System.ComponentModel.DataAnnotations;
- namespace XdCxRhDW.App.WebAPI
- {
- /// <summary>
- /// 定位功能相关接口
- /// </summary>
- public class PosController : BaseController
- {
- #region 一星一地测向定位
- /// <summary>
- /// 一星一地测向带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X1D1PosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX1D1Async(X1D1PosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X1D1CX && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到一星一地测向带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动一星一地测向定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- CxLon = dto.CxLon,
- CxLat = dto.CxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var res = PosApi.X1D1_Pos(cgRes, StationRes, cxRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CxResID = cxRes.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X1D1CX,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 一星一地测向带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X1D1NoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX1D1NoXlAsync(X1D1NoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X1D1CX).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到一星一地带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动一星一地定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- CxLon = dto.CxLon,
- CxLat = dto.CxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var res = PosApi.X1D1_Pos(cgRes, StationRes, cxRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X1D1CX,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- #region 两星一地定位
- /// <summary>
- /// 两星一地带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X2D1PosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2D1Async(X2D1PosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到两星一地带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- YbAdja1Dto = dto.AdjaYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- });
- var res = PosApi.X2D1_Pos(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2D1,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 两星一地带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X2D1NoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2D1NoXlAsync(X2D1NoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X2D1).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到两星一地带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaCode);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaCode}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- YbAdja1Dto = dto.AdjaYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja.data.X,
- Adja1Y = ephAdja.data.Y,
- Adja1Z = ephAdja.data.Z,
- });
- var res = PosApi.X2D1_Pos(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2D1,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 两星一地无参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X2D1NoParPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2D1NoParAsync(X2D1NoParPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到两星一地无参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- });
- var res = PosApi.X2D1_PosNoRef(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2D1NoRef,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 两星一地无参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X2D1NoXlNoParlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2D1NoXlNoParAsync(X2D1NoXlNoParlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X2D1).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到两星一地无参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaCode);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaCode}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.AdjaCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.AdjaCode}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja.data.X,
- Adja1Y = ephAdja.data.Y,
- Adja1Z = ephAdja.data.Z,
- });
- var res = PosApi.X2D1_PosNoRef(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2D1NoRef,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- #region 融合定位
- /// <summary>
- /// 融合带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(RHPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosRhAsync(RHPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.RH && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到融合带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动融合定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- CxLon = dto.CxLon,
- CxLat = dto.CxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- YbAdja1Dto = dto.AdjaYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var res = PosApi.RH_Pos(cgRes, StationRes, cxRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CxResID = cxRes.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.RH,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 融合带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(RHNoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosRhNoXlAsync(RHNoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.RH).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到融合带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动融合定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaCode);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaCode}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.AdjaCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.AdjaCode}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- CdbTxLon = dto.CdbTxLon,
- CdbTxLat = dto.CdbTxLat,
- CxLon = dto.CxLon,
- CxLat = dto.CxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.SxDto,
- Dfo1 = dto.SxDfo,
- Snr1 = dto.SxSnr,
- DtoCdb = dto.XdDto,
- DfoCdb = dto.XdDfo,
- SnrCdb = dto.XdSnr,
- YbMainDto = dto.MainYbDto,
- YbAdja1Dto = dto.AdjaYbDto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja.data.X,
- Adja1Y = ephAdja.data.Y,
- Adja1Z = ephAdja.data.Z,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var res = PosApi.RH_Pos(cgRes, StationRes, cxRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CxResID = cxRes.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.RH,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- #region 三星双时差定位
- /// <summary>
- /// 三星双时差带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDtoPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoAsync(X3TwoDtoPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X3TwoDto && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双时差带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- YbMainDto = dto.YbMainDto,
- YbAdja1Dto = dto.YbAdja1Dto,
- YbAdja2Dto = dto.YbAdja2Dto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.Adja1X,
- Adja1Y = dto.Adja1Y,
- Adja1Z = dto.Adja1Z,
- Adja2X = dto.Adja2X,
- Adja2Y = dto.Adja2Y,
- Adja2Z = dto.Adja2Z,
- });
- var res = PosApi.X3_Pos(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 三星双时差带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDtoNoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoNoXlAsync(X3TwoDtoNoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X3TwoDto).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双时差带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.Adja1Code);
- var parameter4 = new SQLiteParameter("@satcode", dto.Adja2Code);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- }
- var xlInfo3 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter4).FirstOrDefaultAsync();
- if (xlInfo3 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja1Code}使用{xlInfo2.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja2Code}使用{xlInfo3.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja1.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja1Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja1Code}]的星历出错");
- }
- var XlCalcDto3 = new XlCalcDto() { tleStr = xlInfo3.TwoLine, dt = dto.SigTime };
- var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto3);
- if (ephAdja2.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja2Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja2Code}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- YbMainDto = dto.YbMainDto,
- YbAdja1Dto = dto.YbAdja1Dto,
- YbAdja2Dto = dto.YbAdja2Dto,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja1.data.X,
- Adja1Y = ephAdja1.data.Y,
- Adja1Z = ephAdja1.data.Z,
- Adja2X = ephAdja2.data.X,
- Adja2Y = ephAdja2.data.Y,
- Adja2Z = ephAdja2.data.Z,
- });
- var res = PosApi.X3_Pos(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 三星双时差无参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDtoNoParPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoNoParAsync(X3TwoDtoNoParPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X3TwoDto && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双时差无参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- Adja1X = dto.Adja1X,
- Adja1Y = dto.Adja1Y,
- Adja1Z = dto.Adja1Z,
- Adja2X = dto.Adja2X,
- Adja2Y = dto.Adja2Y,
- Adja2Z = dto.Adja2Z,
- });
- var res = PosApi.X3_PosNoRef(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3NoRef,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 三星双时差无参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDtoNoXlNoParPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDtoNoXlNoParAsync(X3TwoDtoNoXlNoParPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X3TwoDto).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双时差无参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双时差定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.Adja1Code);
- var parameter4 = new SQLiteParameter("@satcode", dto.Adja2Code);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- }
- var xlInfo3 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter4).FirstOrDefaultAsync();
- if (xlInfo3 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja1Code}使用{xlInfo2.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja2Code}使用{xlInfo3.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja1.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja1Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja1Code}]的星历出错");
- }
- var XlCalcDto3 = new XlCalcDto() { tleStr = xlInfo3.TwoLine, dt = dto.SigTime };
- var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto3);
- if (ephAdja2.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja2Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja2Code}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- Adja1X = ephAdja1.data.X,
- Adja1Y = ephAdja1.data.Y,
- Adja1Z = ephAdja1.data.Z,
- Adja2X = ephAdja2.data.X,
- Adja2Y = ephAdja2.data.Y,
- Adja2Z = ephAdja2.data.Z,
- });
- var res = PosApi.X3_PosNoRef(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3NoRef,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- #region 三星双频差定位
- /// <summary>
- /// 三星双频差带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDfoPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDfoAsync(X3TwoDfoPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X3TwoDfo && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双频差带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双频差定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- YbMainDfo = dto.YbMainDfo,
- YbAdja1Dfo = dto.YbAdja1Dfo,
- YbAdja2Dfo = dto.YbAdja2Dfo,
- TarFreqUp = dto.TarFreqUp,
- TarFreqDown = dto.TarFreqDown,
- RefFreqUp = dto.RefFreqUp,
- RefFreqDown = dto.RefFreqDown,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- MainVx = dto.MainVx,
- MainVy = dto.MainVy,
- MainVz = dto.MainVz,
- Adja1X = dto.Adja1X,
- Adja1Y = dto.Adja1Y,
- Adja1Z = dto.Adja1Z,
- Adja1Vx = dto.Adja1Vx,
- Adja1Vy = dto.Adja1Vy,
- Adja1Vz = dto.Adja1Vz,
- Adja2X = dto.Adja2X,
- Adja2Y = dto.Adja2Y,
- Adja2Z = dto.Adja2Z,
- Adja2Vx = dto.Adja2Vx,
- Adja2Vy = dto.Adja2Vy,
- Adja2Vz = dto.Adja2Vz,
- });
- var res = PosApi.X3_PosTwoDfo(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3TwoDfo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 三星双频差带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X3TwoDfoNoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX3TwoDfoNoXlAsync(X3TwoDfoNoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X3TwoDfo).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到三星双频差带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动三星双频差定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.Adja1Code);
- var parameter4 = new SQLiteParameter("@satcode", dto.Adja2Code);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja1Code}]的双行根数星历");
- }
- var xlInfo3 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter4).FirstOrDefaultAsync();
- if (xlInfo3 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.Adja2Code}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja1Code}使用{xlInfo2.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.Adja2Code}使用{xlInfo3.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja1.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja1Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja1Code}]的星历出错");
- }
- var XlCalcDto3 = new XlCalcDto() { tleStr = xlInfo3.TwoLine, dt = dto.SigTime };
- var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto3);
- if (ephAdja2.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.Adja2Code}]的星历出错");
- return Error<PosResDto>($"推算[{dto.Adja2Code}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto1,
- Dfo1 = dto.Dfo1,
- Snr1 = dto.Snr1,
- Dto2 = dto.Dto2,
- Dfo2 = dto.Dfo2,
- Snr2 = dto.Snr2,
- YbMainDfo = dto.YbMainDfo,
- YbAdja1Dfo = dto.YbAdja1Dfo,
- YbAdja2Dfo = dto.YbAdja2Dfo,
- TarFreqUp = dto.TarFreqUp,
- TarFreqDown = dto.TarFreqDown,
- RefFreqUp = dto.RefFreqUp,
- RefFreqDown = dto.RefFreqDown,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.Adja1Code,
- Adja2Code = dto.Adja2Code,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- MainVx = ephMain.data.VX,
- MainVy = ephMain.data.VY,
- MainVz = ephMain.data.VZ,
- Adja1X = ephAdja1.data.X,
- Adja1Y = ephAdja1.data.Y,
- Adja1Z = ephAdja1.data.Z,
- Adja1Vx = ephAdja1.data.VX,
- Adja1Vy = ephAdja1.data.VY,
- Adja1Vz = ephAdja1.data.VZ,
- Adja2X = ephAdja2.data.X,
- Adja2Y = ephAdja2.data.Y,
- Adja2Z = ephAdja2.data.Z,
- Adja2Vx = ephAdja2.data.VX,
- Adja2Vy = ephAdja2.data.VY,
- Adja2Vz = ephAdja2.data.VZ,
- });
- var res = PosApi.X3_PosTwoDfo(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X3TwoDfo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- #region 双星时频差定位
- /// <summary>
- /// 双星时频差带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- [CustomValidation(typeof(X2DtoDfoPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2DtoDfoAsync(X2DtoDfoPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.FirstOrDefaultAsync(p => p.PosType == EnumPosType.X2Dfo && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到双星时频差带参定位(含星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动双星时频差定位任务");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto,
- Dfo1 = dto.Dfo,
- Snr1 = dto.Snr,
- YbMainDto = dto.YbMainDto,
- YbAdja1Dto = dto.YbAdjaDto,
- YbMainDfo = dto.YbMainDfo,
- YbAdja1Dfo = dto.YbAdjaDfo,
- TarFreqUp = dto.TarFreqUp,
- TarFreqDown = dto.TarFreqDown,
- RefFreqUp = dto.RefFreqUp,
- RefFreqDown = dto.RefFreqDown,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- MainVx = dto.MainVx,
- MainVy = dto.MainVy,
- MainVz = dto.MainVz,
- Adja1X = dto.AdjaX,
- Adja1Y = dto.AdjaY,
- Adja1Z = dto.AdjaZ,
- Adja1Vx = dto.AdjaVx,
- Adja1Vy = dto.AdjaVy,
- Adja1Vz = dto.AdjaVz,
- });
- var res = PosApi.X2_PosDtoDfo(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2Dfo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- /// <summary>
- /// 双星时频差带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- [CustomValidation(typeof(X2DtoDfoNoXlPosDto), "Validate")]
- public async Task<AjaxResult<PosResDto>> PosX2DtoDfoNoXlAsync(X2DtoDfoNoXlPosDto dto)
- {
- using (RHDWContext db = new RHDWContext())
- {
- var runTask = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running && p.PosType == EnumPosType.X2Dfo).FirstOrDefaultAsync();
- if (runTask == null)
- {
- Serilog.Log.Warning($"接收到双星时频差带参定位(无星历)参数,由于任务没有运行中忽略本次定位!");
- return Error<PosResDto>($"多模式融合定位平台没有启动双星时频差定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainCode);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaCode);
- var xlInfo1 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter2).FirstOrDefaultAsync();
- if (xlInfo1 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.MainCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.MainCode}]的双行根数星历");
- }
- var xlInfo2 = await db.XlInfos.SqlQuery("select * from XlInfo where ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))=(select min(ABS(JULIANDAY(TimeBJ)-JULIANDAY(@sigTime))) from XlInfo where satcode=@satcode)", parameter1, parameter3).FirstOrDefaultAsync();
- if (xlInfo2 == null)
- {
- Serilog.Log.Error($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- return Error<PosResDto>($"未找到卫星[{dto.AdjaCode}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainCode}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaCode}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- string url = string.Format("http://{0}:{1}/Api/Xl/Calc", IpHelper.GetLocalIp(), settings.HttpPort);
- var XlCalcDto = new XlCalcDto() { tleStr = xlInfo1.TwoLine, dt = dto.SigTime };
- var ephMain = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto);
- if (ephMain.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.MainCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.MainCode}]的星历出错");
- }
- var XlCalcDto2 = new XlCalcDto() { tleStr = xlInfo2.TwoLine, dt = dto.SigTime };
- var ephAdja = await HttpHelper.PostRequestAsync<SatEphDto>(url, XlCalcDto2);
- if (ephAdja.code != 200)
- {
- Serilog.Log.Error($"推算[{dto.AdjaCode}]的星历出错");
- return Error<PosResDto>($"推算[{dto.AdjaCode}]的星历出错");
- }
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.SatTxLon,
- SatTxLat = dto.SatTxLat,
- RefLon = dto.RefLon,
- RefLat = dto.RefLat,
- });
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- Dto1 = dto.Dto,
- Dfo1 = dto.Dfo,
- Snr1 = dto.Snr,
- YbMainDto = dto.YbMainDto,
- YbAdja1Dto = dto.YbAdjaDto,
- YbMainDfo = dto.YbMainDfo,
- YbAdja1Dfo = dto.YbAdjaDfo,
- TarFreqUp = dto.TarFreqUp,
- TarFreqDown = dto.TarFreqDown,
- RefFreqUp = dto.RefFreqUp,
- RefFreqDown = dto.RefFreqDown,
- StationResID = StationRes.ID,
- MainCode = dto.MainCode,
- Adja1Code = dto.AdjaCode,
- MainX = ephMain.data.X,
- MainY = ephMain.data.Y,
- MainZ = ephMain.data.Z,
- MainVx = ephMain.data.VX,
- MainVy = ephMain.data.VY,
- MainVz = ephMain.data.VZ,
- Adja1X = ephAdja.data.X,
- Adja1Y = ephAdja.data.Y,
- Adja1Z = ephAdja.data.Z,
- Adja1Vx = ephAdja.data.VX,
- Adja1Vy = ephAdja.data.VY,
- Adja1Vz = ephAdja.data.VZ,
- });
- var res = PosApi.X2_PosDtoDfo(cgRes, StationRes);
- PosRes posRes = new PosRes()
- {
- SigTime = dto.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = res[0],
- PosLat = res[1],
- MirrLon = res[3],
- MirrLat = res[4],
- PosResType = EnumPosResType.X2Dfo,
- };
- posRes = db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- PosObServer.Instance.Pub(posRes);
- return Success(Map(posRes));
- }
- }
- #endregion
- private PosResDto Map(PosRes res)
- {
- return new PosResDto()
- {
- ID = res.ID,
- SigTime = res.SigTime,
- TaskInfoID = res.TaskInfoID,
- TarName = string.IsNullOrWhiteSpace(res.TarName) ? "未知目标" : res.TarName,
- PosLon = res.PosLon,
- PosLat = res.PosLat,
- MirrLon = res.MirrLon,
- MirrLat = res.MirrLat,
- PosResType = (EnumPosResTypeDto)((int)res.PosResType)
- };
- }
- /// <summary>
- /// 查询定位结果(暂未实现)
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- [HttpGet]
- public async Task<AjaxResult<PosResDto>> GetPosRes(PosResQueryDto dto)
- {
- await Task.Delay(100);
- return Error<PosResDto>("该功能暂未实现!");
- }
- }
- }
|