EntityBase.cs 5.6 KB

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