CreateRectangle.cs 47 KB

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