EntityBase.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. using Newtonsoft.Json;
  2. using Newtonsoft.Json.Linq;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.ComponentModel.DataAnnotations;
  7. using System.Data.Linq.Mapping;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Reflection;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Forms;
  14. namespace PTMedicalInsurance.Entity
  15. {
  16. /// <summary>
  17. /// 后面出入参基本集成该类,将一些通用方法封装于该类
  18. /// 基线版的出入参需要包含Column属性,数据库字段名成,数据库字段类型(可以为入参给定类型)等
  19. /// 需要包含StringLength 属性,标明在表格中显示的宽度,实际显示宽度值 = 长度 * 字体大概像素宽度,其中各种字体的不同SIZE对应的像素宽度是不同的,具体每个字符的像素宽度也是不同的,因此只能估计
  20. /// 包含DisplayName属性,在表中的标题显示
  21. /// 以上属性均进行为空判断
  22. /// </summary>
  23. public class EntityBase
  24. {
  25. /// <summary>
  26. /// 动态增加datagridview列
  27. /// </summary>
  28. /// <param name="dgv"></param>
  29. /// <param name="headerText"></param>
  30. /// <param name="dataPropertyName"></param>
  31. protected void AddDGVColumn(DataGridView dgv, string headerText, string dataPropertyName, int width = 120,bool isAdapter = false)
  32. {
  33. DataGridViewColumn newColumn = new DataGridViewTextBoxColumn();
  34. newColumn.HeaderText = headerText;
  35. newColumn.Width = width;
  36. newColumn.DataPropertyName = dataPropertyName;
  37. newColumn.Name = dataPropertyName;
  38. if (isAdapter) newColumn.AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
  39. dgv.Columns.Add(newColumn);
  40. }
  41. public void SetHeaderText(DataGridView dgv,Font font)
  42. {
  43. Type type = this.GetType();
  44. var properties = type.GetProperties();
  45. dgv.AutoGenerateColumns = false;
  46. dgv.Columns.Clear();
  47. dgv.Font = font;
  48. foreach (var property in properties)
  49. {
  50. //获取显示名称
  51. var display = property.GetCustomAttribute<DisplayNameAttribute>();
  52. if (display == null) continue;
  53. string dispalyName = display.DisplayName;
  54. int disLen = CalculateVarCharLength(dispalyName);
  55. var strLength = property.GetCustomAttribute<StringLengthAttribute>();
  56. if (strLength == null) continue;
  57. int len = strLength.MaximumLength;
  58. int width = len>disLen ? (int)(len*6.5f) : (int)(disLen * 6.5f);
  59. bool isAdapter = width > 200;
  60. AddDGVColumn(dgv, dispalyName, property.Name, width,isAdapter);
  61. }
  62. dgv.CellValueChanged += DataGridView_CellValueChanged;
  63. }
  64. /// <summary>
  65. /// 计算字符串在 VarChar 类型中的长度(以字节为单位)
  66. /// </summary>
  67. /// <param name="input">要计算长度的字符串</param>
  68. /// <returns>字符串在 VarChar 类型中的长度</returns>
  69. public static int CalculateVarCharLength(string input)
  70. {
  71. // 使用 UTF-16 编码计算字符串的字节数
  72. Encoding utf16Encoding = Encoding.UTF8;
  73. byte[] bytes = utf16Encoding.GetBytes(input);
  74. return bytes.Length;
  75. }
  76. /// <summary>
  77. /// 将实体类转换为数据库入参(Json)
  78. /// </summary>
  79. public JObject ConvertToDBJson()
  80. {
  81. Type type = this.GetType();
  82. var properties = type.GetProperties();
  83. JObject joRtn = new JObject();
  84. foreach (var property in properties)
  85. {
  86. var attribute = property.GetCustomAttribute<ColumnAttribute>();
  87. if (attribute == null) continue;
  88. string fieldName = attribute.Name;
  89. // 使用 BindingFlags 来允许访问非公共属性
  90. object value = property.GetValue(this, null);
  91. // 保持原始数据类型
  92. JToken token = value == null ? JValue.CreateNull() : JToken.FromObject(value);
  93. joRtn.Add(fieldName, token);
  94. }
  95. return joRtn;
  96. }
  97. public JObject ToJson()
  98. {
  99. string jsonString = JsonConvert.SerializeObject(this);
  100. return JObject.Parse(jsonString);
  101. }
  102. private static void DataGridView_CellValueChanged(object sender, DataGridViewCellEventArgs e)
  103. {
  104. // 只有在最后一列编辑完成时才会触发此事件
  105. if (e.RowIndex == -1 && e.ColumnIndex == -1)
  106. {
  107. AdjustColumnWidths((DataGridView)sender);
  108. }
  109. }
  110. private static void AdjustColumnWidths(DataGridView dataGridView)
  111. {
  112. for (int i = 0; i < dataGridView.Columns.Count; i++)
  113. {
  114. DataGridViewColumn column = dataGridView.Columns[i];
  115. // 获取列标题的宽度
  116. float titleSize = CalculateVarCharLength(column.HeaderText);
  117. float maxWidth = titleSize;
  118. // 遍历每一行
  119. foreach (DataGridViewRow row in dataGridView.Rows)
  120. {
  121. if (!row.IsNewRow && !string.IsNullOrEmpty(row.Cells[i].Value?.ToString()))
  122. {
  123. float cellSize = CalculateVarCharLength(row.Cells[i].Value.ToString());
  124. maxWidth = Math.Max(maxWidth, cellSize);
  125. }
  126. }
  127. // 设置列宽
  128. column.Width = (int)Math.Ceiling(maxWidth) + 5; // 加上一点额外空间
  129. }
  130. }
  131. }
  132. }