CtrlSat.cs 5.7 KB

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