ShowCgCtrl.cs 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. using DevExpress.XtraEditors;
  2. using ExtensionsDev;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.Data;
  7. using System.Data.Entity;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Windows.Forms;
  13. using XdCxRhDW.App.Model;
  14. using XdCxRhDW.Entity;
  15. using XdCxRhDW.Repostory;
  16. namespace XdCxRhDW.App.PopupControl
  17. {
  18. public partial class ShowCgCtrl : DevExpress.XtraEditors.XtraUserControl
  19. {
  20. PosRes posItem;
  21. List<ModelCg> listCg = new List<ModelCg>();
  22. List<ModelCgXgf> listXgf = new List<ModelCgXgf>();
  23. public ShowCgCtrl()
  24. {
  25. InitializeComponent();
  26. this.layoutControl1.UseDefault();
  27. gridShowCg.UseDefault(listCg);
  28. gridCgXgf.UseDefault(listXgf).UseRowNumber();
  29. }
  30. public ShowCgCtrl(PosRes posItem)
  31. : this()
  32. {
  33. this.posItem = posItem;
  34. }
  35. private async void ShowCgCtrl_Load(object sender, EventArgs e)
  36. {
  37. List<SatInfo> sats = null;
  38. using (MySqlContext db = new MySqlContext())
  39. {
  40. sats = await db.SatInfos.ToListAsync();
  41. }
  42. List<ModelCg> list = new List<ModelCg>();
  43. using (MySqlContext db=new MySqlContext())
  44. {
  45. if (db == null) return;
  46. var cgEntity = db.CgRes.Where(p => p.ID == posItem.CgResID).FirstOrDefault();
  47. if (cgEntity == null) return;
  48. //主邻1
  49. if (cgEntity.Adja1Code != null)
  50. {
  51. ModelCg item = new ModelCg()
  52. {
  53. ID = cgEntity.ID,
  54. CreateTime = cgEntity.CreateTime,
  55. UpdateTime = cgEntity.UpdateTime,
  56. SigTime = cgEntity.SigTime,
  57. Dto = cgEntity.Dto1,
  58. Dfo = cgEntity.Dfo1,
  59. Snr = cgEntity.Snr1,
  60. MainSat = cgEntity.MainCode?.ToString(),
  61. AdjaSat = cgEntity.Adja1Code.ToString(),
  62. CgType = 0,
  63. };
  64. var find = sats.Find(p => p.SatCode == cgEntity.MainCode.Value);
  65. if (find != null)
  66. item.MainSat = find.Sat;
  67. find = sats.Find(p => p.SatCode == cgEntity.Adja1Code.Value);
  68. if (find != null)
  69. item.AdjaSat = find.Sat;
  70. list.Add(item);
  71. }
  72. //主邻2
  73. if (cgEntity.Adja2Code != null)
  74. {
  75. ModelCg item = new ModelCg()
  76. {
  77. ID = cgEntity.ID,
  78. CreateTime = cgEntity.CreateTime,
  79. UpdateTime = cgEntity.UpdateTime,
  80. SigTime = cgEntity.SigTime,
  81. Dto = cgEntity.Dto2,
  82. Dfo = cgEntity.Dfo2,
  83. Snr = cgEntity.Snr2,
  84. MainSat = cgEntity.MainCode?.ToString(),
  85. AdjaSat = cgEntity.Adja2Code.ToString(),
  86. CgType = 1,
  87. };
  88. var find = sats.Find(p => p.SatCode == cgEntity.MainCode.Value);
  89. if (find != null)
  90. item.MainSat = find.Sat;
  91. find = sats.Find(p => p.SatCode == cgEntity.Adja2Code.Value);
  92. if (find != null)
  93. item.AdjaSat = find.Sat;
  94. list.Add(item);
  95. }
  96. //超短
  97. if (cgEntity.DtoCdb != null)
  98. {
  99. ModelCg item = new ModelCg()
  100. {
  101. ID = cgEntity.ID,
  102. CreateTime = cgEntity.CreateTime,
  103. UpdateTime = cgEntity.UpdateTime,
  104. SigTime = cgEntity.SigTime,
  105. Dto = cgEntity.DtoCdb,
  106. Dfo = cgEntity.DfoCdb,
  107. Snr = cgEntity.SnrCdb,
  108. MainSat = cgEntity.MainCode?.ToString(),
  109. AdjaSat = "超短站",
  110. CgType = 2,
  111. };
  112. var find = sats.Find(p => p.SatCode == cgEntity.MainCode.Value);
  113. if (find != null)
  114. item.MainSat = find.Sat;
  115. list.Add(item);
  116. }
  117. }
  118. this.listCg.Clear();
  119. this.listCg.AddRange(list);
  120. gridView1.RefreshData();
  121. }
  122. private async void gridView1_FocusedRowObjectChanged(object sender, DevExpress.XtraGrid.Views.Base.FocusedRowObjectChangedEventArgs e)
  123. {
  124. listXgf.Clear();
  125. var cgItem = e.Row as ModelCg;
  126. if (cgItem != null)
  127. {
  128. using (MySqlContext db=new MySqlContext())
  129. {
  130. if (db != null)
  131. {
  132. var data = await db.CgXgfRes.Where(p => p.Deleted == 0 && p.CgResID == cgItem.ID && p.CgType == cgItem.CgType).ToListAsync();
  133. listXgf.AddRange(data.Select(p => new ModelCgXgf
  134. {
  135. ID = p.ID,
  136. Dto = p.Dto,
  137. Dfo = p.Dfo,
  138. Snr = p.Snr,
  139. CreateTime = p.CreateTime,
  140. UpdateTime = p.UpdateTime,
  141. }));
  142. }
  143. }
  144. //查询相关峰结果
  145. }
  146. this.gridView2.RefreshData();
  147. }
  148. }
  149. }