CDisplayGDIObject.cs 47 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Drawing;
  4. using System.Drawing.Drawing2D;
  5. using System.Windows.Forms;
  6. namespace OTSMeasureApp
  7. {
  8. public class CDisplayGDIObject /*: CRectangleGDIObject */// 同样的方式可以从ADraggableGDIObject生成其它图形的继承角类,比如矩形,三形等等。。
  9. {
  10. public CDisplayGDIObject()
  11. {
  12. ID = System.Guid.NewGuid().ToString();
  13. OTSX = -1;
  14. OTSY = -1;
  15. }
  16. /// <summary>
  17. /// 创建图形
  18. /// </summary>
  19. /// <param name="startx">X位置</param>
  20. /// <param name="starty">Y位置</param>
  21. /// <param name="width">宽度</param>
  22. /// <param name="height">高度</param>
  23. /// <param name="cType">图形类型:createType=0 圆角矩形 createType=1 圆形 createType=2 文字</param>
  24. /// <param name="content">文字内容</param>
  25. public CDisplayGDIObject(float startx, float starty, float width, float height, CreateRectangleType cType, string content, string name)
  26. {
  27. var rec = new RectangleF(startx, starty, width, height);
  28. m_OrigineRegionF = rec;
  29. SetInitRegionF(m_OrigineRegionF);
  30. CreateType = cType;
  31. strContent = content;
  32. NameOrHoleName = name;
  33. ID = System.Guid.NewGuid().ToString();
  34. OTSX = -1;
  35. OTSY = -1;
  36. }
  37. public CDisplayGDIObject(RectangleF rect, CreateRectangleType cType)
  38. {
  39. m_OrigineRegionF = rect;
  40. SetInitRegionF(m_OrigineRegionF);
  41. CreateType = cType;
  42. ID = System.Guid.NewGuid().ToString();
  43. //startPoint = new PointF(rect.Left, rect.Top);
  44. //EndPoint = new PointF(rect.Right, rect.Bottom);
  45. OTSX = -1;
  46. OTSY = -1;
  47. }
  48. public CDisplayGDIObject(RectangleF rect, CreateRectangleType cType, string name)
  49. {
  50. m_OrigineRegionF = rect;
  51. SetInitRegionF(m_OrigineRegionF);
  52. CreateType = cType;
  53. NameOrHoleName = name;
  54. ID = System.Guid.NewGuid().ToString();
  55. OTSX = -1;
  56. OTSY = -1;
  57. }
  58. public CDisplayGDIObject(RectangleF rect, CreateRectangleType cType, ShapeType shape, string name, Color selColor)
  59. {
  60. m_OrigineRegionF = rect;
  61. SetInitRegionF(m_OrigineRegionF);
  62. CreateType = cType;
  63. NameOrHoleName = name;
  64. Shape = shape;
  65. SelColor = selColor;
  66. ID = System.Guid.NewGuid().ToString();
  67. OTSX = -1;
  68. OTSY = -1;
  69. }
  70. public CDisplayGDIObject(RectangleF rectMeasure, CreateRectangleType cType, ShapeType shape, string name, string sampleName, Color selColor)
  71. {
  72. m_OrigineRegionF = rectMeasure;
  73. SetInitRegionF(m_OrigineRegionF);
  74. CreateType = cType;
  75. NameOrHoleName = name;
  76. Shape = shape;
  77. SelColor = selColor;
  78. SampleName = sampleName;
  79. ID = System.Guid.NewGuid().ToString();
  80. OTSX = -1;
  81. OTSY = -1;
  82. }
  83. //绘制帧图
  84. public CDisplayGDIObject(RectangleF rectSingle, CreateRectangleType cType, string name, string sampleName, Color selColor)
  85. {
  86. m_OrigineRegionF = rectSingle;
  87. SetInitRegionF(m_OrigineRegionF);
  88. CreateType = cType;
  89. NameOrHoleName = name;
  90. Shape = 0;
  91. SelColor = selColor;
  92. SampleName = sampleName;
  93. ID = System.Guid.NewGuid().ToString();
  94. OTSX = -1;
  95. OTSY = -1;
  96. }
  97. //绘制帧图
  98. public CDisplayGDIObject(RectangleF rectField, int OTSx, int OTSy, CreateRectangleType cType, string name, string sampleName, Color selColor)
  99. {
  100. m_OrigineRegionF = rectField;
  101. SetInitRegionF(m_OrigineRegionF);
  102. CreateType = cType;
  103. NameOrHoleName = name;
  104. Shape = 0;
  105. SelColor = selColor;
  106. SampleName = sampleName;
  107. ID = System.Guid.NewGuid().ToString();
  108. OTSX = OTSx;
  109. OTSY = OTSy;
  110. }
  111. /// <summary>
  112. /// 获取样品孔中BSE图像
  113. /// </summary>
  114. /// <param name="rect">位置大小</param>
  115. /// <param name="sampleHoleName">所在样品孔名称</param>
  116. /// <param name="bseImage">图像信息</param>
  117. /// <param name="bseImageWitdh">图像宽度</param>
  118. /// <param name="bseImageHeight">图像高度</param>
  119. /// <param name="drawImageLocation">图像开始位置</param>
  120. /// <param name="cType">绘制类型</param>
  121. public CDisplayGDIObject(RectangleF rect, int OTSx, int OTSy, string sampleName, string sampleHoleName, float bseImageWitdh, float bseImageHeight, CreateRectangleType cType)
  122. {
  123. m_OrigineRegionF = rect;
  124. SetInitRegionF(m_OrigineRegionF);
  125. NameOrHoleName = sampleHoleName;
  126. SampleName = sampleName;
  127. //生成编号
  128. ID = System.Guid.NewGuid().ToString();
  129. //图像信息
  130. //BSEImage = bseImage;
  131. //图像宽度
  132. BSEImageWitdh = bseImageWitdh;
  133. //图像高度
  134. BSEImageHeight = bseImageHeight;
  135. //图像位置
  136. BSEImageLocation = rect.Location;
  137. OTSX = OTSx;
  138. OTSY = OTSy;
  139. //绘制类型
  140. CreateType = cType;
  141. }
  142. public CDisplayGDIObject(RectangleF rect, Point ImgPoint, float m_Multiple, CreateRectangleType cType)
  143. {
  144. m_OrigineRegionF = rect;
  145. SetInitRegionF(m_OrigineRegionF);
  146. CreateType = cType;
  147. ID = System.Guid.NewGuid().ToString();
  148. OTSX = -1;
  149. OTSY = -1;
  150. }
  151. /// <summary>
  152. /// 获取多边形点集合
  153. /// </summary>
  154. /// <param name="mPoint"></param>
  155. /// <param name="cType"></param>
  156. public CDisplayGDIObject(List<PointF> mPoint, CreateRectangleType cType, ShapeType shape, string name, string sampleName, Color selColor)
  157. {
  158. ID = System.Guid.NewGuid().ToString();
  159. this.SetOriginalPolygonPointFList(mPoint);
  160. CreateType = cType;
  161. Shape = shape;
  162. SelColor = selColor;
  163. }
  164. #region 变量重写
  165. public virtual void OnPaint(PaintEventArgs e)
  166. {
  167. if (createType == CreateRectangleType.SampleBackGround_Rectangle)
  168. {
  169. //获取颜色
  170. Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.RoundRectangleColor);
  171. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  172. GraphicsPath grPath = CreateRoundedRectanglePath(m_RegionF, 20);
  173. //e.Graphics.SmoothingMode = SmoothingMode.HighQuality;
  174. e.Graphics.FillPath(sampleBrush, grPath);
  175. e.Graphics.DrawPath(Pens.Black, grPath);
  176. }
  177. //样品台-圆形
  178. else if (createType == CreateRectangleType.SampleBackGround_Circle)
  179. {
  180. //获取颜色
  181. Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.SampleBackGroundColor);
  182. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  183. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  184. e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  185. e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  186. e.Graphics.FillEllipse(sampleBrush, m_RegionF);
  187. e.Graphics.DrawEllipse(Pens.Black, m_RegionF);
  188. }
  189. //圆形
  190. else if (createType == CreateRectangleType.Circle)
  191. {
  192. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(System.Drawing.Color.White);
  193. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  194. e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  195. e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  196. e.Graphics.FillEllipse(sampleBrush, m_RegionF);
  197. e.Graphics.DrawEllipse(Pens.Black, m_RegionF);
  198. }
  199. //文字
  200. else if (createType == CreateRectangleType.Text)
  201. {
  202. //设置文字对齐方式
  203. StringFormat sf = new StringFormat();
  204. sf.Alignment = StringAlignment.Center;
  205. sf.LineAlignment = StringAlignment.Center;
  206. //文字颜色
  207. Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.FontColor);
  208. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  209. SolidBrush solidBrush = new SolidBrush(Color.FromArgb(50, Color.Black));
  210. //字体大小 根据样品孔Rectangle大小
  211. float fontSize = m_RegionF.Width / 2;
  212. Font font = new Font("宋体", fontSize, FontStyle.Regular);
  213. if (fontSize == 0)
  214. {
  215. font = new Font("宋体", 5, FontStyle.Regular);
  216. }
  217. //消除锯齿
  218. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  219. e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  220. e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  221. e.Graphics.DrawString(strContent, font, sampleBrush, m_RegionF, sf);
  222. }
  223. //矩形
  224. else if (createType == CreateRectangleType.Rectangle)
  225. {
  226. Color myColor = System.Drawing.Color.White;
  227. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  228. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  229. e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  230. e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  231. e.Graphics.FillRectangle(sampleBrush, m_RegionF);
  232. var m_Region = new Rectangle();
  233. m_Region.X = (int)m_RegionF.X;
  234. m_Region.Y = (int)m_RegionF.Y;
  235. m_Region.Width = (int)m_RegionF.Width;
  236. m_Region.Height = (int)m_RegionF.Height;
  237. e.Graphics.DrawRectangle(Pens.Black, m_Region);
  238. }
  239. //选择样品台
  240. else if (createType == CreateRectangleType.SelectSample)
  241. {
  242. Color myColor = selColor;
  243. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  244. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  245. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  246. //e.Graphics.CompositingQuality = CompositingQuality.AssumeLinear;//再加一点
  247. if (Shape == 0)
  248. {
  249. e.Graphics.FillEllipse(sampleBrush, m_RegionF);
  250. e.Graphics.DrawEllipse(Pens.Black, m_RegionF);
  251. }
  252. else
  253. {
  254. e.Graphics.FillRectangle(sampleBrush, m_RegionF);
  255. var m_Region = new Rectangle();
  256. m_Region.X = (int)m_RegionF.X;
  257. m_Region.Y = (int)m_RegionF.Y;
  258. m_Region.Width = (int)m_RegionF.Width;
  259. m_Region.Height = (int)m_RegionF.Height;
  260. e.Graphics.DrawRectangle(Pens.Black, m_Region);
  261. }
  262. }
  263. //测试区域
  264. else if (createType == CreateRectangleType.MeasureArea)
  265. {
  266. Color myColor = selColor;
  267. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  268. Pen p = new Pen(myColor, 1);
  269. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  270. e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  271. e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  272. if (Shape == 0)
  273. {
  274. e.Graphics.DrawEllipse(p, m_RegionF);
  275. }
  276. else
  277. {
  278. var m_Region = new Rectangle();
  279. m_Region.X = (int)m_RegionF.X;
  280. m_Region.Y = (int)m_RegionF.Y;
  281. m_Region.Width = (int)m_RegionF.Width;
  282. m_Region.Height = (int)m_RegionF.Height;
  283. e.Graphics.DrawRectangle(p, m_Region);
  284. }
  285. }
  286. //绘制帧图 直线
  287. else if (createType == CreateRectangleType.SingleLine)
  288. {
  289. //设置颜色
  290. Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.FieldColor);
  291. //设置画笔
  292. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  293. Pen pen = new Pen(sampleBrush, 0.0001f);
  294. //未抗锯齿
  295. e.Graphics.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.Default;
  296. e.Graphics.InterpolationMode = InterpolationMode.Default;
  297. e.Graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias;
  298. //设置直线位置与尺寸
  299. PointF startPointF = new PointF(startPoint.X, startPoint.Y);
  300. PointF endPointF = new PointF(endPoint.X, endPoint.Y);
  301. //度量单位
  302. e.Graphics.PageUnit = GraphicsUnit.Display;
  303. e.Graphics.DrawLine(pen, startPointF, endPointF);
  304. }
  305. //绘制标样
  306. else if (createType == CreateRectangleType.SpecimenRectangle)
  307. {
  308. Color myColor = System.Drawing.Color.Black;
  309. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  310. Pen pen = new Pen(sampleBrush, 0.0001f);
  311. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias;
  312. var m_Region = new Rectangle();
  313. m_Region.X = (int)m_RegionF.X;
  314. m_Region.Y = (int)m_RegionF.Y;
  315. m_Region.Width = (int)m_RegionF.Width;
  316. m_Region.Height = (int)m_RegionF.Height;
  317. e.Graphics.DrawRectangle(pen, m_Region);
  318. e.Graphics.FillRectangle(sampleBrush, m_Region);
  319. }
  320. //绘制标样
  321. else if (createType == CreateRectangleType.SpecimenCircle)
  322. {
  323. Color myColor = System.Drawing.Color.Black;
  324. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  325. Pen pen = new Pen(sampleBrush, 0.0001f);
  326. e.Graphics.SmoothingMode = SmoothingMode.AntiAlias;
  327. e.Graphics.DrawEllipse(pen, m_RegionF);
  328. e.Graphics.FillEllipse(sampleBrush, m_RegionF);
  329. }
  330. //绘制帧图
  331. else if (createType == CreateRectangleType.FieldRectangle)
  332. {
  333. Color myColor = SelColor;
  334. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  335. Pen pen = new Pen(sampleBrush, 0.01f);
  336. e.Graphics.SmoothingMode = SmoothingMode.Default;
  337. //设置直线位置与尺寸
  338. PointF startPointF = new PointF(m_RegionF.Left, m_RegionF.Top);
  339. PointF endPointF = new PointF(m_RegionF.Right, m_RegionF.Bottom);
  340. float fontSize = m_RegionF.Width / 4;
  341. Font font;
  342. if (fontSize == 0)
  343. {
  344. font = new Font("宋体", 5, FontStyle.Regular);
  345. }
  346. else
  347. {
  348. font = new Font("宋体", fontSize, FontStyle.Regular);
  349. }
  350. StringFormat sf = new StringFormat();
  351. sf.Alignment = StringAlignment.Center;
  352. sf.LineAlignment = StringAlignment.Center;
  353. e.Graphics.DrawString(m_sequenceNum.ToString(), font, sampleBrush, m_RegionF, sf);
  354. //绘制帧图
  355. e.Graphics.DrawRectangle(pen, startPointF.X, startPointF.Y, endPointF.X - startPointF.X, endPointF.Y - startPointF.Y);
  356. }
  357. //绘制颗粒
  358. else if (createType == CreateRectangleType.ParticleLine)
  359. {
  360. Color myColor = LineColor;
  361. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  362. Pen pen = new Pen(sampleBrush, 0.01f);
  363. e.Graphics.SmoothingMode = SmoothingMode.Default;
  364. //设置直线位置与长度
  365. PointF startPointF = LineStartPoint;
  366. float length = LineLength;
  367. PointF endPointF = new PointF(startPointF.X + length, startPointF.Y);
  368. e.Graphics.DrawLine(pen, startPointF, endPointF);
  369. }
  370. //矩形
  371. else if (createType == CreateRectangleType.ParticleAreaRectangle)
  372. {
  373. Color myColor = System.Drawing.Color.White;
  374. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  375. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  376. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  377. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  378. var m_Region = new Rectangle();
  379. m_Region.X = (int)m_RegionF.X;
  380. m_Region.Y = (int)m_RegionF.Y;
  381. m_Region.Width = (int)m_RegionF.Width;
  382. m_Region.Height = (int)m_RegionF.Height;
  383. e.Graphics.DrawRectangle(Pens.Black, m_Region);
  384. }
  385. //绘制样品孔BSE图像
  386. else if (createType == CreateRectangleType.DrawFrameOfHoleBSEImage)
  387. {
  388. //Color myColor = System.Drawing.Color.White;
  389. //System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  390. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  391. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  392. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  393. //设置直线位置与尺寸
  394. PointF startPointF = new PointF(m_RegionF.Left, m_RegionF.Top);
  395. PointF endPointF = new PointF(m_RegionF.Right + 2, m_RegionF.Bottom + 2);
  396. //绘制样品孔中图像信息
  397. if (BSEImage != null)
  398. {
  399. e.Graphics.DrawImage(BSEImage, startPointF.X, startPointF.Y, endPointF.X - startPointF.X, endPointF.Y - startPointF.Y);
  400. }
  401. }
  402. else if (createType == CreateRectangleType.DrawSEMCenterPoint)
  403. {
  404. Color myColor = System.Drawing.Color.Red;
  405. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  406. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  407. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  408. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  409. //X轴线
  410. PointF startPointX = semCenterPoint;
  411. startPointX.X = startPointX.X - 3;
  412. PointF endPointX = semCenterPoint;
  413. endPointX.X = endPointX.X + 3;
  414. //Y轴线
  415. PointF startPointY = semCenterPoint;
  416. startPointY.Y = startPointY.Y - 3;
  417. PointF endPointY = semCenterPoint;
  418. endPointY.Y = endPointY.Y + 3;
  419. //绘制XY轴交叉线+
  420. Pen pen = new Pen(sampleBrush, 0.0001f);
  421. e.Graphics.DrawLine(pen, startPointX, endPointX);
  422. e.Graphics.DrawLine(pen, startPointY, endPointY);
  423. }
  424. //绘制BSE标记
  425. else if (createType == CreateRectangleType.DrawBSEElementSignPoint)
  426. {
  427. System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(System.Drawing.Color.Green);
  428. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  429. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  430. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  431. Pen pen = new Pen(sampleBrush, 2f);
  432. int X = (int)m_OrigineRegionF.X;
  433. int Y = (int)m_OrigineRegionF.Y;
  434. e.Graphics.DrawLine(pen, new Point(X - 8, Y), new Point(X + 8, Y));
  435. e.Graphics.DrawLine(pen, new Point(X, Y - 8), new Point(X, Y + 8));
  436. }
  437. //绘制多边形测量区域
  438. else if (createType == CreateRectangleType.Polygon)
  439. {
  440. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  441. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  442. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  443. Color myColor = selColor;
  444. //System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  445. Pen pen = new Pen(myColor, 1);
  446. if (GetPolygonPointFList().Count > 0)
  447. {
  448. List<PointF> PolygonPointF = new List<PointF>();
  449. foreach (var item in m_PolygonPoints)
  450. {
  451. PolygonPointF.Add(item);
  452. }
  453. if (PolygonDrawingEndPoint.X != 0 && PolygonDrawingEndPoint.Y != 0)
  454. {
  455. PolygonPointF.Add(PolygonDrawingEndPoint);
  456. }
  457. e.Graphics.DrawLines(pen, PolygonPointF.ToArray());
  458. }
  459. }//多边形测量区域完成标识
  460. else if (createType == CreateRectangleType.DrawPolygonFinish)
  461. {
  462. Color myColor = selColor;
  463. //System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  464. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  465. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  466. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  467. Pen pen = new Pen(myColor, 1);
  468. var m_Region = new Rectangle();
  469. m_Region.X = (int)m_RegionF.X;
  470. m_Region.Y = (int)m_RegionF.Y;
  471. m_Region.Width = (int)m_RegionF.Width;
  472. m_Region.Height = (int)m_RegionF.Height;
  473. e.Graphics.DrawRectangle(pen, m_Region);
  474. }
  475. //绘制多边形测量区域
  476. else if (createType == CreateRectangleType.CircleByThreePoints)
  477. {
  478. Color myColor = selColor;
  479. //System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
  480. Pen p = new Pen(myColor, 1);
  481. //e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择
  482. //e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量
  483. //e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点
  484. var m_Region = new Rectangle();
  485. m_Region.X = (int)m_RegionF.X;
  486. m_Region.Y = (int)m_RegionF.Y;
  487. m_Region.Width = (int)m_RegionF.Width;
  488. m_Region.Height = (int)m_RegionF.Height;
  489. e.Graphics.DrawEllipse(p, m_Region);
  490. }
  491. }
  492. public Image BSEImage
  493. {
  494. get { return bseImage; }
  495. set { bseImage = value; }
  496. }
  497. public float BSEImageWitdh
  498. {
  499. get { return bseImageWidth; }
  500. set { bseImageWidth = value; }
  501. }
  502. public float BSEImageHeight
  503. {
  504. get { return bseImageHeight; }
  505. set { bseImageHeight = value; }
  506. }
  507. public PointF BSEImageLocation
  508. {
  509. get { return bseImageLocation; }
  510. set { bseImageLocation = value; }
  511. }
  512. public Color LineColor
  513. {
  514. get { return lineColor; }
  515. set { lineColor = value; }
  516. }
  517. public float LineLength
  518. {
  519. get { return lineLength; }
  520. set { lineLength = value; }
  521. }
  522. public PointF LineStartPoint
  523. {
  524. get { return lineStartPoint; }
  525. set { lineStartPoint = value; }
  526. }
  527. public int OTSX
  528. {
  529. get { return otsX; }
  530. set { otsX = value; }
  531. }
  532. public int OTSY
  533. {
  534. get { return otsY; }
  535. set { otsY = value; }
  536. }
  537. public CreateRectangleType CreateType
  538. {
  539. get { return createType; }
  540. set { createType = value; }
  541. }
  542. public ShapeType Shape
  543. {
  544. get { return shape; }
  545. set { shape = value; }
  546. }
  547. public Color SelColor
  548. {
  549. get { return selColor; }
  550. set { selColor = value; }
  551. }
  552. public string NameOrHoleName//holename when they are not field rectangle gdi object.
  553. {
  554. get { return nameOrHoleName; }
  555. set { nameOrHoleName = value; }
  556. }
  557. public string ID
  558. {
  559. get { return id; }
  560. set { id = value; }
  561. }
  562. public string SampleName
  563. {
  564. get { return sampleName; }
  565. set { sampleName = value; }
  566. }
  567. public int SampleCount
  568. {
  569. get { return sampleCount; }
  570. set { sampleCount = value; }
  571. }
  572. public string StrContent
  573. {
  574. get { return strContent; }
  575. set { strContent = value; }
  576. }
  577. public RectangleF GetZoomedRegion
  578. {
  579. get {
  580. var m_Region = new RectangleF();
  581. m_Region.X = m_RegionF.X;
  582. m_Region.Y = m_RegionF.Y;
  583. m_Region.Width = m_RegionF.Width;
  584. m_Region.Height = m_RegionF.Height;
  585. return m_Region;
  586. }
  587. }
  588. public List<PointF> GetVertexPoints()
  589. {
  590. List<PointF> vertexPoint = new List<PointF>();
  591. var region = this.GetZoomedRegionF();
  592. vertexPoint.Add(region.Location);
  593. vertexPoint.Add(new PointF(region.X, region.Y + region.Height));
  594. vertexPoint.Add(new PointF(region.X + region.Width, region.Y));
  595. vertexPoint.Add(new PointF(region.X + region.Width, region.Y + region.Height));
  596. return vertexPoint;
  597. }
  598. public RectangleF GetZoomedRegionF()
  599. {
  600. return m_RegionF;
  601. }
  602. public void SetInitRegionF(RectangleF OrigineRegionF)//not zoomed regine value
  603. {
  604. float x1, y1;
  605. x1 = OrigineRegionF.X * m_zoomNum + m_refPoint.X;
  606. y1 = OrigineRegionF.Y * m_zoomNum + m_refPoint.Y;
  607. float w1, h1;
  608. w1 = OrigineRegionF.Width * m_zoomNum;
  609. h1 = OrigineRegionF.Height * m_zoomNum;
  610. m_OrigineRegionF = OrigineRegionF;
  611. m_RegionF = new RectangleF(x1, y1, w1, h1);
  612. }
  613. internal void SetZoomedRegionF(RectangleF scaleRectangleF)
  614. {
  615. float x1, y1;
  616. x1 = (scaleRectangleF.X-m_refPoint.X) / m_zoomNum ;
  617. y1 = (scaleRectangleF.Y-m_refPoint.Y) / m_zoomNum ;
  618. float w1, h1;
  619. w1 = scaleRectangleF.Width / m_zoomNum;
  620. h1 = scaleRectangleF.Height / m_zoomNum;
  621. m_OrigineRegionF = new RectangleF(x1, y1, w1, h1);
  622. m_RegionF = scaleRectangleF;
  623. }
  624. private Rectangle GetMinRectangleOfPolygon(List<PointF> polygonPointList)
  625. {
  626. if (polygonPointList != null)
  627. {
  628. if (polygonPointList.Count > 0)
  629. {
  630. int pCount = polygonPointList.Count;
  631. float minX = polygonPointList[0].X;
  632. float minY = polygonPointList[0].Y;
  633. float maxX = polygonPointList[0].X;
  634. float maxY = polygonPointList[0].Y;
  635. //获取最小X,Y 最大X,Y
  636. for (int i = 0; i < pCount; i++)
  637. {
  638. minX = Math.Min(minX, polygonPointList[i].X);
  639. minY = Math.Min(minY, polygonPointList[i].Y);
  640. maxX = Math.Max(maxX, polygonPointList[i].X);
  641. maxY = Math.Max(maxY, polygonPointList[i].Y);
  642. }
  643. //创建外接矩形
  644. Rectangle rect = new Rectangle();
  645. rect.Location = new Point((int)minX, (int)minY);
  646. rect.Size = new Size((int)maxX - (int)minX, (int)maxY - (int)minY);
  647. return rect;
  648. }
  649. }
  650. return new Rectangle();
  651. }
  652. public RectangleF GetOrigionalDrawRegionF()
  653. { return m_OrigineRegionF; }
  654. public List<PointF> GetOriginalPolygonPointFList()
  655. { return m_originalPolygonPoints; }
  656. public void SetOriginalPolygonPointFList(List<PointF> value)
  657. {
  658. if (m_zoomNum != 1)
  659. {
  660. var ps = new List<PointF>();
  661. foreach (var p in value)
  662. {
  663. var p1 = new PointF();
  664. p1.X = p.X * m_zoomNum+m_refPoint.X;
  665. p1.Y = p.Y *m_zoomNum+ m_refPoint.Y;
  666. ps.Add(p1);
  667. }
  668. m_PolygonPoints = ps;
  669. m_originalPolygonPoints = value;
  670. }
  671. else
  672. {
  673. m_originalPolygonPoints = value;
  674. m_PolygonPoints = value;
  675. }
  676. }
  677. public List<PointF> GetPolygonPointFList()
  678. { return m_PolygonPoints; }
  679. public void SetPolygonPointFList(List<PointF> value)
  680. {
  681. if (m_zoomNum != 1)
  682. {
  683. var ps = new List<PointF>();
  684. foreach (var p in value)
  685. {
  686. var p1 = new PointF();
  687. p1.X = (p.X - m_refPoint.X) / m_zoomNum;
  688. p1.Y = (p.Y - m_refPoint.Y) / m_zoomNum;
  689. ps.Add(p1);
  690. }
  691. m_originalPolygonPoints = ps;
  692. m_PolygonPoints = value;
  693. }
  694. else
  695. {
  696. m_originalPolygonPoints = value;
  697. m_PolygonPoints = value;
  698. }
  699. var region = GetMinRectangleOfPolygon(m_PolygonPoints);
  700. SetZoomedRegionF(region);
  701. }
  702. public GraphicsPath GetGPath()
  703. {
  704. var measureItem = this;
  705. //重新绘制测量区域路径
  706. GraphicsPath GPath = new GraphicsPath();
  707. if (measureItem.CreateType == CreateRectangleType.Polygon)
  708. {
  709. GraphicsPath PolygonMeasurePath = new GraphicsPath();
  710. PolygonMeasurePath.AddPolygon(measureItem.GetPolygonPointFList().ToArray());
  711. GPath = PolygonMeasurePath;
  712. }
  713. else if (measureItem.CreateType == CreateRectangleType.CircleByThreePoints)
  714. {
  715. GPath.AddEllipse(GetZoomedRegionF());
  716. }
  717. else
  718. {
  719. if (measureItem.Shape == (int)CreateRectangleType.Circle)
  720. {
  721. GPath.AddEllipse(GetZoomedRegionF());
  722. }
  723. else
  724. {
  725. GPath.AddRectangle(GetZoomedRegionF());
  726. }
  727. }
  728. return GPath;
  729. }
  730. public PointF PolygonDrawingEndPoint
  731. {
  732. get { return endPoint; }
  733. set { endPoint = value; }
  734. }
  735. public Point GetZoomedCenterPoint()
  736. {
  737. Point pCenterPoint = new Point();
  738. //获取在工作窗口中X,Y位置
  739. pCenterPoint.X = (int)(this.GetZoomedRegion.X + this.GetZoomedRegion.Width / 2);
  740. pCenterPoint.Y = (int)(this.GetZoomedRegion.Y + this.GetZoomedRegion.Height / 2);
  741. return pCenterPoint;
  742. }
  743. public PointF GetCenterPoint()
  744. {
  745. PointF pCenterPoint = new PointF();
  746. //获取在工作窗口中X,Y位置
  747. pCenterPoint.X = (this.GetOrigionalDrawRegionF().X + this.GetOrigionalDrawRegionF().Width / 2);
  748. pCenterPoint.Y = (this.GetOrigionalDrawRegionF().Y + this.GetOrigionalDrawRegionF().Height / 2);
  749. return pCenterPoint;
  750. }
  751. #endregion
  752. public bool IsDragging
  753. {
  754. get { return m_IsDragging; }
  755. set { m_IsDragging = value; }
  756. }
  757. public bool IsAltering// changing the size by gui operating.
  758. {
  759. get { return m_IsAlter; }
  760. set { m_IsAlter = value; }
  761. }
  762. public bool IsWorkSample
  763. {
  764. get { return m_IsWorkSample; }
  765. set { m_IsWorkSample = value; }
  766. }
  767. public PointF DraggingPoint
  768. {
  769. get { return m_DraggingPoint; }
  770. set {
  771. m_DraggingPoint = value;
  772. if (subItems.Count != 0)
  773. {
  774. foreach (var item in subItems)
  775. {
  776. item.DraggingPoint = m_DraggingPoint;
  777. }
  778. }
  779. }
  780. }
  781. public int SequenceNum { get => m_sequenceNum; set => m_sequenceNum = value; }
  782. public bool IsMoving { get => m_IsMoving; set => m_IsMoving = value; }
  783. public PointF GetDisplayRefPoint()
  784. { return m_refPoint; }
  785. public void SetDisplayRefPoint(PointF value)
  786. {
  787. m_refPoint = value;
  788. SetInitRegionF(m_OrigineRegionF);
  789. if (m_originalPolygonPoints.Count != 0)
  790. {
  791. this.SetPolygonPointFList(m_originalPolygonPoints);
  792. }
  793. }
  794. public float GetZoomNumber()
  795. { return m_zoomNum; }
  796. public void SetZoomNumber(float value)
  797. {
  798. m_zoomNum = value;
  799. SetInitRegionF(m_OrigineRegionF);
  800. if (m_originalPolygonPoints.Count != 0)
  801. {
  802. this.SetPolygonPointFList(m_originalPolygonPoints);
  803. }
  804. }
  805. #region 画圆角矩形
  806. internal static GraphicsPath CreateRoundedRectanglePath(RectangleF rect, int cornerRadius)
  807. {
  808. GraphicsPath roundedRect = new GraphicsPath();
  809. roundedRect.AddArc(rect.X, rect.Y, cornerRadius * 2, cornerRadius * 2, 180, 90);
  810. roundedRect.AddLine(rect.X + cornerRadius, rect.Y, rect.Right - cornerRadius * 2, rect.Y);
  811. roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y, cornerRadius * 2, cornerRadius * 2, 270, 90);
  812. roundedRect.AddLine(rect.Right, rect.Y + cornerRadius * 2, rect.Right, rect.Y + rect.Height - cornerRadius * 2);
  813. roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y + rect.Height - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 0, 90);
  814. roundedRect.AddLine(rect.Right - cornerRadius * 2, rect.Bottom, rect.X + cornerRadius * 2, rect.Bottom);
  815. roundedRect.AddArc(rect.X, rect.Bottom - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 90, 90);
  816. roundedRect.AddLine(rect.X, rect.Bottom - cornerRadius * 2, rect.X, rect.Y + cornerRadius * 2);
  817. roundedRect.CloseFigure();
  818. return roundedRect;
  819. }
  820. public bool IfZoomContains(Point mousePoint)
  821. {
  822. if (mousePoint.X > m_RegionF.Left && mousePoint.X < m_RegionF.Left + m_RegionF.Width)
  823. {
  824. if (mousePoint.Y > m_RegionF.Top && mousePoint.Y < m_RegionF.Top + m_RegionF.Height)
  825. {
  826. return true;
  827. }
  828. }
  829. return false;
  830. }
  831. public bool IfContains(PointF thePoint)
  832. {
  833. if (thePoint.X > m_OrigineRegionF.Left && thePoint.X < m_OrigineRegionF.Left + m_OrigineRegionF.Width)
  834. {
  835. if (thePoint.Y > m_OrigineRegionF.Top && thePoint.Y < m_OrigineRegionF.Top + m_OrigineRegionF.Height)
  836. {
  837. return true;
  838. }
  839. }
  840. return false;
  841. }
  842. public List<CDisplayGDIObject> SubItems()
  843. {
  844. if (subItems == null) subItems = new List<CDisplayGDIObject>();
  845. return subItems;
  846. }
  847. public void AddSubItems(CDisplayGDIObject item)
  848. {
  849. if (subItems == null) subItems = new List<CDisplayGDIObject>();
  850. subItems.Add(item);
  851. }
  852. public void ClearSubItems()
  853. {
  854. subItems.Clear();
  855. }
  856. public void Zoom(PointF mousePoint, float zoomNum)
  857. {
  858. float X1;
  859. float curZoom = m_zoomNum;
  860. float deltaZoom = zoomNum - curZoom;
  861. float Y1;
  862. if (zoomNum == 1)
  863. {
  864. m_zoomNum = 1;
  865. m_RegionF = m_OrigineRegionF;
  866. m_refPoint = new PointF(0, 0);
  867. m_PolygonPoints = m_originalPolygonPoints;
  868. }
  869. else
  870. {
  871. X1 = (m_RegionF.X - mousePoint.X) / curZoom * deltaZoom + m_RegionF.X;
  872. Y1 = (m_RegionF.Y - mousePoint.Y) / curZoom * deltaZoom + m_RegionF.Y;
  873. m_refPoint.X = (m_refPoint.X - mousePoint.X) / curZoom * deltaZoom + m_refPoint.X;
  874. m_refPoint.Y = (m_refPoint.Y - mousePoint.Y) / curZoom * deltaZoom + m_refPoint.Y;
  875. float Width = GetOrigionalDrawRegionF().Width * zoomNum;
  876. float Height = GetOrigionalDrawRegionF().Height * zoomNum;
  877. m_RegionF = new RectangleF(X1, Y1, Width, Height);
  878. m_zoomNum = zoomNum;
  879. }
  880. BSEImageWitdh = m_RegionF.Width;
  881. BSEImageHeight = m_RegionF.Height;
  882. BSEImageLocation = m_RegionF.Location;
  883. var scalePs = new List<PointF>();
  884. foreach (var p in m_PolygonPoints)
  885. {
  886. float x, y;
  887. x = (p.X - mousePoint.X) / curZoom * deltaZoom + p.X;
  888. y = (p.Y - mousePoint.Y) / curZoom * deltaZoom + p.Y;
  889. scalePs.Add(new PointF(x, y));
  890. }
  891. m_PolygonPoints = scalePs;
  892. if (this.subItems.Count != 0)
  893. {
  894. foreach (var g in subItems)
  895. {
  896. g.Zoom(mousePoint,zoomNum);
  897. }
  898. }
  899. }
  900. public void Move(PointF location)
  901. {
  902. PointF offset = new PointF(location.X - DraggingPoint.X, location.Y - DraggingPoint.Y);
  903. float X1;
  904. float Y1;
  905. X1 = (m_RegionF.X + offset.X);
  906. Y1 = (m_RegionF.Y + offset.Y);
  907. m_RegionF = new RectangleF(X1, Y1, m_RegionF.Width, m_RegionF.Height);
  908. m_refPoint.X = m_refPoint.X + offset.X;
  909. m_refPoint.Y = m_refPoint.Y + offset.Y;
  910. BSEImageWitdh = m_RegionF.Width;
  911. BSEImageHeight = m_RegionF.Height;
  912. BSEImageLocation = m_RegionF.Location;
  913. //SEMCenterPoint = m_RegionF.Location;
  914. LineStartPoint = m_RegionF.Location;
  915. m_DraggingPoint = new Point((int)location.X,(int)location.Y);
  916. var scalePs = new List<PointF>();
  917. foreach (var p in m_PolygonPoints)
  918. {
  919. float x, y;
  920. x = (p.X + offset.X);
  921. y = (p.Y + offset.Y);
  922. scalePs.Add(new PointF(x, y));
  923. }
  924. m_PolygonPoints = scalePs;
  925. if (this.subItems.Count != 0)
  926. {
  927. foreach (var g in subItems)
  928. {
  929. g.Move(location);
  930. }
  931. }
  932. }
  933. public void PositionAltering(PointF location,bool ifZoomCoord)
  934. {
  935. PointF offset = new PointF(location.X - DraggingPoint.X, location.Y - DraggingPoint.Y);
  936. PointF realShift;
  937. if (ifZoomCoord)
  938. {
  939. realShift = new PointF(offset.X / m_zoomNum, offset.Y / m_zoomNum);
  940. }
  941. else
  942. {
  943. realShift = new PointF(offset.X , offset.Y );
  944. }
  945. m_OrigineRegionF = new RectangleF(m_OrigineRegionF.X+realShift.X, m_OrigineRegionF.Y+realShift.Y, m_OrigineRegionF.Width, m_OrigineRegionF.Height);
  946. SetInitRegionF(m_OrigineRegionF);
  947. BSEImageWitdh = m_RegionF.Width;
  948. BSEImageHeight = m_RegionF.Height;
  949. BSEImageLocation = m_RegionF.Location;
  950. LineStartPoint = m_RegionF.Location;
  951. var scalePs = new List<PointF>();
  952. var OriginalPs = new List<PointF>();
  953. foreach (var p in m_PolygonPoints)
  954. {
  955. float x, y;
  956. x = (p.X + offset.X);
  957. y = (p.Y + offset.Y);
  958. scalePs.Add(new PointF(x, y));
  959. }
  960. m_PolygonPoints = scalePs;
  961. foreach (var p in m_originalPolygonPoints)
  962. {
  963. OriginalPs.Add(new PointF(p.X + realShift.X, p.Y + realShift.Y));
  964. }
  965. m_originalPolygonPoints = OriginalPs;
  966. m_DraggingPoint = new Point((int)location.X, (int)location.Y);
  967. if (this.subItems.Count != 0)
  968. {
  969. foreach (var g in subItems)
  970. {
  971. g.PositionAltering(location,ifZoomCoord);
  972. }
  973. }
  974. }
  975. public CDisplayGDIObject Duplicate(CreateRectangleType newType)
  976. {
  977. CDisplayGDIObject r = new CDisplayGDIObject();
  978. r.NameOrHoleName = this.nameOrHoleName;
  979. r.SampleName = this.SampleName;
  980. r.m_OrigineRegionF = this.m_OrigineRegionF;
  981. r.IsWorkSample = this.IsWorkSample;
  982. r.m_RegionF = this.m_RegionF;
  983. r.m_refPoint = this.m_refPoint;
  984. r.m_zoomNum = this.m_zoomNum;
  985. r.shape = this.shape;
  986. r.createType = newType;
  987. return r;
  988. }
  989. virtual public bool ifRectangleIntersect(CDisplayGDIObject othergdi)
  990. {
  991. return true;
  992. }
  993. #endregion
  994. //是否设置为选择样品
  995. private bool m_IsAlter;
  996. //是否存在帧图信息
  997. //是否设置为拖动
  998. private bool m_IsDragging;
  999. private bool m_IsMoving;
  1000. //是否为工作样品
  1001. private bool m_IsWorkSample;
  1002. private CreateRectangleType createType;
  1003. private ShapeType shape;
  1004. private string id;
  1005. protected string nameOrHoleName="";
  1006. public string sampleName="";
  1007. //样品孔中样品的数量
  1008. public int sampleCount = 0;
  1009. public string strContent;
  1010. private Color selColor;
  1011. private PointF m_DraggingPoint;
  1012. private int m_sequenceNum;
  1013. protected RectangleF m_RegionF;
  1014. //绘制时与移动缩放时记录的位置与尺寸
  1015. protected RectangleF m_OrigineRegionF;
  1016. //private GraphicsPath g_Path=new GraphicsPath();
  1017. private PointF startPoint;
  1018. private PointF endPoint;
  1019. //绘制颗粒图
  1020. private Color lineColor;
  1021. private float lineLength;
  1022. private PointF lineStartPoint;
  1023. private int otsX;
  1024. private int otsY;
  1025. //绘制样品孔BSE图像
  1026. private Image bseImage;
  1027. //绘制样品孔BSE图像宽度
  1028. private float bseImageWidth;
  1029. //绘制样品孔BSE图像高度
  1030. private float bseImageHeight;
  1031. //绘制样品孔BSE图像位置
  1032. private PointF bseImageLocation;
  1033. //绘制SEM中心位置
  1034. private PointF semCenterPoint;
  1035. private List<PointF> m_PolygonPoints=new List<PointF>();
  1036. //绘制时与移动缩放时记录的位置
  1037. private List<PointF> m_originalPolygonPoints = new List<PointF>();
  1038. private List<CDisplayGDIObject> subItems=new List<CDisplayGDIObject>();
  1039. protected float m_zoomNum=1;
  1040. private PointF m_refPoint=new PointF(0,0);
  1041. }
  1042. public enum XYIndex
  1043. {
  1044. X = 0,
  1045. Y = 1
  1046. }
  1047. public enum CreateRectangleType
  1048. {
  1049. //样品台-圆形
  1050. SampleBackGround_Circle = -1,
  1051. //圆形
  1052. Circle = 0,
  1053. //圆角矩形
  1054. SampleBackGround_Rectangle = 1,
  1055. //样品孔中的文字
  1056. Text = 2,
  1057. //矩形
  1058. Rectangle = 3,
  1059. //选择的样品
  1060. SelectSample = 4,
  1061. //测量区域
  1062. MeasureArea = 5,
  1063. //帧图-直线绘制方式
  1064. SingleLine = 6,
  1065. //表样-矩形
  1066. SpecimenRectangle = 7,
  1067. //表样-圆形
  1068. SpecimenCircle = 8,
  1069. //帧图-矩形绘制
  1070. FieldRectangle = 9,
  1071. //颗粒直线图
  1072. ParticleLine = 10,
  1073. //颗粒分布图 鼠标
  1074. ParticleAreaRectangle = 11,
  1075. //绘制拍摄样品孔BSE照片
  1076. DrawFrameOfHoleBSEImage = 12,
  1077. //绘制sem中心点+
  1078. DrawSEMCenterPoint=13,
  1079. //绘制BSE采集标记
  1080. DrawBSEElementSignPoint = 14,
  1081. //多边形
  1082. Polygon = 15,
  1083. //多边形完成标识
  1084. DrawPolygonFinish = 16,
  1085. //圆形三点法
  1086. CircleByThreePoints=17,
  1087. RingShape=18
  1088. }
  1089. public enum ColorType
  1090. {
  1091. FieldColor,//帧图fd8f8f
  1092. RoundRectangleColor,//c8c8c8圆角矩形
  1093. SampleBackGroundColor,//c0c0c0圆角矩形
  1094. FontColor,//90ee90文字颜色
  1095. SampleColor,//f4f4f4 样品未选择
  1096. SampleSelColor//505050 样品选择后
  1097. }
  1098. public enum GrayLevel
  1099. {
  1100. Min=0,
  1101. Max=255
  1102. }
  1103. }