| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924 | using System;using System.Collections.Generic;using System.Linq;using System.Net.Http;using System.Text;using System.Threading.Tasks;using DW5S.DTO;using DW5S.Repostory;using System.IO;using DW5S.Entity;using DW5S.WebApi;using System.Diagnostics;using System.Configuration;using Microsoft.AspNetCore.Mvc;using Microsoft.Extensions.Logging;using DW5S.KxcApi;namespace DW5S.App.Controllers{    /// <summary>    /// 定位功能相关接口    /// </summary>    public class PosController : BaseController    {        [Autowired]        private readonly ILogger logger;        [Autowired]        private readonly UnitOfWork unitOfWork;        #region 一星一地测向定位        /// <summary>        /// 一星一地测向带参定位        /// </summary>        /// <returns></returns>        [HttpPost]        public async Task<AjaxResult> PosX1D1Async(X1D1NoXlPosDto dto)        {            TaskInfo runTask;            var repsTask = unitOfWork.Reps<TaskInfo>();            if (dto.TaskID == null)            {                runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group              && p.PosType == EnumPosType.X1D1CX && p.TaskState == EnumTaskState.Running);                if (runTask == null)                {                    string msg = $"接收到一星一地测向带参定位参数,由于找不到执行中的任务忽略本次定位";                    logger.LogWarning(msg);                    return Error(msg);                }            }            else            {                runTask = await repsTask.GetByIdAsync(dto.TaskID);                if (runTask == null)                {                    string msg = $"找不到任务,ID={dto.TaskID}";                    logger.LogWarning(msg);                    return Error(msg);                }            }            var repsXl = unitOfWork.Reps<XlInfo>() as XlRepository;            var xl1 = await repsXl.GetLatestAsync(dto.MainCode, dto.SigTime);            if (xl1 == null)            {                string msg = $"系统缺少编号{dto.MainCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };            var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);            if (ephMain.code != 200)            {                string msg = $"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}";                logger.LogError(msg);                return Error(msg);            }            var repsStationRes = unitOfWork.Reps<StationRes>();            var stationRes = await repsStationRes.AddAsync(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 repsCheckRes = unitOfWork.Reps<CheckRes>();            var ckRes = await repsCheckRes.AddAsync(new CheckRes            {                FileName = dto.CheckRes?.FileName,                SmpStart = dto.CheckRes?.SmpStart,                SmpCount = dto.CheckRes?.SmpCount,                PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,                ModRate = dto.CheckRes?.ModRate,                ModType = dto.CheckRes?.ModType,                UserName = dto.CheckRes?.UserName,                FfcHz = dto.CheckRes?.FfcHz,                Snr = dto.CheckRes?.Snr            });            var repsCgRes = unitOfWork.Reps<CgRes>();            var cgRes = await repsCgRes.AddAsync(new CgRes            {                SigTime = dto.SigTime,                DtoCdb = Math.Round(dto.XdDto, 10),                DfoCdb = Math.Round(dto.XdDfo, 10),                SnrCdb = Math.Round(dto.XdSnr, 1),                YbMainDto = Math.Round(dto.MainYbDto, 10),                StationResID = stationRes.Id,                MainCode = dto.MainCode,                MainXlTime = ephMain.data.TleTime,                TaskID = runTask.Id,                MainX = ephMain.data.X,                MainY = ephMain.data.Y,                MainZ = ephMain.data.Z,                MainVx = ephMain.data.VX,                MainVy = ephMain.data.VY,                MainVz = ephMain.data.VZ,                TarFreqUp = dto.FreqUp,                TarFreqDown = dto.FreqDown,            });            var repsCxRes = unitOfWork.Reps<CxRes>();            var cxRes = await repsCxRes.AddAsync(new CxRes()            {                SigTime = dto.SigTime,                Fx = dto.CxRes,            });            var res = PosApi.X1D1_Pos(cgRes, stationRes, cxRes, dto.CalcConfidence);            var repsPosRes = unitOfWork.Reps<PosRes>();            var posRes = await repsPosRes.AddAsync(new PosRes            {                FreqUpHz = (long)cgRes.TarFreqUp.Value,                SigTime = cgRes.SigTime,                TaskInfoID = runTask.Id,                CxResID = cxRes.Id,                CgResID = cgRes.Id,                CheckResID = ckRes.Id,                PosLon = res[0],                PosLat = res[1],                MirrLon = res[3],                MirrLat = res[4],                Confidence = (int)res[6],                PosResType = EnumPosResType.X1D1CX,            });            await unitOfWork.SaveAsync();            //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放            Messenger.Defalut.Pub("新增定位点", MapModel(posRes));            return Success();        }        #endregion        #region  两星一地定位        /// <summary>        /// 两星一地带参定位        /// </summary>        /// <returns></returns>        [HttpPost]        public async Task<AjaxResult> PosX2D1Async(X2D1NoXlPosDto dto)        {            TargetInfo target = null;            TaskInfo runTask;            var repsTask = unitOfWork.Reps<TaskInfo>();            if (dto.TaskID == null)            {                runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group                   && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);                if (runTask == null)                {                    string msg = $"接收到两星一地带参定位参数,由于找不到执行中的任务忽略本次定位";                    logger.LogWarning(msg);                    return Error(msg);                }            }            else            {                runTask = await repsTask.GetByIdAsync(dto.TaskID);                if (runTask == null)                {                    string msg = $"找不到任务,ID={dto.TaskID}";                    logger.LogWarning(msg);                    return Error(msg);                }            }            if (!string.IsNullOrWhiteSpace(dto.Target))            {                var repsTarget = unitOfWork.Reps<TargetInfo>();                target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());                if (target == null)                {                    target = await repsTarget.AddAsync(new TargetInfo()                    {                        TargetName = dto.Target.Trim(),                        TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())                    });                }            }            var repsXl = unitOfWork.Reps<XlInfo>() as XlRepository;            var xl1 = await repsXl.GetLatestAsync(dto.MainCode, dto.SigTime);            if (xl1 == null)            {                string msg = $"系统缺少编号{dto.MainCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl2 = await repsXl.GetLatestAsync(dto.AdjaCode, dto.SigTime);            if (xl2 == null)            {                string msg = $"系统缺少编号{dto.AdjaCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.AdjaCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };            var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);            if (ephMain.code != 200)            {                string msg = $"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };            var ephAdja = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);            if (ephAdja.code != 200)            {                string msg = $"推算卫星{dto.AdjaCode}的ECEF星历出错.{ephAdja.msg}";                logger.LogError(msg);                return Error(msg);            }            //#warning 测试代码            //var tarEcef = PhysicsHelper.GeoToEcef((110, 17, 0));            //var ecefXl1 = (ephMain.data.X, ephMain.data.Y, ephMain.data.Z);            //var ecefXl2 = (ephAdja.data.X, ephAdja.data.Y, ephAdja.data.Z);            //var ecefCdb = PhysicsHelper.GeoToEcef((dto.CdbTxLon, dto.CdbTxLat, 0));            //var ecefRec = PhysicsHelper.GeoToEcef((dto.SatTxLon, dto.SatTxLat, 0));            //var dt1 = PhysicsHelper.Dto(tarEcef, ecefXl1, ecefRec);            //var dt2 = PhysicsHelper.Dto(tarEcef, ecefXl2, ecefRec);            //var dt3 = PhysicsHelper.Dto(tarEcef, ecefCdb);            //var dto1 = dt1 - dt2;            //var dto2 = dt1 - dt3;            //dto.SxDto = Math.Round(dto1 * 1e6 + r.Next(-10, 10) + r.NextDouble(), 3);            //dto.XdDto = Math.Round(dto2 * 1e6 + r.Next(-10, 10) + r.NextDouble(), 3);            //var refEcef = PhysicsHelper.GeoToEcef((dto.RefLon, dto.RefLat, 0));            //var refdt1 = PhysicsHelper.Dto(refEcef, ecefXl1, ecefRec);            //var refdt2 = PhysicsHelper.Dto(refEcef, ecefXl2, ecefRec);            //dto.MainYbDto = Math.Round(refdt1 * 1e6, 3);            //dto.AdjaYbDto = Math.Round(refdt2 * 1e6, 3);            var repsStationRes = unitOfWork.Reps<StationRes>();            var stationRes = await repsStationRes.AddAsync(new StationRes            {                SatTxLon = dto.SatTxLon,                SatTxLat = dto.SatTxLat,                CdbTxLon = dto.CdbTxLon,                CdbTxLat = dto.CdbTxLat,                RefLon = dto.RefLon,                RefLat = dto.RefLat,            });            var repsCheckRes = unitOfWork.Reps<CheckRes>();            var ckRes = await repsCheckRes.AddAsync(new CheckRes            {                FileName = dto.CheckRes?.FileName,                SmpStart = dto.CheckRes?.SmpStart,                SmpCount = dto.CheckRes?.SmpCount,                PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,                ModRate = dto.CheckRes?.ModRate,                ModType = dto.CheckRes?.ModType,                UserName = dto.CheckRes?.UserName,                FfcHz = dto.CheckRes?.FfcHz,                Snr = dto.CheckRes?.Snr            });            var repsCgRes = unitOfWork.Reps<CgRes>();            var cgRes = await repsCgRes.AddAsync(new CgRes            {                SigTime = dto.SigTime,                Dto1 = Math.Round(dto.SxDto, 10),                Dfo1 = Math.Round(dto.SxDfo, 10),                Snr1 = Math.Round(dto.SxSnr, 1),                DtoCdb = Math.Round(dto.XdDto, 10),                DfoCdb = Math.Round(dto.XdDfo, 10),                SnrCdb = Math.Round(dto.XdSnr, 1),                YbMainDto = Math.Round(dto.MainYbDto, 10),                YbAdja1Dto = Math.Round(dto.AdjaYbDto, 10),                StationResID = stationRes.Id,                MainCode = dto.MainCode,                MainXlTime = ephMain.data.TleTime,                Adja1Code = dto.AdjaCode,                Adja1XlTime = ephAdja.data.TleTime,                TaskID = runTask.Id,                MainX = ephMain.data.X,                MainY = ephMain.data.Y,                MainZ = ephMain.data.Z,                MainVx = ephMain.data.VX,                MainVy = ephMain.data.VY,                MainVz = ephMain.data.VZ,                Adja1Vx = ephAdja.data.VX,                Adja1Vy = ephAdja.data.VY,                Adja1Vz = ephAdja.data.VZ,                Adja1X = ephAdja.data.X,                Adja1Y = ephAdja.data.Y,                Adja1Z = ephAdja.data.Z,                TarFreqUp = dto.FreqUp,                TarFreqDown = dto.FreqDown,            });            var res = PosApi.X2D1_Pos(cgRes, stationRes, dto.CalcConfidence);            var repsPosRes = unitOfWork.Reps<PosRes>();            var posRes = await repsPosRes.AddAsync(new PosRes            {                FreqUpHz = (long)cgRes.TarFreqUp.Value,                SigTime = dto.SigTime,                TaskInfoID = runTask.Id,                CgResID = cgRes.Id,                CheckResID = ckRes.Id,                PosLon = res[0],                PosLat = res[1],                MirrLon = res[3],                MirrLat = res[4],                Confidence = (int)res[6],                PosResType = EnumPosResType.X2D1,                TargetInfoID = target?.Id            });            await unitOfWork.SaveAsync();            //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放            Messenger.Defalut.Pub("新增定位点", MapModel(posRes));            return Success();        }        /// <summary>        /// 两星一地无参定位        /// </summary>        /// <returns></returns>        [HttpPost]        public async Task<AjaxResult> PosX2D1NoParAsync(X2D1NoXlNoParlPosDto dto)        {            TargetInfo target = null;            TaskInfo runTask;            var repsTask = unitOfWork.Reps<TaskInfo>();            if (dto.TaskID == null)            {                runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group                   && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);                if (runTask == null)                {                    string msg = $"接收到两星一地无参定位参数,由于找不到执行中的任务忽略本次定位";                    logger.LogWarning(msg);                    return Error(msg);                }            }            else            {                runTask = await repsTask.GetByIdAsync(dto.TaskID);                if (runTask == null)                {                    string msg = $"找不到任务,ID={dto.TaskID}";                    logger.LogWarning(msg);                    return Error(msg);                }            }            if (!string.IsNullOrWhiteSpace(dto.Target))            {                var repsTarget = unitOfWork.Reps<TargetInfo>();                target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());                if (target == null)                {                    target = await repsTarget.AddAsync(new TargetInfo()                    {                        TargetName = dto.Target.Trim(),                        TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())                    });                }            }            var repsXl = unitOfWork.Reps<XlInfo>() as XlRepository;            var xl1 = await repsXl.GetLatestAsync(dto.MainCode, dto.SigTime);            if (xl1 == null)            {                string msg = $"系统缺少编号{dto.MainCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl2 = await repsXl.GetLatestAsync(dto.AdjaCode, dto.SigTime);            if (xl2 == null)            {                string msg = $"系统缺少编号{dto.AdjaCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.AdjaCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };            var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);            if (ephMain.code != 200)            {                string msg = $"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };            var ephAdja = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);            if (ephAdja.code != 200)            {                string msg = $"推算卫星{dto.AdjaCode}的ECEF星历出错.{ephAdja.msg}";                logger.LogError(msg);                return Error(msg);            }            //#warning 测试代码            //var tarEcef = PhysicsHelper.GeoToEcef((46, 21, 0));            //var ecefXl1 = (ephMain.data.X, ephMain.data.Y, ephMain.data.Z);            //var ecefXl2 = (ephAdja.data.X, ephAdja.data.Y, ephAdja.data.Z);            //var ecefCdb = PhysicsHelper.GeoToEcef((dto.CdbTxLon, dto.CdbTxLat, 0));            //var ecefRec = PhysicsHelper.GeoToEcef((dto.SatTxLon, dto.SatTxLat, 0));            //var dt1 = PhysicsHelper.Dto(tarEcef, ecefXl1, ecefRec);            //var dt2 = PhysicsHelper.Dto(tarEcef, ecefXl2, ecefRec);            //var dt3 = PhysicsHelper.Dto(tarEcef, ecefCdb);            //var dto1 = dt1 - dt2;            //var dto2 = dt1 - dt3;            //dto.SxDto = dto1 * 1e6 + r.Next(-10, 10) + Math.Round(r.NextDouble(), 3);            //dto.XdDto = dto2 * 1e6 + r.Next(-10, 10) + Math.Round(r.NextDouble(), 3);            var repsStationRes = unitOfWork.Reps<StationRes>();            var stationRes = await repsStationRes.AddAsync(new StationRes            {                SatTxLon = dto.SatTxLon,                SatTxLat = dto.SatTxLat,                CdbTxLon = dto.CdbTxLon,                CdbTxLat = dto.CdbTxLat,            });            var repsCheckRes = unitOfWork.Reps<CheckRes>();            var ckRes = await repsCheckRes.AddAsync(new CheckRes            {                FileName = dto.CheckRes?.FileName,                SmpStart = dto.CheckRes?.SmpStart,                SmpCount = dto.CheckRes?.SmpCount,                PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,                ModRate = dto.CheckRes?.ModRate,                ModType = dto.CheckRes?.ModType,                UserName = dto.CheckRes?.UserName,                FfcHz = dto.CheckRes?.FfcHz,                Snr = dto.CheckRes?.Snr            });            var repsCgRes = unitOfWork.Reps<CgRes>();            var cgRes = await repsCgRes.AddAsync(new CgRes            {                SigTime = dto.SigTime,                Dto1 = Math.Round(dto.SxDto, 10),                Dfo1 = Math.Round(dto.SxDfo, 10),                Snr1 = Math.Round(dto.SxSnr, 1),                DtoCdb = Math.Round(dto.XdDto, 10),                DfoCdb = Math.Round(dto.XdDfo, 10),                SnrCdb = Math.Round(dto.XdSnr, 1),                StationResID = stationRes.Id,                MainCode = dto.MainCode,                Adja1Code = dto.AdjaCode,                MainXlTime = ephMain.data.TleTime,                Adja1XlTime = ephAdja.data.TleTime,                TaskID = runTask.Id,                MainX = ephMain.data.X,                MainY = ephMain.data.Y,                MainZ = ephMain.data.Z,                Adja1X = ephAdja.data.X,                Adja1Y = ephAdja.data.Y,                Adja1Z = ephAdja.data.Z,                MainVx = ephMain.data.VX,                MainVy = ephMain.data.VY,                MainVz = ephMain.data.VZ,                Adja1Vx = ephAdja.data.VX,                Adja1Vy = ephAdja.data.VY,                Adja1Vz = ephAdja.data.VZ,                TarFreqUp = dto.FreqUp,                TarFreqDown = dto.FreqDown,            });            var res = PosApi.X2D1_PosNoRef_ZL(cgRes, stationRes, dto.CalcConfidence);            var repsPosRes = unitOfWork.Reps<PosRes>();            var posRes = await repsPosRes.AddAsync(new PosRes            {                FreqUpHz = (long)cgRes.TarFreqUp.Value,                SigTime = dto.SigTime,                TaskInfoID = runTask.Id,                CgResID = cgRes.Id,                CheckResID = ckRes.Id,                PosLon = res[0],                PosLat = res[1],                MirrLon = res[3],                MirrLat = res[4],                Confidence = (int)res[6],                PosResType = EnumPosResType.X2D1NoRef,                TargetInfoID = target?.Id            });            await unitOfWork.SaveAsync();            //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放            Messenger.Defalut.Pub("新增定位点", MapModel(posRes));            return Success();        }        #endregion        #region 三星双时差定位        /// <summary>        /// 三星双时差带参定位        /// </summary>        /// <returns></returns>        [HttpPost]        public async Task<AjaxResult> PosX3TwoDtoAsync(X3TwoDtoNoXlPosDto dto)        {            TargetInfo target = null;            TaskInfo runTask;            var repsTask = unitOfWork.Reps<TaskInfo>();            if (dto.TaskID == null)            {                runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group                   && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);                if (runTask == null)                {                    string msg = $"接收到三星双时差带参定位参数,由于找不到执行中的任务忽略本次定位";                    logger.LogWarning(msg);                    return Error(msg);                }            }            else            {                runTask = await repsTask.GetByIdAsync(dto.TaskID);                if (runTask == null)                {                    string msg = $"找不到任务,ID={dto.TaskID}";                    logger.LogWarning(msg);                    return Error(msg);                }            }            if (!string.IsNullOrWhiteSpace(dto.Target))            {                var repsTarget = unitOfWork.Reps<TargetInfo>();                target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());                if (target == null)                {                    target = await repsTarget.AddAsync(new TargetInfo()                    {                        TargetName = dto.Target.Trim(),                        TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())                    });                }            }            var repsXl = unitOfWork.Reps<XlInfo>() as XlRepository;            var xl1 = await repsXl.GetLatestAsync(dto.MainCode, dto.SigTime);            if (xl1 == null)            {                string msg = $"系统缺少编号{dto.MainCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl2 = await repsXl.GetLatestAsync(dto.Adja1Code, dto.SigTime);            if (xl2 == null)            {                string msg = $"系统缺少编号{dto.Adja1Code}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.Adja1Code}使用发布时刻为{xl2.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl3 = await repsXl.GetLatestAsync(dto.Adja2Code, dto.SigTime);            if (xl3 == null)            {                string msg = $"系统缺少编号{dto.Adja2Code}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.Adja2Code}使用发布时刻为{xl3.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };            var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);            if (ephMain.code != 200)            {                string msg = $"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };            var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);            if (ephAdja1.code != 200)            {                string msg = $"推算卫星{dto.Adja1Code}的ECEF星历出错.{ephAdja1.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto3 = new XlCalcDto() { tleStr = xl3.TwoLine, SigTime = dto.SigTime };            var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto3);            if (ephAdja2.code != 200)            {                string msg = $"推算卫星{dto.Adja2Code}的ECEF星历出错.{ephAdja2.msg}";                logger.LogError(msg);                return Error(msg);            }            var repsStationRes = unitOfWork.Reps<StationRes>();            var stationRes = await repsStationRes.AddAsync(new StationRes            {                SatTxLon = dto.SatTxLon,                SatTxLat = dto.SatTxLat,                RefLon = dto.RefLon,                RefLat = dto.RefLat,            });            var repsCheckRes = unitOfWork.Reps<CheckRes>();            var ckRes = await repsCheckRes.AddAsync(new CheckRes            {                FileName = dto.CheckRes?.FileName,                SmpStart = dto.CheckRes?.SmpStart,                SmpCount = dto.CheckRes?.SmpCount,                PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,                ModRate = dto.CheckRes?.ModRate,                ModType = dto.CheckRes?.ModType,                UserName = dto.CheckRes?.UserName,                FfcHz = dto.CheckRes?.FfcHz,                Snr = dto.CheckRes?.Snr            });            var repsCgRes = unitOfWork.Reps<CgRes>();            var cgRes = await repsCgRes.AddAsync(new CgRes            {                SigTime = dto.SigTime,                Dto1 = Math.Round(dto.Dto1, 10),                Dfo1 = Math.Round(dto.Dfo1, 10),                Snr1 = Math.Round(dto.Snr1, 1),                Dto2 = Math.Round(dto.Dto2, 10),                Dfo2 = Math.Round(dto.Dfo2, 10),                Snr2 = Math.Round(dto.Snr2, 1),                YbMainDto = Math.Round(dto.YbMainDto, 10),                YbAdja1Dto = Math.Round(dto.YbAdja1Dto, 10),                YbAdja2Dto = Math.Round(dto.YbAdja2Dto, 10),                StationResID = stationRes.Id,                MainCode = dto.MainCode,                Adja1Code = dto.Adja1Code,                Adja2Code = dto.Adja2Code,                MainXlTime = ephMain.data.TleTime,                Adja1XlTime = ephAdja1.data.TleTime,                Adja2XlTime = ephAdja2.data.TleTime,                TaskID = runTask.Id,                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,                TarFreqUp = dto.FreqUp,                TarFreqDown = dto.FreqDown,            });            var res = PosApi.X3_Pos(cgRes, stationRes, dto.CalcConfidence);            var repsPosRes = unitOfWork.Reps<PosRes>();            var posRes = await repsPosRes.AddAsync(new PosRes            {                FreqUpHz = (long)cgRes.TarFreqUp.Value,                SigTime = dto.SigTime,                TaskInfoID = runTask.Id,                CgResID = cgRes.Id,                CheckResID = ckRes.Id,                PosLon = res[0],                PosLat = res[1],                MirrLon = res[3],                MirrLat = res[4],                Confidence = (int)res[6],                PosResType = EnumPosResType.X3,                TargetInfoID=target?.Id,            });            await unitOfWork.SaveAsync();            //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放            Messenger.Defalut.Pub("新增定位点", MapModel(posRes));            return Success();        }        /// <summary>        /// 三星双时差无参定位        /// </summary>        /// <returns></returns>        [HttpPost]        public async Task<AjaxResult> PosX3TwoDtoNoParAsync(X3TwoDtoNoXlNoParPosDto dto)        {            TargetInfo target = null;            TaskInfo runTask;            var repsTask = unitOfWork.Reps<TaskInfo>();            if (dto.TaskID == null)            {                runTask = await repsTask.FirstOrDefaultAsync(p => p.TaskType == EnumTaskType.Group                   && p.PosType == EnumPosType.X2D1 && p.TaskState == EnumTaskState.Running);                if (runTask == null)                {                    string msg = $"接收到三星双时差无参定位参数,由于找不到执行中的任务忽略本次定位";                    logger.LogWarning(msg);                    return Error(msg);                }            }            else            {                runTask = await repsTask.GetByIdAsync(dto.TaskID);                if (runTask == null)                {                    string msg = $"找不到任务,ID={dto.TaskID}";                    logger.LogWarning(msg);                    return Error(msg);                }            }            if (!string.IsNullOrWhiteSpace(dto.Target))            {                var repsTarget = unitOfWork.Reps<TargetInfo>();                target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());                if (target == null)                {                    target = await repsTarget.AddAsync(new TargetInfo()                    {                        TargetName = dto.Target.Trim(),                        TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())                    });                }            }            var repsXl = unitOfWork.Reps<XlInfo>() as XlRepository;            var xl1 = await repsXl.GetLatestAsync(dto.MainCode, dto.SigTime);            if (xl1 == null)            {                string msg = $"系统缺少编号{dto.MainCode}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.MainCode}使用发布时刻为{xl1.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl2 = await repsXl.GetLatestAsync(dto.Adja1Code, dto.SigTime);            if (xl2 == null)            {                string msg = $"系统缺少编号{dto.Adja1Code}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.Adja1Code}使用发布时刻为{xl2.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var xl3 = await repsXl.GetLatestAsync(dto.Adja2Code, dto.SigTime);            if (xl3 == null)            {                string msg = $"系统缺少编号{dto.Adja2Code}卫星的星历!";                logger.LogError(msg);                return Error(msg);            }            logger.LogInformation($"卫星{dto.Adja2Code}使用发布时刻为{xl3.TimeUTC:yyyyMMddHHmmss}的星历进行推算");            var XlCalcDto = new XlCalcDto() { tleStr = xl1.TwoLine, SigTime = dto.SigTime };            var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto);            if (ephMain.code != 200)            {                string msg = $"推算卫星{dto.MainCode}的ECEF星历出错.{ephMain.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto2 = new XlCalcDto() { tleStr = xl2.TwoLine, SigTime = dto.SigTime };            var ephAdja1 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto2);            if (ephAdja1.code != 200)            {                string msg = $"推算卫星{dto.Adja1Code}的ECEF星历出错.{ephAdja1.msg}";                logger.LogError(msg);                return Error(msg);            }            var XlCalcDto3 = new XlCalcDto() { tleStr = xl3.TwoLine, SigTime = dto.SigTime };            var ephAdja2 = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), XlCalcDto3);            if (ephAdja2.code != 200)            {                string msg = $"推算卫星{dto.Adja2Code}的ECEF星历出错.{ephAdja2.msg}";                logger.LogError(msg);                return Error(msg);            }            var repsStationRes = unitOfWork.Reps<StationRes>();            var stationRes = await repsStationRes.AddAsync(new StationRes            {                SatTxLon = dto.SatTxLon,                SatTxLat = dto.SatTxLat,            });            var repsCheckRes = unitOfWork.Reps<CheckRes>();            var ckRes = await repsCheckRes.AddAsync(new CheckRes            {                FileName = dto.CheckRes?.FileName,                SmpStart = dto.CheckRes?.SmpStart,                SmpCount = dto.CheckRes?.SmpCount,                PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,                ModRate = dto.CheckRes?.ModRate,                ModType = dto.CheckRes?.ModType,                UserName = dto.CheckRes?.UserName,                FfcHz = dto.CheckRes?.FfcHz,                Snr = dto.CheckRes?.Snr            });            var repsCgRes = unitOfWork.Reps<CgRes>();            var cgRes = await repsCgRes.AddAsync(new CgRes            {                SigTime = dto.SigTime,                Dto1 = Math.Round(dto.Dto1, 10),                Dfo1 = Math.Round(dto.Dfo1, 10),                Snr1 = Math.Round(dto.Snr1, 1),                Dto2 = Math.Round(dto.Dto2, 10),                Dfo2 = Math.Round(dto.Dfo2, 10),                Snr2 = Math.Round(dto.Snr2, 1),                StationResID = stationRes.Id,                MainCode = dto.MainCode,                Adja1Code = dto.Adja1Code,                Adja2Code = dto.Adja2Code,                MainXlTime = ephMain.data.TleTime,                Adja1XlTime = ephAdja1.data.TleTime,                Adja2XlTime = ephAdja2.data.TleTime,                TaskID = runTask.Id,                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,                TarFreqUp = dto.FreqUp,                TarFreqDown = dto.FreqDown,            });            var res = PosApi.X3_PosNoRef(cgRes, stationRes, dto.CalcConfidence);            var repsPosRes = unitOfWork.Reps<PosRes>();            var posRes = await repsPosRes.AddAsync(new PosRes            {                FreqUpHz = (long)cgRes.TarFreqUp.Value,                SigTime = dto.SigTime,                TaskInfoID = runTask.Id,                CgResID = cgRes.Id,                CheckResID = ckRes.Id,                PosLon = res[0],                PosLat = res[1],                MirrLon = res[3],                MirrLat = res[4],                Confidence = (int)res[6],                PosResType = EnumPosResType.X3,                TargetInfoID = target?.Id,            });            await unitOfWork.SaveAsync();            //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放            Messenger.Defalut.Pub("新增定位点", MapModel(posRes));            return Success();        }        #endregion        private object MapModel(PosRes res)        {            return res;            //return new ModelPosRes()            //{            //    ID = res.ID,            //    FreqUpHz = res.FreqUpHz,            //    SigTime = res.SigTime,            //    TaskInfoID = res.TaskInfoID,            //    PosLon = res.PosLon,            //    PosLat = res.PosLat,            //    MirrLon = res.MirrLon,            //    MirrLat = res.MirrLat,            //    TargetState = res.TargetState,            //    PosResType = res.PosResType,            //    CgResID = res.CgResID,            //    CheckRes = res.CheckRes,            //    CheckResID = res.CheckResID,            //    ColorKey = res.ColorKey,            //    CreateTime = res.CreateTime,            //    CxResID = res.CxResID,            //    StationResID = res.StationResID,            //    TargetInfo = res.TargetInfo,            //    TargetInfoID = res.TargetInfoID,            //    UpdateTime = res.UpdateTime,            //    Confidence = res.Confidence,            //};        }    }}
 |