123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704 |
- 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.Security.Cryptography.Xml;
- using System.Text;
- using System.Threading.Tasks;
- using System.Web.Http;
- using System.Windows.Documents;
- using DevExpress.Mvvm.Native;
- using DevExpress.XtraCharts;
- using DevExpress.XtraPrinting;
- using Newtonsoft.Json;
- using PosResAnalysis;
- using Serilog;
- using Swashbuckle.Swagger;
- using XdCxRhDw.Dto;
- using XdCxRhDW.App.Api;
- using XdCxRhDW.App.App.Properties;
- using XdCxRhDW.App.Basic;
- using XdCxRhDW.App.EFContext;
- using XdCxRhDW.App.Model;
- using XdCxRhDW.App.WebAPI.DTO;
- using XdCxRhDW.Dto;
- using static System.Windows.Forms.VisualStyles.VisualStyleElement.TextBox;
- using static XdCxRhDw.CpuCgTools.FormCpuCg;
- using CgRes = XdCxRhDW.App.Model.CgRes;
- namespace XdCxRhDW.App.WebAPI
- {
- /// <summary>
- /// 定位功能相关接口
- /// </summary>
- public class PosController : BaseController
- {
- #region 带参有星历
- /// <summary>
- /// 一星一地测向带参定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动一星一地测向定位任务");
- }
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] res = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- double theta = cxRes.Fx;//单位°
- PosApi.X1D1_POS2023_Core(mainSat, satStation, cdbStation, cxStation, refStation, zone, theta, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, res);
- 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 = Math.Round(res[0], 4),
- PosLat = Math.Round(res[1], 4),
- MirrLon = Math.Round(res[3], 4),
- MirrLat = Math.Round(res[4], 4),
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- /// <summary>
- /// 两星一地定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoSx = dto.SxDto * 1e6,
- DfoSx = dto.SxDfo * 1e6,
- SnrSx = dto.SxSnr,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- YbAdja = dto.AdjaYbDto * 1e6,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- AdjaX = dto.AdjaX,
- AdjaY = dto.AdjaY,
- AdjaZ = dto.AdjaZ,
- });
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] res = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] adjaSat = new double[3] { cgRes.AdjaX, cgRes.AdjaY, cgRes.AdjaZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- PosApi.X2D1_POS_Core(mainSat, adjaSat, cdbStation, satStation, satStation, satStation, satStation, satStation, refStation, zone, cgRes.DtoSx.Value / 1e6, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, cgRes.YbAdja.Value / 1e6, res);
- PosRes posRes = new PosRes()
- {
- SigTime = cgRes.SigTime,
- TaskInfoID = runTask.ID,
- CgResID = cgRes.ID,
- TarName = string.IsNullOrWhiteSpace(dto.TarName) ? "未知目标" : dto.TarName,
- TsName = dto.TsName,
- PosLon = Math.Round(res[0], 4),
- PosLat = Math.Round(res[1], 4),
- MirrLon = Math.Round(res[3], 4),
- MirrLat = Math.Round(res[4], 4),
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- /// <summary>
- /// 融合定位(含星历)
- /// </summary>
- /// <param name="dto">定位参数</param>
- /// <returns></returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var listTx = new List<TxInfo>();
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoSx = dto.SxDto * 1e6,
- DfoSx = dto.SxDfo * 1e6,
- SnrSx = dto.SxSnr,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- YbAdja = dto.AdjaYbDto * 1e6,
- MainX = dto.MainX,
- MainY = dto.MainY,
- MainZ = dto.MainZ,
- AdjaX = dto.AdjaX,
- AdjaY = dto.AdjaY,
- AdjaZ = dto.AdjaZ,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
-
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] resX1D1 = new double[6];
- double[] resX2D1 = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] adjaSat = new double[3] { cgRes.AdjaX, cgRes.AdjaY, cgRes.AdjaZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- double theta = cxRes.Fx;//单位°
- PosApi.X1D1_POS2023_Core(mainSat, satStation, cdbStation, cxStation, refStation, zone, theta, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, resX1D1);
- PosApi.X2D1_POS_Core(mainSat, adjaSat, cdbStation, satStation, satStation, satStation, satStation, satStation, refStation, zone, cgRes.DtoSx.Value / 1e6, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, cgRes.YbAdja.Value / 1e6, resX2D1);
- double[] res = new double[] { 999, 999, 0, 999, 999, 0 };
- if (PosApi.IsGeoPoint(resX1D1) && PosApi.IsGeoPoint(resX2D1))
- {
- res = new double[6] {
- (resX1D1[0] + resX2D1[0]) / 2 + 0.003,
- (resX1D1[1] + resX2D1[1]) / 2 - 0.002,
- (resX1D1[2] + resX2D1[2]) / 2,
- (resX1D1[3] + resX2D1[3]) / 2 + 0.003,
- (resX1D1[4] + resX2D1[4]) / 2 - 0.002,
- (resX1D1[5] + resX2D1[5]) / 2,
- };
- }
- else if (PosApi.IsGeoPoint(resX1D1))
- {
- res = new double[6]
- {
- resX1D1[0] + 0.003,
- resX1D1[1] - 0.002,
- resX1D1[2],
- resX1D1[3] + 0.003,
- resX1D1[4] - 0.002,
- resX1D1[5],
- };
- }
- else if (PosApi.IsGeoPoint(resX2D1))
- {
- res = new double[6]
- {
- resX2D1[0] + 0.003,
- resX2D1[1] - 0.002,
- resX2D1[2],
- resX2D1[3] + 0.003,
- resX2D1[4] - 0.002,
- resX2D1[5],
- };
- }
- 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 = Math.Round(res[0], 4),
- PosLat = Math.Round(res[1], 4),
- MirrLon = Math.Round(res[3], 4),
- MirrLat = Math.Round(res[4], 4),
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- #endregion
- #region 带参无星历
- /// <summary>
- /// 一星一地带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动一星一地定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainSatID);
- 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.MainSatID}]的双行根数星历");
- return Error<PosRes>($"未找到卫星[{dto.MainSatID}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainSatID}使用{xlInfo1.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- var client = new HttpClient();
- string url = string.Format("http://{0}:{1}/Api/", IpHelper.GetLocalIp(), settings.HttpPort);
- url += string.Format("Xl/Calc?tleStr={0}&dt={1}", xlInfo1.TwoLine, dto.SigTime);
- var response = await client.GetAsync(url);
- if (!response.IsSuccessStatusCode) // 处理响应失败
- {
- Serilog.Log.Error($"[{dto.MainSatID}]星厉推算失败");
- return Error<PosRes>($"[{dto.MainSatID}]星厉推算失败");
- }
- var content = await response.Content.ReadAsStringAsync();
- var ephMain = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content).data;
- //var ephMain = EphHelper.Calc(xlInfo1.TwoLine, dto.SigTime);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- MainX = ephMain.X,
- MainY = ephMain.Y,
- MainZ = ephMain.Z,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] res = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- double theta = cxRes.Fx;//单位°
- PosApi.X1D1_POS2023_Core(mainSat, satStation, cdbStation, cxStation, refStation, zone, theta, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, res);
- 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],
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- /// <summary>
- /// 两星一地带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动两星一地定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainSatID);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaSatID);
- 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.MainSatID}]的双行根数星历");
- return Error<PosRes>($"未找到卫星[{dto.MainSatID}]的双行根数星历");
- }
- 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.AdjaSatID}]的双行根数星历");
- return Error<PosRes>($"未找到卫星[{dto.AdjaSatID}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainSatID}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaSatID}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- var client = new HttpClient();
- string url = string.Format("http://{0}:{1}/Api/", IpHelper.GetLocalIp(), settings.HttpPort);
- var url1 = string.Format(url + "Xl/Calc?tleStr={0}&dt={1}", xlInfo1.TwoLine, dto.SigTime);
- var response = await client.GetAsync(url1);
- if (!response.IsSuccessStatusCode) // 处理响应失败
- {
- Serilog.Log.Error($"[{dto.MainSatID}]星厉推算失败");
- return Error<PosRes>($"[{dto.MainSatID}]星厉推算失败");
- }
- var content = await response.Content.ReadAsStringAsync();
- var ephMain = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content).data;
- var url2 = string.Format(url + "Xl/Calc?tleStr={0}&dt={1}", xlInfo2.TwoLine, dto.SigTime);
- var response2 = await client.GetAsync(url2);
- if (!response2.IsSuccessStatusCode) // 处理响应失败
- {
- Serilog.Log.Error($"[{dto.AdjaSatID}]星厉推算失败");
- return Error<PosRes>($"[{dto.AdjaSatID}]星厉推算失败");
- }
- var content2 = await response2.Content.ReadAsStringAsync();
- var ephAdja = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content2).data;
- //var ephMain = EphHelper.Calc(xlInfo1.TwoLine, dto.SigTime);
- //var ephAdja = EphHelper.Calc(xlInfo2.TwoLine, dto.SigTime);
- var cgRes = db.CgRes.Add(new Model.CgRes()
- {
- SigTime = dto.SigTime,
- DtoSx = dto.SxDto * 1e6,
- DfoSx = dto.SxDfo * 1e6,
- SnrSx = dto.SxSnr,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- YbAdja = dto.AdjaYbDto * 1e6,
- MainX = ephMain.X,
- MainY = ephMain.Y,
- MainZ = ephMain.Z,
- AdjaX = ephAdja.X,
- AdjaY = ephAdja.Y,
- AdjaZ = ephAdja.Z,
- });
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] res = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] adjaSat = new double[3] { cgRes.AdjaX, cgRes.AdjaY, cgRes.AdjaZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- PosApi.X2D1_POS_Core(mainSat, adjaSat, cdbStation, satStation, satStation, satStation, satStation, satStation, refStation, zone, dto.SxDto / 1e6, dto.XdDto / 1e6, dto.MainYbDto / 1e6, dto.AdjaYbDto / 1e6, res);
- 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],
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- /// <summary>
- /// 融合带参定位(无星历)
- /// </summary>
- /// <returns>返回定位结果ID</returns>
- [HttpPost]
- public async Task<AjaxResult<PosRes>> 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<PosRes>($"多模式融合定位平台没有启动融合定位任务");
- }
- var parameter1 = new SQLiteParameter("@sigTime", dto.SigTime);
- var parameter2 = new SQLiteParameter("@satcode", dto.MainSatID);
- var parameter3 = new SQLiteParameter("@satcode", dto.AdjaSatID);
- 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.MainSatID}]的双行根数星历");
- return Error<PosRes>($"未找到卫星[{dto.MainSatID}]的双行根数星历");
- }
- 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.AdjaSatID}]的双行根数星历");
- return Error<PosRes>($"未找到卫星[{dto.AdjaSatID}]的双行根数星历");
- }
- Serilog.Log.Information($"卫星{dto.MainSatID}使用{xlInfo1.TwoLine}进行星历推算");
- Serilog.Log.Information($"卫星{dto.AdjaSatID}使用{xlInfo2.TwoLine}进行星历推算");
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- var client = new HttpClient();
- string url = string.Format("http://{0}:{1}/Api/", IpHelper.GetLocalIp(), settings.HttpPort);
- var url1 = string.Format(url + "Xl/Calc?tleStr={0}&dt={1}", xlInfo1.TwoLine, dto.SigTime);
- var response = await client.GetAsync(url1);
- if (!response.IsSuccessStatusCode) // 处理响应失败
- {
- Serilog.Log.Error($"[{dto.MainSatID}]星厉推算失败");
- return Error<PosRes>($"[{dto.MainSatID}]星厉推算失败");
- }
- var content = await response.Content.ReadAsStringAsync();
- var ephMain = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content).data;
- var url2 = string.Format(url + "Xl/Calc?tleStr={0}&dt={1}", xlInfo2.TwoLine, dto.SigTime);
- var response2 = await client.GetAsync(url2);
- if (!response2.IsSuccessStatusCode) // 处理响应失败
- {
- Serilog.Log.Error($"[{dto.AdjaSatID}]星厉推算失败");
- return Error<PosRes>($"[{dto.AdjaSatID}]星厉推算失败");
- }
- var content2 = await response2.Content.ReadAsStringAsync();
- var ephAdja = JsonConvert.DeserializeObject<AjaxResult<SatEphDto>>(content2).data;
- //var ephMain = EphHelper.Calc(xlInfo1.TwoLine, dto.SigTime);
- //var ephAdja = EphHelper.Calc(xlInfo2.TwoLine, dto.SigTime);
- var cgRes = db.CgRes.Add(new CgRes()
- {
- SigTime = dto.SigTime,
- DtoSx = dto.SxDto * 1e6,
- DfoSx = dto.SxDfo * 1e6,
- SnrSx = dto.SxSnr,
- DtoCdb = dto.XdDto * 1e6,
- DfoCdb = dto.XdDfo * 1e6,
- SnrCdb = dto.XdSnr,
- YbMain = dto.MainYbDto * 1e6,
- YbAdja = dto.AdjaYbDto * 1e6,
- MainX = ephMain.X,
- MainY = ephMain.Y,
- MainZ = ephMain.Z,
- AdjaX = ephAdja.X,
- AdjaY = ephAdja.Y,
- AdjaZ = ephAdja.Z,
- });
- var cxRes = db.CxRes.Add(new CxRes()
- {
- SigTime = dto.SigTime,
- Fx = dto.CxRes,
- });
- var StationRes = db.StationRes.Add(new StationRes()
- {
- SatTxLon = dto.StationResInfo.SatTxLon,
- SatTxLat = dto.StationResInfo.SatTxLat,
- CdbTxLon = dto.StationResInfo.CdbTxLon,
- CdbTxLat = dto.StationResInfo.CdbTxLat,
- CxLon = dto.StationResInfo.CxLon,
- CxLat = dto.StationResInfo.CxLat,
- RefLon = dto.StationResInfo.RefLon,
- RefLat = dto.StationResInfo.RefLat,
- });
- double[] resX1D1 = new double[6];
- double[] resX2D1 = new double[6];
- double[] mainSat = new double[3] { cgRes.MainX, cgRes.MainY, cgRes.MainZ };
- double[] adjaSat = new double[3] { cgRes.AdjaX, cgRes.AdjaY, cgRes.AdjaZ };
- double[] satStation = new double[3] { dto.StationResInfo.SatTxLon, dto.StationResInfo.SatTxLat, 0 };
- double[] cdbStation = new double[3] { dto.StationResInfo.CdbTxLon, dto.StationResInfo.CdbTxLat, 0 };
- double[] cxStation = new double[3] { dto.StationResInfo.CxLon, dto.StationResInfo.CxLat, 0 };
- double[] refStation = new double[3] { dto.StationResInfo.RefLon, dto.StationResInfo.RefLat, 0 };
- double[] zone = new double[] { -85, 85, -180, 180 }; //定位区域
- double theta = cxRes.Fx;//单位°
- PosApi.X1D1_POS2023_Core(mainSat, satStation, cdbStation, cxStation, refStation, zone, theta, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, resX1D1);
- PosApi.X2D1_POS_Core(mainSat, adjaSat, cdbStation, satStation, satStation, satStation, satStation, satStation, refStation, zone, cgRes.DtoSx.Value / 1e6, cgRes.DtoCdb.Value / 1e6, cgRes.YbMain.Value / 1e6, cgRes.YbAdja.Value / 1e6, resX2D1);
- double[] res = new double[] { 999, 999, 0, 999, 999, 0 };
- if (PosApi.IsGeoPoint(resX1D1) && PosApi.IsGeoPoint(resX2D1))
- {
- res = new double[6] {
- (resX1D1[0] + resX2D1[0]) / 2 + 0.003,
- (resX1D1[1] + resX2D1[1]) / 2 - 0.002,
- (resX1D1[2] + resX2D1[2]) / 2,
- (resX1D1[3] + resX2D1[3]) / 2 + 0.003,
- (resX1D1[4] + resX2D1[4]) / 2 - 0.002,
- (resX1D1[5] + resX2D1[5]) / 2,
- };
- }
- else if (PosApi.IsGeoPoint(resX1D1))
- {
- res = new double[6]
- {
- resX1D1[0] + 0.003,
- resX1D1[1] - 0.002,
- resX1D1[2],
- resX1D1[3] + 0.003,
- resX1D1[4] - 0.002,
- resX1D1[5],
- };
- }
- else if (PosApi.IsGeoPoint(resX2D1))
- {
- res = new double[6]
- {
- resX2D1[0] + 0.003,
- resX2D1[1] - 0.002,
- resX2D1[2],
- resX2D1[3] + 0.003,
- resX2D1[4] - 0.002,
- resX2D1[5],
- };
- }
- 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 = Math.Round(res[0], 4),
- PosLat = Math.Round(res[1], 4),
- MirrLon = Math.Round(res[3], 4),
- MirrLat = Math.Round(res[4], 4),
- };
- db.PosRes.Add(posRes);
- await db.SaveChangesAsync();
- return Success(posRes);
- }
- }
- #endregion
- /// <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>("该功能暂未实现!");
- }
- }
- }
|