CtrlSat.cs 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. using DevExpress.XtraEditors;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Data.Entity;
  7. using System.Drawing;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. using XdCxRhDW.App.EditForms;
  13. using XdCxRhDW.Entity;
  14. using XdCxRhDW.Repostory;
  15. namespace XdCxRhDW.App.UserControl
  16. {
  17. public partial class CtrlSat : DevExpress.XtraEditors.XtraUserControl
  18. {
  19. List<SatInfo> list = new List<SatInfo>();
  20. public CtrlSat()
  21. {
  22. InitializeComponent();
  23. }
  24. private async void CtrlSat_Load(object sender, EventArgs e)
  25. {
  26. try
  27. {
  28. gridSat.Init<SatInfo>().UseSort().UseFilter().UseMultiSelect().UseRowNumber();
  29. gridSat.DataSource = list;
  30. using (RHDWContext db = new RHDWContext())
  31. {
  32. var res = db.SatInfos.OrderBy(p => p.SatName).OrderBy(p => p.SatName);
  33. list.AddRange(await res.ToListAsync());
  34. }
  35. gridView1.RefreshData();
  36. }
  37. catch (Exception ex)
  38. {
  39. Serilog.Log.Error(ex, "查询卫星信息异常");
  40. DxHelper.MsgBoxHelper.ShowError("查询卫星信息异常");
  41. }
  42. }
  43. private void gridView1_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
  44. {
  45. if (gridView1.GetSelectedRows().Any())
  46. {
  47. btnDel.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  48. btnEdit.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
  49. }
  50. else
  51. {
  52. btnDel.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  53. btnEdit.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
  54. }
  55. popupMenu1.ShowPopup(MousePosition);
  56. }
  57. private async void btnAdd_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  58. {
  59. try
  60. {
  61. SatEditor frm = new SatEditor();
  62. if (frm.ShowDialog() != DialogResult.OK) return;
  63. var addItem = frm.info;
  64. using (RHDWContext db = new RHDWContext())
  65. {
  66. db.SatInfos.Add(addItem);
  67. await db.SaveChangesAsync();
  68. }
  69. list.Add(addItem);
  70. gridView1.RefreshData();
  71. }
  72. catch (Exception ex)
  73. {
  74. Serilog.Log.Error(ex, "添加卫星信息异常");
  75. DxHelper.MsgBoxHelper.ShowError("添加卫星信息异常");
  76. }
  77. }
  78. private async void btnEdit_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  79. {
  80. try
  81. {
  82. var editItem = gridView1.GetFocusedRow() as SatInfo;
  83. SatEditor frm = new SatEditor(editItem);
  84. if (frm.ShowDialog() != DialogResult.OK) return;
  85. editItem = frm.info;
  86. using (RHDWContext db = new RHDWContext())
  87. {
  88. var find = await db.SatInfos.Where(p => p.ID == editItem.ID).FirstOrDefaultAsync();
  89. find.SatName = editItem.SatName;
  90. find.SatCode = editItem.SatCode;
  91. find.SatLon = editItem.SatLon;
  92. await db.SaveChangesAsync();
  93. }
  94. gridView1.RefreshData();
  95. }
  96. catch (Exception ex)
  97. {
  98. Serilog.Log.Error(ex, "保存卫星信息异常");
  99. DxHelper.MsgBoxHelper.ShowError("保存卫星信息异常");
  100. }
  101. }
  102. private async void btnDel_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
  103. {
  104. try
  105. {
  106. if (XtraMessageBox.Show("确认删除选择的卫星信息?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
  107. {
  108. return;
  109. }
  110. var ids = gridView1.GetSelectedRows();
  111. using (RHDWContext db = new RHDWContext())
  112. {
  113. foreach (var id in ids)
  114. {
  115. var item = gridView1.GetRow(id) as SatInfo;
  116. var delItem = await db.SatInfos.Where(p => p.ID == item.ID).FirstOrDefaultAsync();
  117. if (delItem != null)
  118. db.SatInfos.Remove(delItem);
  119. }
  120. await db.SaveChangesAsync();
  121. }
  122. gridView1.DeleteSelectedRows();
  123. }
  124. catch (Exception ex)
  125. {
  126. Serilog.Log.Error(ex, "删除卫星信息异常");
  127. DxHelper.MsgBoxHelper.ShowError("删除卫星信息异常");
  128. }
  129. }
  130. private void gridView1_CustomDrawEmptyForeground(object sender, DevExpress.XtraGrid.Views.Base.CustomDrawEventArgs e)
  131. {
  132. if (gridView1.RowCount == 0)
  133. {
  134. string txt = "右键添加卫星";
  135. var s = e.Appearance.CalcTextSize(e.Cache, txt, e.Bounds.Width).ToSize();
  136. var x = (e.Bounds.Width - s.Width) / 2;
  137. var y = (e.Bounds.Height - s.Height) / 2;
  138. e.Appearance.ForeColor = Color.Gray;
  139. e.Appearance.DrawString(e.Cache, txt, new Rectangle(x, y, s.Width, s.Height));
  140. }
  141. }
  142. }
  143. }