DuanMianAnalystResult.cs 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Drawing.Drawing2D;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. namespace WWPipeLine.MapTools.Conditions.AnalystToolBar
  12. {
  13. public partial class DuanMianAnalystResult : Sunny.UI.UIForm
  14. {
  15. private DataTable m_dt;
  16. public DuanMianAnalystResult(DataTable dt)
  17. {
  18. InitializeComponent();
  19. //this.Size = new Size(820, 720);
  20. this.Style = Sunny.UI.UIStyle.Gray;
  21. this.StartPosition = FormStartPosition.Manual;
  22. this.Location = new System.Drawing.Point(10, 10);
  23. m_dt = dt;
  24. }
  25. private void AnalystResultForm_Load(object sender, EventArgs e)
  26. {
  27. DataColumn dataColumn;
  28. dataColumn = new DataColumn { ColumnName = "x", Caption = "X坐标" }; m_dt.Columns.Add(dataColumn);
  29. dataColumn = new DataColumn { ColumnName = "y", Caption = "Y坐标" }; m_dt.Columns.Add(dataColumn);
  30. int width = 800;// pictureBox.Width;
  31. int height = 600;// pictureBox.Height;
  32. Bitmap image = new Bitmap(width, height);
  33. //创建Graphics类对象
  34. Graphics g = Graphics.FromImage(image);
  35. g.SmoothingMode = SmoothingMode.AntiAlias;
  36. g.InterpolationMode = InterpolationMode.HighQualityBicubic;
  37. g.CompositingQuality = CompositingQuality.HighQuality;
  38. g.TextRenderingHint = System.Drawing.Text.TextRenderingHint.ClearTypeGridFit;
  39. g.Clear(Color.White);
  40. Pen PenXYLine = Pens.Blue;
  41. Brush defaultBrush = Brushes.Black;
  42. Font fontNormal = new Font("Arial", 9, FontStyle.Regular);
  43. Font fontTitle = new Font("Arial", 16, FontStyle.Bold);
  44. //顶部标题
  45. g.DrawString(uitxtTitle.Text, fontTitle, defaultBrush, new PointF(width / 3, 10));
  46. //画图片的边框线
  47. g.DrawRectangle(PenXYLine, 0, 50, width - 2, height - 52);
  48. //绘制 Y轴线,直接从顶到底
  49. g.DrawLine(PenXYLine, 100, 50, 100, height);
  50. int yHeight = 450;// height - 50 - TableLineHeight * 5;
  51. int gxgcFenDuanHeight = 75;// (int)450 / 6; //(int)((height - 55 - TableLineHeight * 6) / 6
  52. #region 计算 Y轴 最大值与最小值 Y轴设置横线5根,数据值5个,分为6段,7个节点
  53. DataView m_dt_dv = m_dt.DefaultView;
  54. m_dt_dv.Sort = "gxgc DESC";
  55. double gxgcMax = 0.0; double.TryParse(m_dt_dv[0]["gxgc"].ToString(), out gxgcMax); gxgcMax = Math.Round(gxgcMax, 2);
  56. double gxgcMin = 0.0; double.TryParse(m_dt_dv[m_dt_dv.Count - 1]["gxgc"].ToString(), out gxgcMin); gxgcMin = Math.Round(gxgcMin, 2);
  57. double gxgcChaZhi = Math.Round(gxgcMax - (gxgcMax + gxgcMin) / 2, 2);
  58. for (int i = 0; i <= 6; i++)//Y轴分为6段,除了顶部和底部,需要绘制5个 短横线和坐标值
  59. {
  60. if (i == 0 || i == 6) continue;
  61. g.DrawLine(PenXYLine, 95, 50 + i * gxgcFenDuanHeight, 100, 50 + i * gxgcFenDuanHeight);
  62. g.DrawString(GetGxgcY(i).ToString(), fontNormal, defaultBrush, 50, 50 + i * gxgcFenDuanHeight - 5);
  63. }
  64. double GetGxgcY(int i)
  65. {
  66. switch (i)
  67. {
  68. case 0: return gxgcMax + gxgcChaZhi * 2;
  69. case 1: return gxgcMax + gxgcChaZhi;
  70. case 2: return gxgcMax;
  71. case 3: return gxgcMax - gxgcChaZhi;
  72. case 4: return gxgcMin;
  73. case 5: return gxgcMin - gxgcChaZhi;
  74. case 6: return gxgcMin - gxgcChaZhi * 2;
  75. default: return 0.0;
  76. }
  77. }
  78. double UnitY = yHeight / ((gxgcMax - (gxgcMax + gxgcMin) / 2) * 6);
  79. #endregion
  80. #region X轴 计算UnitX 并配置断面的X坐标
  81. int xWidth = 700;
  82. double tbJuLiSum = 0.0D;
  83. foreach (DataRow dr in m_dt.Rows)
  84. {
  85. tbJuLiSum += double.Parse(string.IsNullOrEmpty(dr["jl"].ToString()) ? "0" : dr["jl"].ToString());
  86. }
  87. double UnitX = (xWidth - 150) / tbJuLiSum;
  88. double tbJuLiX = 150.0D;
  89. foreach (DataRow dr in m_dt.Rows)
  90. {
  91. tbJuLiX += UnitX * double.Parse(string.IsNullOrEmpty(dr["jl"].ToString()) ? "0" : dr["jl"].ToString());
  92. dr["x"] = tbJuLiX;
  93. }
  94. #endregion
  95. #region 绘制 底部的表格横线 表格数据展示
  96. int TableLineHeight = 20;
  97. string tbTitle = "";
  98. string tbZiDuan = "";
  99. for (int i = 1; i <= 5; i++)
  100. {
  101. g.DrawLine(PenXYLine, 0, height - i * TableLineHeight, width, height - i * TableLineHeight);
  102. GetTableColumsCaption(i);
  103. float StringY = height - i * TableLineHeight + 5;
  104. g.DrawString(tbTitle, fontNormal, defaultBrush, 20, StringY);
  105. for (int j = 0; j < m_dt.Rows.Count; j++)
  106. {
  107. //if (tbZiDuan == "jl")//距离直接显示,这个地方可以 设置 距离在2个断面的中间
  108. //{
  109. // g.DrawString(m_dt.Rows[j]["jl"].ToString(), fontNormal, defaultBrush, float.Parse(m_dt.Rows[j]["x"].ToString()), StringY);
  110. // continue;
  111. //}
  112. g.DrawString(m_dt.Rows[j][tbZiDuan].ToString(), fontNormal, defaultBrush, float.Parse(m_dt.Rows[j]["x"].ToString()), StringY);
  113. if (tbZiDuan == "gxgc")//计算Y坐标,只需要计算一次
  114. {
  115. m_dt.Rows[j]["Y"] = (50 + UnitY * (gxgcMax + gxgcChaZhi * 2 - Double.Parse(m_dt.Rows[j]["gxgc"].ToString())));
  116. }
  117. }
  118. }
  119. void GetTableColumsCaption(int i)
  120. {
  121. switch (i)
  122. {
  123. case 1: tbTitle = "距 离(M)"; tbZiDuan = "jl"; break;
  124. case 2: tbTitle = "管 径(MM)"; tbZiDuan = "gxgj"; break;
  125. case 3: tbTitle = "管线埋深(M)"; tbZiDuan = "gxms"; break;
  126. case 4: tbTitle = "管线高程(M)"; tbZiDuan = "gxgc"; break;
  127. case 5: tbTitle = "地面高程(M)"; tbZiDuan = "dmgc"; break;
  128. default: tbTitle = "未知"; tbZiDuan = ""; break;
  129. }
  130. }
  131. #endregion
  132. #region 绘制 断面管线
  133. double gxgj = 0;
  134. double banjing = 0;
  135. Pen PenXuxian = new Pen(Color.Blue, 2); PenXuxian.DashStyle = DashStyle.Dash;
  136. for (int j = 0; j < m_dt.Rows.Count; j++)
  137. {
  138. double.TryParse(m_dt.Rows[j]["gxgj"].ToString(), out gxgj);
  139. banjing = gxgj / 1000 * UnitY;
  140. g.DrawEllipse(PenXYLine, (float)(float.Parse(m_dt.Rows[j]["x"].ToString()) - banjing), (float)(float.Parse(m_dt.Rows[j]["y"].ToString()) - banjing), (float)(banjing * 2), (float)(banjing * 2));
  141. g.DrawLine(PenXuxian, float.Parse(m_dt.Rows[j]["x"].ToString()), (float)(float.Parse(m_dt.Rows[j]["y"].ToString()) + banjing), float.Parse(m_dt.Rows[j]["x"].ToString()), 596);
  142. }
  143. #endregion
  144. //显示 比例尺
  145. string bilichi = string.Format("水平比例尺 1:{0} 垂直比例尺 1:{1} ", Math.Round(UnitX, 0), Math.Round(UnitY, 0));
  146. g.DrawString(bilichi, fontNormal, defaultBrush, width / 3, 60);
  147. pictureBox.Image = image;
  148. uiDataGridView1.DataSource = m_dt;
  149. }
  150. protected override void WndProc(ref Message m)
  151. {
  152. //禁止双击标题栏关闭窗体 0xF093
  153. //禁止拖拽标题栏还原窗体 0xF010
  154. //禁止双击标题栏 0xf122
  155. //禁止关闭按钮 0xF060
  156. //禁止最大化按钮 0xf020
  157. //禁止最小化按钮 0xf030
  158. //禁止还原按钮 0xf120
  159. if (m.Msg != 0xA3 && m.Msg != 0x0003 && m.WParam != (IntPtr)0xF012)
  160. {
  161. base.WndProc(ref m);
  162. }
  163. }
  164. private void uibtnSave_Click(object sender, EventArgs e)
  165. {
  166. SaveFileDialog save = new SaveFileDialog();
  167. save.FileName = uitxtTitle.Text;
  168. save.Filter = "Jpg 图片|*.jpg|Bmp 图片|*.bmp|Png 图片|*.png";
  169. if (save.ShowDialog() == DialogResult.OK)
  170. {
  171. pictureBox.Image.Save(save.FileName);
  172. }
  173. }
  174. private void uibtnQuantu_Click(object sender, EventArgs e)
  175. {
  176. pictureBox.MouseUp -= PictureBox_MouseUp;
  177. pictureBox.Width = 800;
  178. pictureBox.Height = 600;
  179. pictureBox.SizeMode = PictureBoxSizeMode.AutoSize;
  180. pictureBox.Refresh();
  181. }
  182. private void uiIbtnFangda_Click(object sender, EventArgs e)
  183. {
  184. pictureBox.MouseUp -= PictureBox_MouseUp;
  185. pictureBox.SizeMode = PictureBoxSizeMode.StretchImage;
  186. pictureBox.Width = (int)(pictureBox.Width * 1.2);
  187. pictureBox.Height = (int)(pictureBox.Height * 1.2);
  188. pictureBox.Refresh();
  189. }
  190. private void uibtnSuoxiao_Click(object sender, EventArgs e)
  191. {
  192. pictureBox.MouseUp -= PictureBox_MouseUp;
  193. pictureBox.SizeMode = PictureBoxSizeMode.StretchImage;
  194. pictureBox.Width = (int)(pictureBox.Width * 0.8);
  195. pictureBox.Height = (int)(pictureBox.Height * 0.8);
  196. pictureBox.Refresh();
  197. }
  198. private void uibtnPingyi_Click(object sender, EventArgs e)
  199. {
  200. pictureBox.SizeMode = PictureBoxSizeMode.AutoSize;
  201. pictureBox.Cursor = Cursors.Hand;
  202. pictureBox.MouseUp += PictureBox_MouseUp;
  203. }
  204. private void PictureBox_MouseUp(object sender, MouseEventArgs e)
  205. {
  206. }
  207. private void AnalystResultForm_FormClosing(object sender, FormClosingEventArgs e)
  208. {
  209. pictureBox.MouseUp -= PictureBox_MouseUp;
  210. }
  211. }
  212. }