PosController.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net.Http;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using DW5S.DTO;
  8. using DW5S.Repostory;
  9. using System.IO;
  10. using DW5S.Entity;
  11. using DW5S.WebApi;
  12. using System.Diagnostics;
  13. using System.Configuration;
  14. using Microsoft.AspNetCore.Mvc;
  15. using Serilog;
  16. using DW5S.KxcApi;
  17. namespace DW5S.Controllers
  18. {
  19. /// <summary>
  20. /// 定位功能相关接口
  21. /// </summary>
  22. public class PosController : BaseController
  23. {
  24. ILogger logger { get; set; }
  25. IUnitOfWork unitOfWork { get; set; }
  26. #region 一星一地测向定位
  27. /// <summary>
  28. /// 一星一地测向带参定位
  29. /// </summary>
  30. /// <returns></returns>
  31. [HttpPost]
  32. public async Task<AjaxResult> PosX1D1Async(X1D1PosDto dto)
  33. {
  34. TargetInfo target = null;
  35. var repsTask = unitOfWork.Of<TaskInfo>();
  36. var runTask = await repsTask.GetByIdAsync(dto.TaskID);
  37. if (runTask == null)
  38. {
  39. string msg = $"找不到任务,ID={dto.TaskID}";
  40. logger.Error(msg);
  41. return Error(msg);
  42. }
  43. if (!string.IsNullOrWhiteSpace(dto.Target))
  44. {
  45. var repsTarget = unitOfWork.Of<TargetInfo>();
  46. target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());
  47. target ??= await repsTarget.AddOrUpdateAsync(new TargetInfo()
  48. {
  49. TargetName = dto.Target.Trim(),
  50. TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())
  51. });
  52. }
  53. var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), new SatDto { SatCode = dto.MainCode, SigTime = dto.SigTime });
  54. if (ephMain.code != 200)
  55. {
  56. logger.Error(ephMain.msg);
  57. return Error(ephMain.msg);
  58. }
  59. //采集结果
  60. List<AdResDto> adres = new List<AdResDto>() {
  61. dto.AdRes.First(p => p.SatCode == dto.MainCode),//主星采集结果
  62. dto.AdRes.First(p => p.SatCode == dto.Adja1Code) };//超短站某个方向采集结果
  63. var repsAdRes = unitOfWork.OfLong<AdRes>();
  64. List<long> adIds = new List<long>();
  65. foreach (var adRes in adres)
  66. {
  67. var adItem = await repsAdRes.AddOrUpdateAsync(new AdRes
  68. {
  69. SatCode = dto.MainCode,
  70. RealFileCreateTime = adRes.RealFileCreateTime,
  71. FileTime = adRes.FileTime,
  72. RealFileUpdateTime = adRes.RealFileUpdateTime,
  73. Ch = adRes.Ch,
  74. FileSeconds = adRes.FileSeconds,
  75. FreqCenter = adRes.FreqCenter,
  76. FreqdownHz = adRes.FreqdownHz,
  77. FrequpHz = adRes.FrequpHz,
  78. FsHz = adRes.FsHz,
  79. HttpFile = adRes.HttpFile,
  80. SigTime = dto.SigTime,
  81. RecTxInfoID = adRes.RecTxInfoID,
  82. RecStationName = adRes.RecStationName,
  83. FileSize = adRes.FileSize,
  84. RealFileSize = adRes.RealFileSize,
  85. FileErrorMsg = adRes.FileErrorMsg,
  86. });
  87. adIds.Add(adItem.Id);
  88. }
  89. var repsStationRes = unitOfWork.OfLong<StationRes>();
  90. var stationRes = await repsStationRes.AddOrUpdateAsync(new StationRes
  91. {
  92. SatTxLon = dto.SatTxLon,
  93. SatTxLat = dto.SatTxLat,
  94. CdbTxLon = dto.CdbTxLon,
  95. CdbTxLat = dto.CdbTxLat,
  96. CxLon = dto.CxLon,
  97. CxLat = dto.CxLat,
  98. RefLon = dto.RefLon,
  99. RefLat = dto.RefLat,
  100. });
  101. var repsCheckRes = unitOfWork.OfLong<CheckRes>();
  102. var ckRes = await repsCheckRes.AddOrUpdateAsync(new CheckRes
  103. {
  104. HttpFile = dto.CheckRes.FileName,
  105. SmpStart = dto.CheckRes.SmpStart,
  106. SmpCount = dto.CheckRes.SmpCount,
  107. PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
  108. ModRate = dto.CheckRes.ModRate,
  109. ModType = dto.CheckRes.ModType,
  110. UserName = dto.CheckRes.UserName,
  111. FfcHz = dto.CheckRes.FfcHz,
  112. Snr = dto.CheckRes.Snr
  113. });
  114. var repsCgRes = unitOfWork.OfLong<CgRes>();
  115. var cgRes = await repsCgRes.AddOrUpdateAsync(new CgRes
  116. {
  117. SigTime = dto.SigTime,
  118. FrequpHz = dto.FrequpHz,
  119. FreqdownHz = dto.FreqdownHz,
  120. Dto1 = Math.Round(dto.XdDto, 3),
  121. Dfo1 = Math.Round(dto.XdDfo, 3),
  122. Snr1 = Math.Round(dto.XdSnr, 1),
  123. Dto2 = null,
  124. Dfo2 = null,
  125. Snr2 = null,
  126. StationResID = stationRes.Id,
  127. MainCode = dto.MainCode,
  128. Adja1Code = dto.Adja1Code,
  129. Adja2Code = null,
  130. MainXlTime = ephMain.data.TleTime,
  131. Adja1XlTime = null,
  132. TaskID = runTask.Id,
  133. MainX = ephMain.data.X,
  134. MainY = ephMain.data.Y,
  135. MainZ = ephMain.data.Z,
  136. Adja1X = null,
  137. Adja1Y = null,
  138. Adja1Z = null,
  139. CheckResID = ckRes.Id,
  140. SigInfoID = dto.SigInfoID,
  141. AdResId1 = adIds[0],
  142. AdResId2 = adIds[1],
  143. AdResId3 = null,
  144. });
  145. var repsCxRes = unitOfWork.OfLong<CxRes>();
  146. var cxRes = await repsCxRes.AddOrUpdateAsync(new CxRes()
  147. {
  148. SigTime = dto.SigTime,
  149. Fx = dto.CxRes,
  150. });
  151. var res = PosApi.X1D1_Pos(cgRes, stationRes, cxRes, dto.CalcConfidence);
  152. var repsPosRes = unitOfWork.OfLong<PosRes>();
  153. var posRes = await repsPosRes.AddOrUpdateAsync(new PosRes
  154. {
  155. FrequpHz = cgRes.FrequpHz,
  156. FreqdownHz = cgRes.FreqdownHz,
  157. SigTime = dto.SigTime,
  158. TaskID = runTask.Id,
  159. CgResID = cgRes.Id,
  160. CheckResID = ckRes.Id,
  161. PosLon = res[0],
  162. PosLat = res[1],
  163. MirrLon = res[3],
  164. MirrLat = res[4],
  165. Confidence = (int)res[6],
  166. PosResType = EnumPosResType.X1D1CX,
  167. TargetInfoID = target?.Id,
  168. SigInfoID = dto.SigInfoID,
  169. StationResID = stationRes.Id,
  170. CxResID = cxRes.Id,
  171. });
  172. await unitOfWork.SaveAsync();
  173. //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放
  174. Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
  175. return Success();
  176. }
  177. #endregion
  178. #region 两星一地定位
  179. /// <summary>
  180. /// 两星一地带参定位
  181. /// </summary>
  182. /// <returns></returns>
  183. [HttpPost]
  184. public async Task<AjaxResult> PosX2D1Async(X2D1PosDto dto)
  185. {
  186. TargetInfo target = null;
  187. var repsTask = unitOfWork.Of<TaskInfo>();
  188. var runTask = await repsTask.GetByIdAsync(dto.TaskID);
  189. if (runTask == null)
  190. {
  191. string msg = $"找不到任务,ID={dto.TaskID}";
  192. logger.Error(msg);
  193. return Error(msg);
  194. }
  195. if (!string.IsNullOrWhiteSpace(dto.Target))
  196. {
  197. var repsTarget = unitOfWork.Of<TargetInfo>();
  198. target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());
  199. target ??= await repsTarget.AddOrUpdateAsync(new TargetInfo()
  200. {
  201. TargetName = dto.Target.Trim(),
  202. TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())
  203. });
  204. }
  205. var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), new SatDto { SatCode = dto.MainCode, SigTime = dto.SigTime });
  206. if (ephMain.code != 200)
  207. {
  208. logger.Error(ephMain.msg);
  209. return Error(ephMain.msg);
  210. }
  211. var ephAdja = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), new SatDto { SatCode = dto.Adja1Code, SigTime = dto.SigTime });
  212. if (ephAdja.code != 200)
  213. {
  214. logger.Error(ephAdja.msg);
  215. return Error(ephAdja.msg);
  216. }
  217. //#warning 测试代码
  218. //var tarEcef = PhysicsHelper.GeoToEcef((110, 17, 0));
  219. //var ecefXl1 = (ephMain.data.X, ephMain.data.Y, ephMain.data.Z);
  220. //var ecefXl2 = (ephAdja.data.X, ephAdja.data.Y, ephAdja.data.Z);
  221. //var ecefCdb = PhysicsHelper.GeoToEcef((dto.CdbTxLon, dto.CdbTxLat, 0));
  222. //var ecefRec = PhysicsHelper.GeoToEcef((dto.SatTxLon, dto.SatTxLat, 0));
  223. //var dt1 = PhysicsHelper.Dto(tarEcef, ecefXl1, ecefRec);
  224. //var dt2 = PhysicsHelper.Dto(tarEcef, ecefXl2, ecefRec);
  225. //var dt3 = PhysicsHelper.Dto(tarEcef, ecefCdb);
  226. //var dto1 = dt1 - dt2;
  227. //var dto2 = dt1 - dt3;
  228. //dto.SxDto = Math.Round(dto1 * 1e6 + r.Next(-10, 10) + r.NextDouble(), 3);
  229. //dto.XdDto = Math.Round(dto2 * 1e6 + r.Next(-10, 10) + r.NextDouble(), 3);
  230. //var refEcef = PhysicsHelper.GeoToEcef((dto.RefLon, dto.RefLat, 0));
  231. //var refdt1 = PhysicsHelper.Dto(refEcef, ecefXl1, ecefRec);
  232. //var refdt2 = PhysicsHelper.Dto(refEcef, ecefXl2, ecefRec);
  233. //dto.MainYbDto = Math.Round(refdt1 * 1e6, 3);
  234. //dto.AdjaYbDto = Math.Round(refdt2 * 1e6, 3);
  235. //采集结果
  236. List<AdResDto> adres = new List<AdResDto>() {
  237. dto.AdRes.First(p => p.SatCode == dto.MainCode),//主星采集结果
  238. dto.AdRes.First(p => p.SatCode == dto.Adja1Code),//邻1星采集结果
  239. dto.AdRes.First(p => p.SatCode == dto.Adja2Code) };//超短站某个方向采集结果
  240. var repsAdRes = unitOfWork.OfLong<AdRes>();
  241. List<long> adIds = new List<long>();
  242. foreach (var adRes in adres)
  243. {
  244. var adItem = await repsAdRes.AddOrUpdateAsync(new AdRes
  245. {
  246. SatCode = dto.MainCode,
  247. RealFileCreateTime = adRes.RealFileCreateTime,
  248. FileTime = adRes.FileTime,
  249. RealFileUpdateTime = adRes.RealFileUpdateTime,
  250. Ch = adRes.Ch,
  251. FileSeconds = adRes.FileSeconds,
  252. FreqCenter = adRes.FreqCenter,
  253. FreqdownHz = adRes.FreqdownHz,
  254. FrequpHz = adRes.FrequpHz,
  255. FsHz = adRes.FsHz,
  256. HttpFile = adRes.HttpFile,
  257. SigTime = dto.SigTime,
  258. RecTxInfoID = adRes.RecTxInfoID,
  259. RecStationName = adRes.RecStationName,
  260. FileSize = adRes.FileSize,
  261. RealFileSize = adRes.RealFileSize,
  262. FileErrorMsg = adRes.FileErrorMsg,
  263. });
  264. adIds.Add(adItem.Id);
  265. }
  266. //站点信息
  267. var repsStationRes = unitOfWork.OfLong<StationRes>();
  268. var stationRes = await repsStationRes.AddOrUpdateAsync(new StationRes
  269. {
  270. SatTxLon = dto.SatTxLon,
  271. SatTxLat = dto.SatTxLat,
  272. CdbTxLon = dto.CdbTxLon,
  273. CdbTxLat = dto.CdbTxLat,
  274. RefLon = dto.RefLon,
  275. RefLat = dto.RefLat,
  276. });
  277. //检测结果
  278. var repsCheckRes = unitOfWork.OfLong<CheckRes>();
  279. var ckRes = await repsCheckRes.AddOrUpdateAsync(new CheckRes
  280. {
  281. HttpFile = dto.CheckRes.FileName,
  282. SmpStart = dto.CheckRes.SmpStart,
  283. SmpCount = dto.CheckRes.SmpCount,
  284. PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
  285. ModRate = dto.CheckRes.ModRate,
  286. ModType = dto.CheckRes.ModType,
  287. UserName = dto.CheckRes.UserName,
  288. FfcHz = dto.CheckRes.FfcHz,
  289. Snr = dto.CheckRes.Snr,
  290. });
  291. //参估结果
  292. var repsCgRes = unitOfWork.OfLong<CgRes>();
  293. var cgRes = await repsCgRes.AddOrUpdateAsync(new CgRes
  294. {
  295. SigTime = dto.SigTime,
  296. FrequpHz = dto.FrequpHz,
  297. FreqdownHz = dto.FreqdownHz,
  298. Dto1 = Math.Round(dto.SxDto, 10),
  299. Dfo1 = Math.Round(dto.SxDfo, 10),
  300. Snr1 = Math.Round(dto.SxSnr, 1),
  301. Dto2 = Math.Round(dto.XdDto, 10),
  302. Dfo2 = Math.Round(dto.XdDfo, 10),
  303. Snr2 = Math.Round(dto.XdSnr, 1),
  304. StationResID = stationRes.Id,
  305. MainCode = dto.MainCode,
  306. Adja1Code = dto.Adja1Code,
  307. Adja2Code = dto.Adja2Code,
  308. MainXlTime = ephMain.data.TleTime,
  309. Adja1XlTime = ephAdja.data.TleTime,
  310. TaskID = runTask.Id,
  311. MainX = ephMain.data.X,
  312. MainY = ephMain.data.Y,
  313. MainZ = ephMain.data.Z,
  314. Adja1X = ephAdja.data.X,
  315. Adja1Y = ephAdja.data.Y,
  316. Adja1Z = ephAdja.data.Z,
  317. CheckResID = ckRes.Id,
  318. SigInfoID = dto.SigInfoID,
  319. AdResId1 = adIds[0],
  320. AdResId2 = adIds[1],
  321. AdResId3 = adIds[2],
  322. });
  323. //定位结果
  324. var res = PosApi.X2D1_Pos(cgRes, stationRes, dto.CalcConfidence);
  325. var repsPosRes = unitOfWork.OfLong<PosRes>();
  326. var posRes = await repsPosRes.AddOrUpdateAsync(new PosRes
  327. {
  328. FrequpHz = cgRes.FrequpHz,
  329. FreqdownHz = cgRes.FreqdownHz,
  330. SigTime = dto.SigTime,
  331. TaskID = runTask.Id,
  332. CgResID = cgRes.Id,
  333. CheckResID = ckRes.Id,
  334. PosLon = res[0],
  335. PosLat = res[1],
  336. MirrLon = res[3],
  337. MirrLat = res[4],
  338. Confidence = (int)res[6],
  339. PosResType = EnumPosResType.X2D1,
  340. TargetInfoID = target?.Id,
  341. SigInfoID = dto.SigInfoID,
  342. StationResID = stationRes.Id,
  343. });
  344. await unitOfWork.SaveAsync();
  345. //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放
  346. Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
  347. return Success();
  348. }
  349. /// <summary>
  350. /// 两星一地无参定位
  351. /// </summary>
  352. /// <returns></returns>
  353. [HttpPost]
  354. public async Task<AjaxResult> PosX2D1NoParAsync(X2D1NoRefPosDto dto)
  355. {
  356. TargetInfo target = null;
  357. var repsTask = unitOfWork.Of<TaskInfo>();
  358. var runTask = await repsTask.GetByIdAsync(dto.TaskID);
  359. if (runTask == null)
  360. {
  361. string msg = $"找不到任务,ID={dto.TaskID}";
  362. logger.Error(msg);
  363. return Error(msg);
  364. }
  365. if (!string.IsNullOrWhiteSpace(dto.Target))
  366. {
  367. var repsTarget = unitOfWork.Of<TargetInfo>();
  368. target = await repsTarget.FirstOrDefaultAsync(p => p.TargetName == dto.Target.Trim());
  369. target ??= await repsTarget.AddOrUpdateAsync(new TargetInfo()
  370. {
  371. TargetName = dto.Target.Trim(),
  372. TargeColor = ColorHelper.GetHtmlColor(dto.Target.Trim())
  373. });
  374. }
  375. var ephMain = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), new SatDto { SatCode = dto.MainCode, SigTime = dto.SigTime });
  376. if (ephMain.code != 200)
  377. {
  378. logger.Error(ephMain.msg);
  379. return Error(ephMain.msg);
  380. }
  381. var ephAdja = await HttpHelper.PostRequestAsync<SatEphResDto>(SysConfig.GetUrl("Xl/Calc"), new SatDto { SatCode = dto.Adja1Code, SigTime = dto.SigTime });
  382. if (ephAdja.code != 200)
  383. {
  384. logger.Error(ephAdja.msg);
  385. return Error(ephAdja.msg);
  386. }
  387. //#warning 测试代码
  388. //var tarEcef = PhysicsHelper.GeoToEcef((46, 21, 0));
  389. //var ecefXl1 = (ephMain.data.X, ephMain.data.Y, ephMain.data.Z);
  390. //var ecefXl2 = (ephAdja.data.X, ephAdja.data.Y, ephAdja.data.Z);
  391. //var ecefCdb = PhysicsHelper.GeoToEcef((dto.CdbTxLon, dto.CdbTxLat, 0));
  392. //var ecefRec = PhysicsHelper.GeoToEcef((dto.SatTxLon, dto.SatTxLat, 0));
  393. //var dt1 = PhysicsHelper.Dto(tarEcef, ecefXl1, ecefRec);
  394. //var dt2 = PhysicsHelper.Dto(tarEcef, ecefXl2, ecefRec);
  395. //var dt3 = PhysicsHelper.Dto(tarEcef, ecefCdb);
  396. //var dto1 = dt1 - dt2;
  397. //var dto2 = dt1 - dt3;
  398. //dto.SxDto = dto1 * 1e6 + r.Next(-10, 10) + Math.Round(r.NextDouble(), 3);
  399. //dto.XdDto = dto2 * 1e6 + r.Next(-10, 10) + Math.Round(r.NextDouble(), 3);
  400. //采集结果
  401. List<AdResDto> adres = new List<AdResDto>() {
  402. dto.AdRes.First(p => p.SatCode == dto.MainCode),//主星采集结果
  403. dto.AdRes.First(p => p.SatCode == dto.Adja1Code),//邻1星采集结果
  404. dto.AdRes.First(p => p.SatCode == dto.Adja2Code) };//超短站某个方向采集结果
  405. var repsAdRes = unitOfWork.OfLong<AdRes>();
  406. List<long> adIds = new List<long>();
  407. foreach (var adRes in adres)
  408. {
  409. var adItem = await repsAdRes.AddOrUpdateAsync(new AdRes
  410. {
  411. SatCode = dto.MainCode,
  412. RealFileCreateTime = adRes.RealFileCreateTime,
  413. FileTime = adRes.FileTime,
  414. RealFileUpdateTime = adRes.RealFileUpdateTime,
  415. Ch = adRes.Ch,
  416. FileSeconds = adRes.FileSeconds,
  417. FreqCenter = adRes.FreqCenter,
  418. FreqdownHz = adRes.FreqdownHz,
  419. FrequpHz = adRes.FrequpHz,
  420. FsHz = adRes.FsHz,
  421. HttpFile = adRes.HttpFile,
  422. SigTime = dto.SigTime,
  423. RecTxInfoID = adRes.RecTxInfoID,
  424. RecStationName = adRes.RecStationName,
  425. FileSize = adRes.FileSize,
  426. RealFileSize = adRes.RealFileSize,
  427. FileErrorMsg = adRes.FileErrorMsg,
  428. });
  429. adIds.Add(adItem.Id);
  430. }
  431. //站点信息
  432. var repsStationRes = unitOfWork.OfLong<StationRes>();
  433. var stationRes = await repsStationRes.AddOrUpdateAsync(new StationRes
  434. {
  435. SatTxLon = dto.SatTxLon,
  436. SatTxLat = dto.SatTxLat,
  437. CdbTxLon = dto.CdbTxLon,
  438. CdbTxLat = dto.CdbTxLat,
  439. });
  440. //检测结果
  441. var repsCheckRes = unitOfWork.OfLong<CheckRes>();
  442. var ckRes = await repsCheckRes.AddOrUpdateAsync(new CheckRes
  443. {
  444. HttpFile = dto.CheckRes.FileName,
  445. SmpStart = dto.CheckRes.SmpStart,
  446. SmpCount = dto.CheckRes.SmpCount,
  447. PosCheckType = (EnumPosCheckType?)dto.CheckRes?.PosCheckType,
  448. ModRate = dto.CheckRes.ModRate,
  449. ModType = dto.CheckRes.ModType,
  450. UserName = dto.CheckRes.UserName,
  451. FfcHz = dto.CheckRes.FfcHz,
  452. Snr = dto.CheckRes.Snr
  453. });
  454. //参估结果
  455. var repsCgRes = unitOfWork.OfLong<CgRes>();
  456. var cgRes = await repsCgRes.AddOrUpdateAsync(new CgRes
  457. {
  458. SigTime = dto.SigTime,
  459. FrequpHz = dto.FrequpHz,
  460. FreqdownHz = dto.FreqdownHz,
  461. Dto1 = Math.Round(dto.SxDto, 10),
  462. Dfo1 = Math.Round(dto.SxDfo, 10),
  463. Snr1 = Math.Round(dto.SxSnr, 1),
  464. Dto2 = Math.Round(dto.XdDto, 10),
  465. Dfo2 = Math.Round(dto.XdDfo, 10),
  466. Snr2 = Math.Round(dto.XdSnr, 1),
  467. StationResID = stationRes.Id,
  468. MainCode = dto.MainCode,
  469. Adja1Code = dto.Adja1Code,
  470. Adja2Code = dto.Adja2Code,
  471. MainXlTime = ephMain.data.TleTime,
  472. Adja1XlTime = ephAdja.data.TleTime,
  473. TaskID = runTask.Id,
  474. MainX = ephMain.data.X,
  475. MainY = ephMain.data.Y,
  476. MainZ = ephMain.data.Z,
  477. Adja1X = ephAdja.data.X,
  478. Adja1Y = ephAdja.data.Y,
  479. Adja1Z = ephAdja.data.Z,
  480. CheckResID = ckRes.Id,
  481. SigInfoID = dto.SigInfoID,
  482. AdResId1 = adIds[0],
  483. AdResId2 = adIds[1],
  484. AdResId3 = adIds[2],
  485. });
  486. //定位结果
  487. var res = PosApi.X2D1_PosNoRef_ZL(cgRes, stationRes, dto.CalcConfidence);
  488. var repsPosRes = unitOfWork.OfLong<PosRes>();
  489. var posRes = await repsPosRes.AddOrUpdateAsync(new PosRes
  490. {
  491. FrequpHz = cgRes.FrequpHz,
  492. FreqdownHz = cgRes.FreqdownHz,
  493. SigTime = dto.SigTime,
  494. TaskID = runTask.Id,
  495. CgResID = cgRes.Id,
  496. CheckResID = ckRes.Id,
  497. PosLon = res[0],
  498. PosLat = res[1],
  499. MirrLon = res[3],
  500. MirrLat = res[4],
  501. Confidence = (int)res[6],
  502. PosResType = EnumPosResType.X2D1NoRef,
  503. TargetInfoID = target?.Id,
  504. SigInfoID = dto.SigInfoID,
  505. StationResID = stationRes.Id,
  506. });
  507. await unitOfWork.SaveAsync();
  508. //await unitOfWork.DisposeAsync();//依赖注入的对象在容器销毁时自动释放
  509. Messenger.Defalut.Pub("新增定位点", MapModel(posRes));
  510. return Success();
  511. }
  512. #endregion
  513. private object MapModel(PosRes res)
  514. {
  515. return res;
  516. //return new ModelPosRes()
  517. //{
  518. // ID = res.ID,
  519. // FreqUpHz = res.FreqUpHz,
  520. // SigTime = res.SigTime,
  521. // TaskInfoID = res.TaskInfoID,
  522. // PosLon = res.PosLon,
  523. // PosLat = res.PosLat,
  524. // MirrLon = res.MirrLon,
  525. // MirrLat = res.MirrLat,
  526. // TargetState = res.TargetState,
  527. // PosResType = res.PosResType,
  528. // CgResID = res.CgResID,
  529. // CheckRes = res.CheckRes,
  530. // CheckResID = res.CheckResID,
  531. // ColorKey = res.ColorKey,
  532. // CreateTime = res.CreateTime,
  533. // CxResID = res.CxResID,
  534. // StationResID = res.StationResID,
  535. // TargetInfo = res.TargetInfo,
  536. // TargetInfoID = res.TargetInfoID,
  537. // UpdateTime = res.UpdateTime,
  538. // Confidence = res.Confidence,
  539. //};
  540. }
  541. }
  542. }