DuanMianAnalystResult.cs 8.9 KB

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