using System; using System.Collections.Generic; using System.Drawing; using System.Drawing.Drawing2D; using System.Windows.Forms; namespace OTSMeasureApp { public class CRectangleGDIObject /*: CRectangleGDIObject */// 同样的方式可以从ADraggableGDIObject生成其它图形的继承角类,比如矩形,三形等等。。 { public CRectangleGDIObject() { ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } /// /// 创建图形 /// /// X位置 /// Y位置 /// 宽度 /// 高度 /// 图形类型:createType=0 圆角矩形 createType=1 圆形 createType=2 文字 /// 文字内容 public CRectangleGDIObject(float startx, float starty, float width, float height, CreateRectangleType cType, string content, string name) { var rec = new RectangleF(startx, starty, width, height); m_OrigineRegionF = rec; SetInitRegionF(m_OrigineRegionF); CreateType = cType; strContent = content; NameOrHoleName = name; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } public CRectangleGDIObject(RectangleF rect, CreateRectangleType cType) { m_OrigineRegionF = rect; SetInitRegionF(m_OrigineRegionF); CreateType = cType; ID = System.Guid.NewGuid().ToString(); //startPoint = new PointF(rect.Left, rect.Top); //EndPoint = new PointF(rect.Right, rect.Bottom); OTSX = -1; OTSY = -1; } public CRectangleGDIObject(RectangleF rect, CreateRectangleType cType, string name) { m_OrigineRegionF = rect; SetInitRegionF(m_OrigineRegionF); CreateType = cType; NameOrHoleName = name; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } public CRectangleGDIObject(RectangleF rect, CreateRectangleType cType, ShapeType shape, string name, Color selColor) { m_OrigineRegionF = rect; SetInitRegionF(m_OrigineRegionF); CreateType = cType; NameOrHoleName = name; Shape = shape; SelColor = selColor; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } public CRectangleGDIObject(RectangleF rectMeasure, CreateRectangleType cType, ShapeType shape, string name, string sampleName, Color selColor) { m_OrigineRegionF = rectMeasure; SetInitRegionF(m_OrigineRegionF); CreateType = cType; NameOrHoleName = name; Shape = shape; SelColor = selColor; SampleName = sampleName; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } //绘制帧图 public CRectangleGDIObject(RectangleF rectSingle, CreateRectangleType cType, string name, string sampleName, Color selColor) { m_OrigineRegionF = rectSingle; SetInitRegionF(m_OrigineRegionF); CreateType = cType; NameOrHoleName = name; Shape = 0; SelColor = selColor; SampleName = sampleName; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } //绘制帧图 public CRectangleGDIObject(RectangleF rectField, int OTSx, int OTSy, CreateRectangleType cType, string name, string sampleName, Color selColor) { m_OrigineRegionF = rectField; SetInitRegionF(m_OrigineRegionF); CreateType = cType; NameOrHoleName = name; Shape = 0; SelColor = selColor; SampleName = sampleName; ID = System.Guid.NewGuid().ToString(); OTSX = OTSx; OTSY = OTSy; } /// /// 获取样品孔中BSE图像 /// /// 位置大小 /// 所在样品孔名称 /// 图像信息 /// 图像宽度 /// 图像高度 /// 图像开始位置 /// 绘制类型 public CRectangleGDIObject(RectangleF rect, int OTSx, int OTSy, string sampleName, string sampleHoleName, float bseImageWitdh, float bseImageHeight, CreateRectangleType cType) { m_OrigineRegionF = rect; SetInitRegionF(m_OrigineRegionF); NameOrHoleName = sampleHoleName; SampleName = sampleName; //生成编号 ID = System.Guid.NewGuid().ToString(); //图像信息 //BSEImage = bseImage; //图像宽度 BSEImageWitdh = bseImageWitdh; //图像高度 BSEImageHeight = bseImageHeight; //图像位置 BSEImageLocation = rect.Location; OTSX = OTSx; OTSY = OTSy; //绘制类型 CreateType = cType; } public CRectangleGDIObject(RectangleF rect, Point ImgPoint, float m_Multiple, CreateRectangleType cType) { m_OrigineRegionF = rect; SetInitRegionF(m_OrigineRegionF); CreateType = cType; ID = System.Guid.NewGuid().ToString(); OTSX = -1; OTSY = -1; } /// /// 获取多边形点集合 /// /// /// public CRectangleGDIObject(List mPoint, CreateRectangleType cType, ShapeType shape, string name, string sampleName, Color selColor) { ID = System.Guid.NewGuid().ToString(); this.SetOriginalPolygonPointFList(mPoint); NameOrHoleName = name; SampleName = sampleName; CreateType = cType; Shape = shape; SelColor = selColor; } #region 变量重写 public virtual void OnPaint(PaintEventArgs e) { if (createType == CreateRectangleType.SampleBackGround_Rectangle) { //获取颜色 string ColorStr = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.RoundRectangleColor); Color myColor = ColorTranslator.FromHtml(ColorStr); System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); GraphicsPath grPath = CreateRoundedRectanglePath(m_RegionF, 20); e.Graphics.SmoothingMode = SmoothingMode.HighQuality; e.Graphics.FillPath(sampleBrush, grPath); e.Graphics.DrawPath(Pens.Black, grPath); } //样品台-圆形 else if (createType == CreateRectangleType.SampleBackGround_Circle) { //获取颜色 string ColorStr = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.SampleBackGroundColor); Color myColor = ColorTranslator.FromHtml(ColorStr); System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 e.Graphics.FillEllipse(sampleBrush, m_RegionF); e.Graphics.DrawEllipse(Pens.Black, m_RegionF); } //圆形 else if (createType == CreateRectangleType.Circle) { System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(System.Drawing.Color.White); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 e.Graphics.FillEllipse(sampleBrush, m_RegionF); e.Graphics.DrawEllipse(Pens.Black, m_RegionF); } //文字 else if (createType == CreateRectangleType.Text) { //设置文字对齐方式 StringFormat sf = new StringFormat(); sf.Alignment = StringAlignment.Center; sf.LineAlignment = StringAlignment.Center; //文字颜色 string ColorStr = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.FontColor); Color myColor = ColorTranslator.FromHtml(ColorStr); System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); SolidBrush solidBrush = new SolidBrush(Color.FromArgb(50, Color.Black)); //字体大小 根据样品孔Rectangle大小 float fontSize = m_RegionF.Width / 4; Font font = new Font("宋体", fontSize, FontStyle.Regular); if (fontSize == 0) { font = new Font("宋体", 5, FontStyle.Regular); } //消除锯齿 e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 //绘制文字阴影 RectangleF rectFont = m_RegionF; rectFont.X += 2; rectFont.Y += 2; e.Graphics.DrawString(strContent, font, solidBrush, rectFont, sf); e.Graphics.DrawString(strContent, font, sampleBrush, m_RegionF, sf); } //矩形 else if (createType == CreateRectangleType.Rectangle) { Color myColor = System.Drawing.Color.White; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 e.Graphics.FillRectangle(sampleBrush, m_RegionF); var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(Pens.Black, m_Region); } //选择样品台 else if (createType == CreateRectangleType.SelectSample) { Color myColor = selColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.AssumeLinear;//再加一点 if (Shape == 0) { e.Graphics.FillEllipse(sampleBrush, m_RegionF); e.Graphics.DrawEllipse(Pens.Black, m_RegionF); } else { e.Graphics.FillRectangle(sampleBrush, m_RegionF); var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(Pens.Black, m_Region); } } //测试区域 else if (createType == CreateRectangleType.MeasureArea) { Color myColor = selColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen p = new Pen(myColor, 1); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 if (Shape == 0) { e.Graphics.DrawEllipse(p, m_RegionF); } else { var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(p, m_Region); } } //绘制帧图 直线 else if (createType == CreateRectangleType.SingleLine) { //设置颜色 string ColorStr = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.SingleColor); Color myColor = ColorTranslator.FromHtml(ColorStr); //设置画笔 System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(sampleBrush, 0.0001f); //未抗锯齿 e.Graphics.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.Default; e.Graphics.InterpolationMode = InterpolationMode.Default; e.Graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias; //设置直线位置与尺寸 PointF startPointF = new PointF(startPoint.X, startPoint.Y); PointF endPointF = new PointF(endPoint.X, endPoint.Y); //度量单位 e.Graphics.PageUnit = GraphicsUnit.Display; e.Graphics.DrawLine(pen, startPointF, endPointF); } //绘制标样 else if (createType == CreateRectangleType.SpecimenRectangle) { Color myColor = System.Drawing.Color.Black; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(sampleBrush, 0.0001f); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(pen, m_Region); e.Graphics.FillRectangle(sampleBrush, m_Region); } //绘制标样 else if (createType == CreateRectangleType.SpecimenCircle) { Color myColor = System.Drawing.Color.Black; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(sampleBrush, 0.0001f); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; e.Graphics.DrawEllipse(pen, m_RegionF); e.Graphics.FillEllipse(sampleBrush, m_RegionF); } //绘制帧图 else if (createType == CreateRectangleType.FieldRectangle) { Color myColor = SelColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(sampleBrush, 0.01f); e.Graphics.SmoothingMode = SmoothingMode.Default; //设置直线位置与尺寸 PointF startPointF = new PointF(m_RegionF.Left, m_RegionF.Top); PointF endPointF = new PointF(m_RegionF.Right, m_RegionF.Bottom); float fontSize = m_RegionF.Width / 4; Font font; if (fontSize == 0) { font = new Font("宋体", 5, FontStyle.Regular); } else { font = new Font("宋体", fontSize, FontStyle.Regular); } StringFormat sf = new StringFormat(); sf.Alignment = StringAlignment.Center; sf.LineAlignment = StringAlignment.Center; e.Graphics.DrawString(m_sequenceNum.ToString(), font, sampleBrush, m_RegionF, sf); //绘制帧图 e.Graphics.DrawRectangle(pen, startPointF.X, startPointF.Y, endPointF.X - startPointF.X, endPointF.Y - startPointF.Y); } //绘制颗粒 else if (createType == CreateRectangleType.ParticleLine) { Color myColor = LineColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(sampleBrush, 0.01f); e.Graphics.SmoothingMode = SmoothingMode.Default; //设置直线位置与长度 PointF startPointF = LineStartPoint; float length = LineLength; PointF endPointF = new PointF(startPointF.X + length, startPointF.Y); e.Graphics.DrawLine(pen, startPointF, endPointF); } //矩形 else if (createType == CreateRectangleType.ParticleAreaRectangle) { Color myColor = System.Drawing.Color.White; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(Pens.Black, m_Region); } //绘制样品孔BSE图像 else if (createType == CreateRectangleType.DrawFrameOfHoleBSEImage) { Color myColor = System.Drawing.Color.White; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 //设置直线位置与尺寸 PointF startPointF = new PointF(m_RegionF.Left, m_RegionF.Top); PointF endPointF = new PointF(m_RegionF.Right + 2, m_RegionF.Bottom + 2); //绘制样品孔中图像信息 if (BSEImage != null) { e.Graphics.DrawImage(BSEImage, startPointF.X, startPointF.Y, endPointF.X - startPointF.X, endPointF.Y - startPointF.Y); } } else if (createType == CreateRectangleType.DrawSEMCenterPoint) { Color myColor = System.Drawing.Color.Red; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 //X轴线 PointF startPointX = semCenterPoint; startPointX.X = startPointX.X - 3; PointF endPointX = semCenterPoint; endPointX.X = endPointX.X + 3; //Y轴线 PointF startPointY = semCenterPoint; startPointY.Y = startPointY.Y - 3; PointF endPointY = semCenterPoint; endPointY.Y = endPointY.Y + 3; //绘制XY轴交叉线+ Pen pen = new Pen(sampleBrush, 0.0001f); e.Graphics.DrawLine(pen, startPointX, endPointX); e.Graphics.DrawLine(pen, startPointY, endPointY); } //绘制BSE标记 else if (createType == CreateRectangleType.DrawBSEElementSignPoint) { System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(System.Drawing.Color.Green); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 Pen pen = new Pen(sampleBrush, 2f); int X = (int)m_OrigineRegionF.X; int Y = (int)m_OrigineRegionF.Y; e.Graphics.DrawLine(pen, new Point(X - 8, Y), new Point(X + 8, Y)); e.Graphics.DrawLine(pen, new Point(X, Y - 8), new Point(X, Y + 8)); } //绘制多边形测量区域 else if (createType == CreateRectangleType.Polygon) { e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 Color myColor = selColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen pen = new Pen(myColor, 1); if (GetPolygonPointFList().Count > 0) { List PolygonPointF = new List(); foreach (var item in m_PolygonPoints) { PolygonPointF.Add(item); } if (PolygonDrawingEndPoint.X != 0 && PolygonDrawingEndPoint.Y != 0) { PolygonPointF.Add(PolygonDrawingEndPoint); } e.Graphics.DrawLines(pen, PolygonPointF.ToArray()); } }//多边形测量区域完成标识 else if (createType == CreateRectangleType.DrawPolygonFinish) { Color myColor = selColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 Pen pen = new Pen(myColor, 1); var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawRectangle(pen, m_Region); } //绘制多边形测量区域 else if (createType == CreateRectangleType.CircleByThreePoints) { Color myColor = selColor; System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor); Pen p = new Pen(myColor, 1); e.Graphics.SmoothingMode = SmoothingMode.AntiAlias; //图片柔顺模式选择 e.Graphics.InterpolationMode = InterpolationMode.HighQualityBicubic;//高质量 e.Graphics.CompositingQuality = CompositingQuality.HighQuality;//再加一点 var m_Region = new Rectangle(); m_Region.X = (int)m_RegionF.X; m_Region.Y = (int)m_RegionF.Y; m_Region.Width = (int)m_RegionF.Width; m_Region.Height = (int)m_RegionF.Height; e.Graphics.DrawEllipse(p, m_Region); } } public Image BSEImage { get { return bseImage; } set { bseImage = value; } } public float BSEImageWitdh { get { return bseImageWidth; } set { bseImageWidth = value; } } public float BSEImageHeight { get { return bseImageHeight; } set { bseImageHeight = value; } } public PointF BSEImageLocation { get { return bseImageLocation; } set { bseImageLocation = value; } } public Color LineColor { get { return lineColor; } set { lineColor = value; } } public float LineLength { get { return lineLength; } set { lineLength = value; } } public PointF LineStartPoint { get { return lineStartPoint; } set { lineStartPoint = value; } } //public PointF SEMCenterPoint //{ // get { return semCenterPoint; } // set { semCenterPoint = value; } //} public int OTSX { get { return otsX; } set { otsX = value; } } public int OTSY { get { return otsY; } set { otsY = value; } } public CreateRectangleType CreateType { get { return createType; } set { createType = value; } } public ShapeType Shape { get { return shape; } set { shape = value; } } public Color SelColor { get { return selColor; } set { selColor = value; } } public string NameOrHoleName//holename when they are not field rectangle gdi object. { get { return nameOrHoleName; } set { nameOrHoleName = value; } } public string ID { get { return id; } set { id = value; } } public string SampleName { get { return sampleName; } set { sampleName = value; } } public int SampleCount { get { return sampleCount; } set { sampleCount = value; } } public string StrContent { get { return strContent; } set { strContent = value; } } public RectangleF GetZoomedRegion { get { var m_Region = new RectangleF(); m_Region.X = m_RegionF.X; m_Region.Y = m_RegionF.Y; m_Region.Width = m_RegionF.Width; m_Region.Height = m_RegionF.Height; return m_Region; } } public List GetVertexPoints() { List vertexPoint = new List(); var region = this.GetZoomedRegionF(); vertexPoint.Add(region.Location); vertexPoint.Add(new PointF(region.X, region.Y + region.Height)); vertexPoint.Add(new PointF(region.X + region.Width, region.Y)); vertexPoint.Add(new PointF(region.X + region.Width, region.Y + region.Height)); return vertexPoint; } public RectangleF GetZoomedRegionF() { return m_RegionF; } public void SetInitRegionF(RectangleF OrigineRegionF)//not zoomed regine value { float x1, y1; x1 = OrigineRegionF.X * m_zoomNum + m_refPoint.X; y1 = OrigineRegionF.Y * m_zoomNum + m_refPoint.Y; float w1, h1; w1 = OrigineRegionF.Width * m_zoomNum; h1 = OrigineRegionF.Height * m_zoomNum; m_OrigineRegionF = OrigineRegionF; m_RegionF = new RectangleF(x1, y1, w1, h1); } internal void SetZoomedRegionF(RectangleF scaleRectangleF) { float x1, y1; x1 = (scaleRectangleF.X-m_refPoint.X) / m_zoomNum ; y1 = (scaleRectangleF.Y-m_refPoint.Y) / m_zoomNum ; float w1, h1; w1 = scaleRectangleF.Width / m_zoomNum; h1 = scaleRectangleF.Height / m_zoomNum; m_OrigineRegionF = new RectangleF(x1, y1, w1, h1); m_RegionF = scaleRectangleF; } private Rectangle GetMinRectangleOfPolygon(List polygonPointList) { if (polygonPointList != null) { if (polygonPointList.Count > 0) { int pCount = polygonPointList.Count; float minX = polygonPointList[0].X; float minY = polygonPointList[0].Y; float maxX = polygonPointList[0].X; float maxY = polygonPointList[0].Y; //获取最小X,Y 最大X,Y for (int i = 0; i < pCount; i++) { minX = Math.Min(minX, polygonPointList[i].X); minY = Math.Min(minY, polygonPointList[i].Y); maxX = Math.Max(maxX, polygonPointList[i].X); maxY = Math.Max(maxY, polygonPointList[i].Y); } //创建外接矩形 Rectangle rect = new Rectangle(); rect.Location = new Point((int)minX, (int)minY); rect.Size = new Size((int)maxX - (int)minX, (int)maxY - (int)minY); return rect; } } return new Rectangle(); } public RectangleF GetOrigionalDrawRegionF() { return m_OrigineRegionF; } public List GetOriginalPolygonPointFList() { return m_originalPolygonPoints; } public void SetOriginalPolygonPointFList(List value) { if (m_zoomNum != 1) { var ps = new List(); foreach (var p in value) { var p1 = new PointF(); p1.X = p.X * m_zoomNum+m_refPoint.X; p1.Y = p.Y *m_zoomNum+ m_refPoint.Y; ps.Add(p1); } m_PolygonPoints = ps; m_originalPolygonPoints = value; } else { m_originalPolygonPoints = value; m_PolygonPoints = value; } } public List GetPolygonPointFList() { return m_PolygonPoints; } public void SetPolygonPointFList(List value) { if (m_zoomNum != 1) { var ps = new List(); foreach (var p in value) { var p1 = new PointF(); p1.X = (p.X - m_refPoint.X) / m_zoomNum; p1.Y = (p.Y - m_refPoint.Y) / m_zoomNum; ps.Add(p1); } m_originalPolygonPoints = ps; m_PolygonPoints = value; } else { m_originalPolygonPoints = value; m_PolygonPoints = value; } var region = GetMinRectangleOfPolygon(m_PolygonPoints); SetZoomedRegionF(region); } public GraphicsPath GetGPath() { var measureItem = this; //重新绘制测量区域路径 GraphicsPath GPath = new GraphicsPath(); if (measureItem.CreateType == CreateRectangleType.Polygon) { GraphicsPath PolygonMeasurePath = new GraphicsPath(); PolygonMeasurePath.AddPolygon(measureItem.GetPolygonPointFList().ToArray()); GPath = PolygonMeasurePath; } else if (measureItem.CreateType == CreateRectangleType.CircleByThreePoints) { GPath.AddEllipse(GetZoomedRegionF()); } else { if (measureItem.Shape == (int)CreateRectangleType.Circle) { GPath.AddEllipse(GetZoomedRegionF()); } else { GPath.AddRectangle(GetZoomedRegionF()); } } return GPath; } public PointF PolygonDrawingEndPoint { get { return endPoint; } set { endPoint = value; } } public Point GetZoomedCenterPoint() { Point pCenterPoint = new Point(); //获取在工作窗口中X,Y位置 pCenterPoint.X = (int)(this.GetZoomedRegion.X + this.GetZoomedRegion.Width / 2); pCenterPoint.Y = (int)(this.GetZoomedRegion.Y + this.GetZoomedRegion.Height / 2); return pCenterPoint; } public PointF GetCenterPoint() { PointF pCenterPoint = new PointF(); //获取在工作窗口中X,Y位置 pCenterPoint.X = (this.GetOrigionalDrawRegionF().X + this.GetOrigionalDrawRegionF().Width / 2); pCenterPoint.Y = (this.GetOrigionalDrawRegionF().Y + this.GetOrigionalDrawRegionF().Height / 2); return pCenterPoint; } #endregion public bool IsDragging { get { return m_IsDragging; } set { m_IsDragging = value; } } public bool IsAltering// changing the size by gui operating. { get { return m_IsAlter; } set { m_IsAlter = value; } } public bool IsWorkSample { get { return m_IsWorkSample; } set { m_IsWorkSample = value; } } public PointF DraggingPoint { get { return m_DraggingPoint; } set { m_DraggingPoint = value; if (subItems.Count != 0) { foreach (var item in subItems) { item.DraggingPoint = m_DraggingPoint; } } } } public int SequenceNum { get => m_sequenceNum; set => m_sequenceNum = value; } public bool IsMoving { get => m_IsMoving; set => m_IsMoving = value; } public PointF GetDisplayRefPoint() { return m_refPoint; } public void SetDisplayRefPoint(PointF value) { m_refPoint = value; SetInitRegionF(m_OrigineRegionF); if (m_originalPolygonPoints.Count != 0) { this.SetPolygonPointFList(m_originalPolygonPoints); } } public float GetZoomNumber() { return m_zoomNum; } public void SetZoomNumber(float value) { m_zoomNum = value; SetInitRegionF(m_OrigineRegionF); if (m_originalPolygonPoints.Count != 0) { this.SetPolygonPointFList(m_originalPolygonPoints); } } #region 画圆角矩形 internal static GraphicsPath CreateRoundedRectanglePath(RectangleF rect, int cornerRadius) { GraphicsPath roundedRect = new GraphicsPath(); roundedRect.AddArc(rect.X, rect.Y, cornerRadius * 2, cornerRadius * 2, 180, 90); roundedRect.AddLine(rect.X + cornerRadius, rect.Y, rect.Right - cornerRadius * 2, rect.Y); roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y, cornerRadius * 2, cornerRadius * 2, 270, 90); roundedRect.AddLine(rect.Right, rect.Y + cornerRadius * 2, rect.Right, rect.Y + rect.Height - cornerRadius * 2); roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y + rect.Height - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 0, 90); roundedRect.AddLine(rect.Right - cornerRadius * 2, rect.Bottom, rect.X + cornerRadius * 2, rect.Bottom); roundedRect.AddArc(rect.X, rect.Bottom - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 90, 90); roundedRect.AddLine(rect.X, rect.Bottom - cornerRadius * 2, rect.X, rect.Y + cornerRadius * 2); roundedRect.CloseFigure(); return roundedRect; } public bool IfZoomContains(Point mousePoint) { if (mousePoint.X > m_RegionF.Left && mousePoint.X < m_RegionF.Left + m_RegionF.Width) { if (mousePoint.Y > m_RegionF.Top && mousePoint.Y < m_RegionF.Top + m_RegionF.Height) { return true; } } return false; } public bool IfContains(PointF thePoint) { if (thePoint.X > m_OrigineRegionF.Left && thePoint.X < m_OrigineRegionF.Left + m_OrigineRegionF.Width) { if (thePoint.Y > m_OrigineRegionF.Top && thePoint.Y < m_OrigineRegionF.Top + m_OrigineRegionF.Height) { return true; } } return false; } public List SubItems() { if (subItems == null) subItems = new List(); return subItems; } public void AddSubItems(CRectangleGDIObject item) { if (subItems == null) subItems = new List(); subItems.Add(item); } public void ClearSubItems() { subItems.Clear(); } public void Zoom(PointF mousePoint, float zoomNum) { float X1; float curZoom = m_zoomNum; float deltaZoom = zoomNum - curZoom; float Y1; if (zoomNum == 1) { m_zoomNum = 1; m_RegionF = m_OrigineRegionF; m_refPoint = new PointF(0, 0); m_PolygonPoints = m_originalPolygonPoints; } else { X1 = (m_RegionF.X - mousePoint.X) / curZoom * deltaZoom + m_RegionF.X; Y1 = (m_RegionF.Y - mousePoint.Y) / curZoom * deltaZoom + m_RegionF.Y; m_refPoint.X = (m_refPoint.X - mousePoint.X) / curZoom * deltaZoom + m_refPoint.X; m_refPoint.Y = (m_refPoint.Y - mousePoint.Y) / curZoom * deltaZoom + m_refPoint.Y; float Width = GetOrigionalDrawRegionF().Width * zoomNum; float Height = GetOrigionalDrawRegionF().Height * zoomNum; m_RegionF = new RectangleF(X1, Y1, Width, Height); m_zoomNum = zoomNum; } BSEImageWitdh = m_RegionF.Width; BSEImageHeight = m_RegionF.Height; BSEImageLocation = m_RegionF.Location; //SEMCenterPoint = m_RegionF.Location; var scalePs = new List(); foreach (var p in m_PolygonPoints) { float x, y; x = (p.X - mousePoint.X) / curZoom * deltaZoom + p.X; y = (p.Y - mousePoint.Y) / curZoom * deltaZoom + p.Y; scalePs.Add(new PointF(x, y)); } m_PolygonPoints = scalePs; if (this.subItems.Count != 0) { foreach (var g in subItems) { g.Zoom(mousePoint,zoomNum); } } } public void Move(PointF location) { PointF offset = new PointF(location.X - DraggingPoint.X, location.Y - DraggingPoint.Y); float X1; float Y1; X1 = (m_RegionF.X + offset.X); Y1 = (m_RegionF.Y + offset.Y); m_RegionF = new RectangleF(X1, Y1, m_RegionF.Width, m_RegionF.Height); m_refPoint.X = m_refPoint.X + offset.X; m_refPoint.Y = m_refPoint.Y + offset.Y; BSEImageWitdh = m_RegionF.Width; BSEImageHeight = m_RegionF.Height; BSEImageLocation = m_RegionF.Location; //SEMCenterPoint = m_RegionF.Location; LineStartPoint = m_RegionF.Location; m_DraggingPoint = new Point((int)location.X,(int)location.Y); var scalePs = new List(); foreach (var p in m_PolygonPoints) { float x, y; x = (p.X + offset.X); y = (p.Y + offset.Y); scalePs.Add(new PointF(x, y)); } m_PolygonPoints = scalePs; if (this.subItems.Count != 0) { foreach (var g in subItems) { g.Move(location); } } } public void PositionAltering(PointF location,bool ifZoomCoord) { PointF offset = new PointF(location.X - DraggingPoint.X, location.Y - DraggingPoint.Y); PointF realShift; if (ifZoomCoord) { realShift = new PointF(offset.X / m_zoomNum, offset.Y / m_zoomNum); } else { realShift = new PointF(offset.X , offset.Y ); } m_OrigineRegionF = new RectangleF(m_OrigineRegionF.X+realShift.X, m_OrigineRegionF.Y+realShift.Y, m_OrigineRegionF.Width, m_OrigineRegionF.Height); SetInitRegionF(m_OrigineRegionF); BSEImageWitdh = m_RegionF.Width; BSEImageHeight = m_RegionF.Height; BSEImageLocation = m_RegionF.Location; LineStartPoint = m_RegionF.Location; var scalePs = new List(); var OriginalPs = new List(); foreach (var p in m_PolygonPoints) { float x, y; x = (p.X + offset.X); y = (p.Y + offset.Y); scalePs.Add(new PointF(x, y)); } m_PolygonPoints = scalePs; foreach (var p in m_originalPolygonPoints) { OriginalPs.Add(new PointF(p.X + realShift.X, p.Y + realShift.Y)); } m_originalPolygonPoints = OriginalPs; m_DraggingPoint = new Point((int)location.X, (int)location.Y); if (this.subItems.Count != 0) { foreach (var g in subItems) { g.PositionAltering(location,ifZoomCoord); } } } public CRectangleGDIObject Duplicate(CreateRectangleType newType) { CRectangleGDIObject r = new CRectangleGDIObject(); r.NameOrHoleName = this.nameOrHoleName; r.SampleName = this.SampleName; r.m_OrigineRegionF = this.m_OrigineRegionF; r.IsWorkSample = this.IsWorkSample; r.m_RegionF = this.m_RegionF; r.m_refPoint = this.m_refPoint; r.m_zoomNum = this.m_zoomNum; r.shape = this.shape; r.createType = newType; return r; } virtual public bool ifRectangleIntersect(CRectangleGDIObject othergdi) { return true; } #endregion //是否设置为选择样品 private bool m_IsAlter; //是否存在帧图信息 //是否设置为拖动 private bool m_IsDragging; private bool m_IsMoving; //是否为工作样品 private bool m_IsWorkSample; private CreateRectangleType createType; private ShapeType shape; private string id; protected string nameOrHoleName=""; public string sampleName=""; //样品孔中样品的数量 public int sampleCount = 0; public string strContent; private Color selColor; private PointF m_DraggingPoint; private int m_sequenceNum; protected RectangleF m_RegionF; //绘制时与移动缩放时记录的位置与尺寸 protected RectangleF m_OrigineRegionF; //private GraphicsPath g_Path=new GraphicsPath(); private PointF startPoint; private PointF endPoint; //绘制颗粒图 private Color lineColor; private float lineLength; private PointF lineStartPoint; private int otsX; private int otsY; //绘制样品孔BSE图像 private Image bseImage; //绘制样品孔BSE图像宽度 private float bseImageWidth; //绘制样品孔BSE图像高度 private float bseImageHeight; //绘制样品孔BSE图像位置 private PointF bseImageLocation; //绘制SEM中心位置 private PointF semCenterPoint; private List m_PolygonPoints=new List(); //绘制时与移动缩放时记录的位置 private List m_originalPolygonPoints = new List(); private List subItems=new List(); protected float m_zoomNum=1; private PointF m_refPoint=new PointF(0,0); } //public enum SEMControlIndex //{ // Magnification=0, // WorkingDistance=1 //} public enum XYIndex { X = 0, Y = 1 } public enum CreateRectangleType { //样品台-圆形 SampleBackGround_Circle = -1, //圆形 Circle = 0, //圆角矩形 SampleBackGround_Rectangle = 1, //样品孔中的文字 Text = 2, //矩形 Rectangle = 3, //选择的样品 SelectSample = 4, //测量区域 MeasureArea = 5, //帧图-直线绘制方式 SingleLine = 6, //表样-矩形 SpecimenRectangle = 7, //表样-圆形 SpecimenCircle = 8, //帧图-矩形绘制 FieldRectangle = 9, //颗粒直线图 ParticleLine = 10, //颗粒分布图 鼠标 ParticleAreaRectangle = 11, //绘制拍摄样品孔BSE照片 DrawFrameOfHoleBSEImage = 12, //绘制sem中心点+ DrawSEMCenterPoint=13, //绘制BSE采集标记 DrawBSEElementSignPoint = 14, //多边形 Polygon = 15, //多边形完成标识 DrawPolygonFinish = 16, //圆形三点法 CircleByThreePoints=17, RingShape=18 } public enum ColorType { SingleColor,//帧图fd8f8f RoundRectangleColor,//c8c8c8圆角矩形 SampleBackGroundColor,//c0c0c0圆角矩形 FontColor,//90ee90文字颜色 SampleColor,//f4f4f4 样品未选择 SampleSelColor//505050 样品选择后 } public enum GrayLevel { Min=0, Max=255 } }