ResultController.cs 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.Entity;
  4. using System.Linq;
  5. using System.Net.Http;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Web.Http;
  9. using XdCxRhDW.Dto;
  10. using XdCxRhDW.Repostory;
  11. using System.IO;
  12. using XdCxRhDW.Entity;
  13. using XdCxRhDW.Api;
  14. using XdCxRhDW.WebApi;
  15. using DPP_YH_Core.Extensions;
  16. using XdCxRhDW.App.Model;
  17. using System.Diagnostics;
  18. using System.Configuration;
  19. namespace XdCxRhDW.App.Controllers
  20. {
  21. /// <summary>
  22. /// 结果查询相关接口
  23. /// </summary>
  24. public class ResultController : BaseController
  25. {
  26. /// <summary>
  27. /// 根据时间范围查询参估结果
  28. /// </summary>
  29. /// <param name="dto"><see cref="CgResQueryDto"/>查询参数</param>
  30. /// <returns></returns>
  31. /// <exception cref="Exception"></exception>
  32. [HttpPost]
  33. public async Task<AjaxResult<List<CgResDto>>> GetCgResByTimeRange(CgResQueryDto dto)
  34. {
  35. List<CgResDto> cgList = new List<CgResDto>();
  36. try
  37. {
  38. DateTime start = dto.BeginTime;
  39. DateTime end = dto.EndTime;
  40. var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
  41. if (!Directory.Exists(dir)) return Success(cgList);
  42. List<string> list = new List<string>();
  43. DateTime tempStart = new DateTime(start.Year, start.Month, start.Day);
  44. while (end >= tempStart)
  45. {
  46. list.Add(end.ToString("yyyy") + "\\" + end.ToString("MMdd") + ".db");
  47. end = end.AddDays(-1);
  48. }
  49. end = dto.EndTime;
  50. foreach (var item in list)
  51. {
  52. var dayFile = Path.Combine(dir, item);
  53. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  54. {
  55. if (db == null) continue;
  56. var query = db.PosRes.Where(p => p.SigTime >= start && p.SigTime <= end && p.TaskInfoID == dto.TaskInfoID);
  57. if (!dto.IncludeInvalidate)
  58. query = query.Where(p => p.PosLon != 999);
  59. if (dto.TarFrequpHz != null && dto.TarFrequpHz > 0)
  60. query = query.Where(p => p.FreqUpHz == dto.TarFrequpHz.Value);
  61. var cgRes = await query.Include(p => p.CgRes).Select(t => t.CgRes).Include(t => t.StationRes).OrderByDescending(p => p.SigTime).ToListAsync();
  62. var listDto = MapCgDto(cgRes);
  63. cgList.AddRange(listDto);
  64. }
  65. }
  66. return Success(cgList);
  67. }
  68. catch (TaskCanceledException)
  69. {
  70. string msg = $"参估结果时间范围查询超时.任务ID={dto.TaskInfoID},{dto.BeginTime:yyyyMMddHHmmss}-{dto.EndTime:yyyyMMddHHmmss}";
  71. XdCxRhDW.Framework.LogHelper.Error(msg);
  72. return Error<List<CgResDto>>("参估结果时间范围查询超时");
  73. }
  74. catch (Exception ex)
  75. {
  76. string msg = $"参估结果时间范围查询异常.任务ID={dto.TaskInfoID},{dto.BeginTime:yyyyMMddHHmmss}-{dto.EndTime:yyyyMMddHHmmss}";
  77. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  78. return Error<List<CgResDto>>("参估结果时间范围查询异常");
  79. }
  80. }
  81. /// <summary>
  82. /// 获取指定任务的所有上行频点
  83. /// </summary>
  84. /// <param name="dto">任务频点查询模型</param>
  85. /// <returns>任务所有频点信息</returns>
  86. /// <exception cref="Exception"></exception>
  87. [HttpPost]
  88. public async Task<AjaxResult<List<TaskFreqResDto>>> GetTaskFreqs(TaskFreqQueryDto dto)
  89. {
  90. var posList = new List<long>();
  91. try
  92. {
  93. var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
  94. if (!Directory.Exists(dir)) return Success(new List<TaskFreqResDto>());
  95. var yearDirs = Directory.EnumerateDirectories(dir).OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name));//年目录,倒叙排列
  96. DateTime max = DateTime.MinValue;
  97. foreach (var yearDir in yearDirs)
  98. {
  99. if (max != DateTime.MinValue) break;
  100. //每一天的db文件,倒序排列
  101. var dayFiles = Directory.EnumerateFiles(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, yearDir), "*.db").OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name.Substring(0, 4)));
  102. foreach (var dayFile in dayFiles)
  103. {
  104. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  105. {
  106. if (db == null) continue;
  107. var listFrequp = await db.PosRes.Where(p => p.TaskInfoID == dto.TaskInfoID).Select(p => p.FreqUpHz).Distinct().ToListAsync();
  108. foreach (var item in listFrequp)
  109. {
  110. if (!posList.Contains(item))
  111. posList.Add(item);
  112. }
  113. }
  114. }
  115. }
  116. var res = posList.Select(p => new TaskFreqResDto() { FreqUpHz = p }).OrderBy(o => o.FreqUpHz).ToList();
  117. return Success(res);
  118. }
  119. catch (Exception ex)
  120. {
  121. string msg = $"定位结果查询异常-任务编号:{dto.TaskInfoID}";
  122. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  123. return Error<List<TaskFreqResDto>>("定位结果查询异常");
  124. }
  125. }
  126. /// <summary>
  127. /// 获取所有执行中的任务
  128. /// </summary>
  129. [HttpPost]
  130. public async Task<AjaxResult<List<TaskQueryResDto>>> GetRunningTasks()
  131. {
  132. try
  133. {
  134. using (RHDWContext db = new RHDWContext())
  135. {
  136. var tasks = await db.TaskInfos.Where(p => p.TaskState == EnumTaskState.Running).ToListAsync();
  137. var res = tasks.Select(t => new TaskQueryResDto()
  138. {
  139. TaskID = t.ID,
  140. PosType = (EnumPosTypeDto)(int)t.PosType,
  141. TaskType = (EnumTaskTypeDto)(int)t.TaskType,
  142. });
  143. return Success(res.ToList());
  144. }
  145. }
  146. catch (Exception ex)
  147. {
  148. string msg = $"查询执行中的任务异常";
  149. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  150. return Error<List<TaskQueryResDto>>("查询执行中的任务异常");
  151. }
  152. }
  153. #region 定位结果查询接口
  154. /// <summary>
  155. /// 根据时间范围查询定位结果
  156. /// </summary>
  157. /// <param name="dto"><see cref="PosRequestByTimeRangeDto"/>查询参数</param>
  158. /// <returns></returns>
  159. /// <exception cref="Exception"></exception>
  160. [HttpPost]
  161. public async Task<AjaxResult<List<PosResDto>>> GetPosResByTimeRange(PosRequestByTimeRangeDto dto)
  162. {
  163. var response = (await GetPosResByTimeRangeObsolete(dto));
  164. if (response.code == 200)
  165. {
  166. var listDto = response.data?.Select(p => MapDto(p)).ToList();
  167. return Success(listDto);
  168. }
  169. else
  170. {
  171. return Error<List<PosResDto>>(response.msg);
  172. }
  173. }
  174. /// <summary>
  175. /// 查询最后X小时的的定位结果
  176. /// </summary>
  177. /// <param name="dto"><see cref="PosRequestByLastRangeDto"/>查询参数</param>
  178. /// <returns></returns>
  179. /// <exception cref="Exception"></exception>
  180. [HttpPost]
  181. public async Task<AjaxResult<List<PosResDto>>> GetPosResByLastHours(PosRequestByLastRangeDto dto)
  182. {
  183. var response = (await GetPosResByLastHoursObsolete(dto));
  184. if (response.code == 200)
  185. {
  186. var listDto = response.data?.Select(p => MapDto(p)).ToList();
  187. return Success(listDto);
  188. }
  189. else
  190. {
  191. return Error<List<PosResDto>>(response.msg);
  192. }
  193. }
  194. /// <summary>
  195. /// 根据时间范围查询定位结果(此方法内部调用)
  196. /// </summary>
  197. /// <param name="dto"><see cref="PosRequestByTimeRangeDto"/>查询参数</param>
  198. /// <returns></returns>
  199. /// <exception cref="Exception"></exception>
  200. [HttpPost]
  201. [Obsolete]
  202. public async Task<AjaxResult<List<PosRes>>> GetPosResByTimeRangeObsolete(PosRequestByTimeRangeDto dto)
  203. {
  204. List<PosRes> posList = new List<PosRes>();
  205. try
  206. {
  207. DateTime start = dto.BeginTime;
  208. DateTime end = dto.EndTime;
  209. var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
  210. if (!Directory.Exists(dir)) return Success(posList);
  211. List<string> list = new List<string>();
  212. DateTime tempStart = new DateTime(start.Year, start.Month, start.Day);
  213. while (end >= tempStart)
  214. {
  215. list.Add(end.ToString("yyyy") + "\\" + end.ToString("MMdd") + ".db");
  216. end = end.AddDays(-1);
  217. }
  218. end = dto.EndTime;
  219. List<TargetInfo> targets;
  220. using (RHDWContext dbBasic = new RHDWContext())
  221. {
  222. targets = await dbBasic.TargetInfos.ToListAsync();
  223. }
  224. foreach (var item in list)
  225. {
  226. var dayFile = Path.Combine(dir, item);
  227. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  228. {
  229. for (int i = 0; i < 2; i++)
  230. {
  231. try
  232. {
  233. if (db == null) continue;
  234. var query = db.PosRes.Where(p => p.SigTime >= start && p.SigTime <= end && p.TaskInfoID == dto.TaskInfoID);
  235. if (!dto.IncludeInvalidate)
  236. query = query.Where(p => p.PosLon != 999);
  237. if (dto.TarFrequpHz != null && dto.TarFrequpHz > 0)
  238. query = query.Where(p => p.FreqUpHz == dto.TarFrequpHz.Value);
  239. var posRes = await query.Include(p => p.CheckRes).OrderByDescending(p => p.SigTime).ToListAsync();
  240. foreach (var itemPos in posRes)
  241. {
  242. if (itemPos.TargetInfoID > 0)
  243. {
  244. itemPos.TargetInfo = targets.FirstOrDefault(p => p.ID == itemPos.TargetInfoID);
  245. if (itemPos.TargetInfo != null && !string.IsNullOrWhiteSpace(itemPos.TargetInfo.TargeColor))
  246. itemPos.ColorKey = itemPos.TargetInfo.TargeColor;
  247. }
  248. }
  249. posList.AddRange(posRes);
  250. break;
  251. }
  252. catch (Exception ex)
  253. {
  254. LogHelper.Error($"同步分区表结构异常,DayFile={dayFile}", ex).Wait(5000);
  255. db.SyncDb();
  256. }
  257. }
  258. }
  259. }
  260. return Success(posList);
  261. }
  262. catch (Exception ex)
  263. {
  264. string msg = $"定位结果时间范围查询异常.任务ID={dto.TaskInfoID},{dto.BeginTime:yyyyMMddHHmmss}-{dto.EndTime:yyyyMMddHHmmss}";
  265. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  266. return Error<List<PosRes>>("定位结果时间范围查询异常");
  267. }
  268. }
  269. /// <summary>
  270. /// 根据时间范围查询定位结果(此方法内部调用)
  271. /// </summary>
  272. /// <param name="dto"><see cref="PosRequestByTimeRangeDto"/>查询参数</param>
  273. /// <returns></returns>
  274. /// <exception cref="Exception"></exception>
  275. [HttpPost]
  276. [Obsolete]
  277. public async Task<AjaxResult<List<RePosRes>>> GetPosCgResByTimeRangeObsolete(PosRequestByTimeRangeDto dto)
  278. {
  279. List<RePosRes> posList = new List<RePosRes>();
  280. try
  281. {
  282. DateTime start = dto.BeginTime;
  283. DateTime end = dto.EndTime;
  284. var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
  285. if (!Directory.Exists(dir)) return Success(posList);
  286. List<string> list = new List<string>();
  287. DateTime tempStart = new DateTime(start.Year, start.Month, start.Day);
  288. while (end >= tempStart)
  289. {
  290. list.Add(end.ToString("yyyy") + "\\" + end.ToString("MMdd") + ".db");
  291. end = end.AddDays(-1);
  292. }
  293. end = dto.EndTime;
  294. List<TargetInfo> targets;
  295. using (RHDWContext dbBasic = new RHDWContext())
  296. {
  297. targets = await dbBasic.TargetInfos.ToListAsync();
  298. }
  299. foreach (var item in list)
  300. {
  301. var dayFile = Path.Combine(dir, item);
  302. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  303. {
  304. if (db == null) continue;
  305. var query = db.PosRes.Where(p => p.SigTime >= start && p.SigTime <= end && p.TaskInfoID == dto.TaskInfoID);
  306. if (!dto.IncludeInvalidate)
  307. query = query.Where(p => p.PosLon != 999);
  308. if (dto.TarFrequpHz != null && dto.TarFrequpHz > 0)
  309. query = query.Where(p => p.FreqUpHz == dto.TarFrequpHz.Value);
  310. var posRes = await query.OrderByDescending(p => p.SigTime).ToListAsync();
  311. foreach (var itemPos in posRes)
  312. {
  313. var repos = new RePosRes();
  314. repos.ID = itemPos.ID;
  315. repos.SigTime = itemPos.SigTime;
  316. repos.PosLon = itemPos.PosLon;
  317. repos.PosLat = itemPos.PosLat;
  318. repos.MirrLon = itemPos.MirrLon;
  319. repos.MirrLat = itemPos.MirrLat;
  320. repos.TaskInfoID = itemPos.TaskInfoID;
  321. repos.FreqUpHz = itemPos.FreqUpHz;
  322. repos.StationResID = itemPos.StationResID;
  323. repos.CxResID = itemPos.CxResID;
  324. repos.CgResID = itemPos.CgResID;
  325. repos.CheckResID = itemPos.CheckResID;
  326. repos.PosResType = itemPos.PosResType;
  327. repos.TargetState = itemPos.TargetState;
  328. repos.TargetInfo = targets?.FirstOrDefault(p => p.ID == itemPos.TargetInfoID);
  329. if (itemPos.TargetInfo != null && !string.IsNullOrWhiteSpace(itemPos.TargetInfo.TargeColor))
  330. {
  331. repos.ColorKey = itemPos.TargetInfo.TargeColor;
  332. }
  333. repos.BaseTargetName = itemPos.TargetInfo?.TargetName;
  334. repos.CheckRes = await db.CheckRes.FirstOrDefaultAsync(p => p.ID == itemPos.CheckResID);
  335. repos.BaseCheckType = itemPos.CheckRes?.PosCheckType?.GetEnumDisplayName();
  336. repos.CgRes = await db.CgRes.FirstOrDefaultAsync(p => p.ID == itemPos.CgResID);
  337. repos.CxRes = await db.CxRes.FirstOrDefaultAsync(p => p.ID == itemPos.CxResID);
  338. repos.StationRes = await db.StationRes.FirstOrDefaultAsync(p => p.ID == itemPos.StationResID);
  339. posList.Add(repos);
  340. }
  341. }
  342. }
  343. return Success(posList);
  344. }
  345. catch (Exception ex)
  346. {
  347. string msg = $"定位结果时间范围查询异常.任务ID={dto.TaskInfoID},{dto.BeginTime:yyyyMMddHHmmss}-{dto.EndTime:yyyyMMddHHmmss}";
  348. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  349. return Error<List<RePosRes>>("定位结果时间范围查询异常");
  350. }
  351. }
  352. /// <summary>
  353. /// 查询最后X小时的的定位结果(此方法内部调用)
  354. /// </summary>
  355. /// <param name="dto"><see cref="PosRequestByLastRangeDto"/>查询参数</param>
  356. /// <returns></returns>
  357. /// <exception cref="Exception"></exception>
  358. [HttpPost]
  359. [Obsolete]
  360. public async Task<AjaxResult<List<PosRes>>> GetPosResByLastHoursObsolete(PosRequestByLastRangeDto dto)
  361. {
  362. List<PosRes> posList = new List<PosRes>();
  363. try
  364. {
  365. var dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "DbPart");
  366. if (!Directory.Exists(dir)) return Success(posList);
  367. var yearDirs = Directory.EnumerateDirectories(dir).OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name));//年目录,倒叙排列
  368. DateTime max = DateTime.MinValue;
  369. foreach (var yearDir in yearDirs)
  370. {
  371. if (max != DateTime.MinValue) break;
  372. //每一天的db文件,倒序排列
  373. var dayFiles = Directory.EnumerateFiles(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, yearDir), "*.db").OrderByDescending(p => Convert.ToInt32(new DirectoryInfo(p).Name.Substring(0, 4)));
  374. foreach (var dayFile in dayFiles)
  375. {
  376. using (RHDWPartContext db = RHDWPartContext.GetContext(dayFile))
  377. {
  378. if (db == null) continue;
  379. var query = db.PosRes.Where(p => p.TaskInfoID == dto.TaskInfoID);
  380. if (!dto.IncludeInvalidate)
  381. {
  382. query = query.Where(p => p.PosLon != 999);
  383. }
  384. if (dto.TarFrequpHz != null && dto.TarFrequpHz > 0)
  385. {
  386. query = query.Where(p => p.FreqUpHz == dto.TarFrequpHz);
  387. }
  388. bool any = await query.AnyAsync();
  389. if (any)
  390. max = await query.MaxAsync(p => p.SigTime);
  391. }
  392. if (max != DateTime.MinValue)
  393. {
  394. break;
  395. }
  396. }
  397. }
  398. if (max == DateTime.MinValue) return Success(posList);
  399. DateTime min = max.AddHours(-dto.Hours);
  400. var res = await GetPosResByTimeRangeObsolete(new PosRequestByTimeRangeDto()
  401. {
  402. TaskInfoID = dto.TaskInfoID,
  403. BeginTime = min,
  404. EndTime = max,
  405. IncludeInvalidate = dto.IncludeInvalidate,
  406. TarFrequpHz = dto.TarFrequpHz,
  407. });
  408. return res;
  409. }
  410. catch (Exception ex)
  411. {
  412. string msg = $"定位结果查询最新数据异常-任务编号:{dto.TaskInfoID},Hours:{dto.Hours}";
  413. XdCxRhDW.Framework.LogHelper.Error(msg, ex);
  414. return Error<List<PosRes>>("定位结果查询最新数据异常");
  415. }
  416. }
  417. #endregion
  418. private PosResDto MapDto(PosRes res)
  419. {
  420. return new PosResDto()
  421. {
  422. ID = res.ID,
  423. FreqUpHz = res.FreqUpHz,
  424. SigTime = res.SigTime,
  425. TaskInfoID = res.TaskInfoID,
  426. TarName = res.TargetInfo?.TargetName,
  427. PosLon = res.PosLon,
  428. PosLat = res.PosLat,
  429. MirrLon = res.MirrLon,
  430. MirrLat = res.MirrLat,
  431. CheckType = res.CheckRes?.PosCheckType == null ? "" : res.CheckRes?.PosCheckType?.GetEnumDisplayName(),
  432. TargetState = (EnumTargetStateDto)res.TargetState,
  433. PosResType = (EnumPosResTypeDto)res.PosResType,
  434. Confidence = res.Confidence,
  435. CreateTime = res.CreateTime,
  436. };
  437. }
  438. private List<CgResDto> MapCgDto(List<CgRes> listCg)
  439. {
  440. List<CgResDto> list = new List<CgResDto>();
  441. foreach (CgRes cgRes in listCg)
  442. {
  443. var dto = new CgResDto()
  444. {
  445. ID = cgRes.ID,
  446. TaskID = cgRes.TaskID,
  447. FreqUpHz = cgRes.TarFreqUp == null ? 0 : (long)(cgRes.TarFreqUp.Value),
  448. SigTime = cgRes.SigTime,
  449. Dto1 = cgRes.Dto1,
  450. Dfo1 = cgRes.Dfo1,
  451. Snr1 = cgRes.Snr1,
  452. Dto2 = cgRes.Dto2,
  453. Dfo2 = cgRes.Dfo2,
  454. Snr2 = cgRes.Snr2,
  455. DtoCdb = cgRes.DtoCdb,
  456. DfoCdb = cgRes.DfoCdb,
  457. SnrCdb = cgRes.SnrCdb,
  458. YbMainDto = cgRes.YbMainDto,
  459. YbMainDfo = cgRes.YbMainDfo,
  460. YbMainSnr = cgRes.YbMainSnr,
  461. YbAdja1Dto = cgRes.YbAdja1Dto,
  462. YbAdja1Dfo = cgRes.YbAdja1Dfo,
  463. YbAdja1Snr = cgRes.YbAdja1Snr,
  464. YbAdja2Dfo = cgRes.YbAdja2Dfo,
  465. YbAdja2Dto = cgRes.YbAdja2Dto,
  466. YbAdja2Snr = cgRes.YbAdja2Snr,
  467. TarFreqUp = cgRes.TarFreqUp,
  468. TarFreqDown = cgRes.TarFreqDown,
  469. RefFreqUp = cgRes.RefFreqUp,
  470. RefFreqDown = cgRes.RefFreqDown,
  471. MainCode = cgRes.MainCode,
  472. Adja1Code = cgRes.Adja1Code,
  473. Adja2Code = cgRes.Adja2Code,
  474. MainXlTime = cgRes.MainXlTime,
  475. Adja1XlTime = cgRes.Adja1XlTime,
  476. Adja2XlTime = cgRes.Adja2XlTime,
  477. MainX = cgRes.MainX,
  478. MainY = cgRes.MainY,
  479. MainZ = cgRes.MainZ,
  480. MainVx = cgRes.MainVx,
  481. MainVy = cgRes.MainVy,
  482. MainVz = cgRes.MainVz,
  483. Adja1X = cgRes.Adja1X,
  484. Adja1Y = cgRes.Adja1Y,
  485. Adja1Z = cgRes.Adja1Z,
  486. Adja1Vx = cgRes.Adja1Vx,
  487. Adja1Vy = cgRes.Adja1Vy,
  488. Adja1Vz = cgRes.Adja1Vz,
  489. Adja2X = cgRes.Adja2X,
  490. Adja2Y = cgRes.Adja2Y,
  491. Adja2Z = cgRes.Adja2Z,
  492. Adja2Vx = cgRes.Adja2Vx,
  493. Adja2Vy = cgRes.Adja2Vy,
  494. Adja2Vz = cgRes.Adja2Vz,
  495. SatTxLon = cgRes.StationRes.SatTxLon,
  496. SatTxLat = cgRes.StationRes.SatTxLat,
  497. CdbTxLon = cgRes.StationRes.CdbTxLon,
  498. CdbTxLat = cgRes.StationRes.CdbTxLat,
  499. CxLon = cgRes.StationRes.CxLon,
  500. CxLat = cgRes.StationRes.CxLat,
  501. RefLon = cgRes.StationRes.RefLon,
  502. RefLat = cgRes.StationRes.RefLat,
  503. CreateTime = cgRes.CreateTime,
  504. };
  505. list.Add(dto);
  506. }
  507. return list;
  508. }
  509. }
  510. }