gsp před 10 měsíci
rodič
revize
d1233865c7

+ 1318 - 0
OTSIncAMeasureApp/4-OTSSamplespaceGraphicsPanel/CDisplayGDIObject.cs

@@ -0,0 +1,1318 @@
+using System;
+using System.Collections.Generic;
+using System.Drawing;
+using System.Drawing.Drawing2D;
+using System.Windows.Forms;
+
+namespace OTSMeasureApp
+{
+    
+
+    public class CDisplayGDIObject /*: CRectangleGDIObject */// 同样的方式可以从ADraggableGDIObject生成其它图形的继承角类,比如矩形,三形等等。。
+    {
+        public CDisplayGDIObject()
+        {
+       
+            ID = System.Guid.NewGuid().ToString();
+            OTSX = -1;
+            OTSY = -1;
+        }
+        /// <summary>
+        /// 创建图形
+        /// </summary>
+        /// <param name="startx">X位置</param>
+        /// <param name="starty">Y位置</param>
+        /// <param name="width">宽度</param>
+        /// <param name="height">高度</param>
+        /// <param name="cType">图形类型:createType=0 圆角矩形 createType=1 圆形 createType=2 文字</param>
+        /// <param name="content">文字内容</param>
+        public CDisplayGDIObject(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 CDisplayGDIObject(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 CDisplayGDIObject(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 CDisplayGDIObject(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 CDisplayGDIObject(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 CDisplayGDIObject(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 CDisplayGDIObject(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;
+        }
+
+        /// <summary>
+        /// 获取样品孔中BSE图像
+        /// </summary>
+        /// <param name="rect">位置大小</param>
+        /// <param name="sampleHoleName">所在样品孔名称</param>
+        /// <param name="bseImage">图像信息</param>
+        /// <param name="bseImageWitdh">图像宽度</param>
+        /// <param name="bseImageHeight">图像高度</param>
+        /// <param name="drawImageLocation">图像开始位置</param>
+        /// <param name="cType">绘制类型</param>
+        public CDisplayGDIObject(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 CDisplayGDIObject(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;
+        }
+        /// <summary>
+        /// 获取多边形点集合
+        /// </summary>
+        /// <param name="mPoint"></param>
+        /// <param name="cType"></param>
+        public CDisplayGDIObject(List<PointF> mPoint, CreateRectangleType cType, ShapeType shape, string name, string sampleName, Color selColor)
+        {
+            ID = System.Guid.NewGuid().ToString();
+
+            this.SetOriginalPolygonPointFList(mPoint);
+
+
+           
+            CreateType = cType;
+            Shape = shape;
+            SelColor = selColor;
+
+
+         
+
+
+        }
+        #region 变量重写
+        public virtual  void OnPaint(PaintEventArgs e) 
+        {
+            if (createType == CreateRectangleType.SampleBackGround_Rectangle)
+            {
+                //获取颜色
+                Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.RoundRectangleColor);
+                
+                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)
+            {
+                //获取颜色
+                Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.SampleBackGroundColor);
+                
+                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;
+                //文字颜色
+                Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.FontColor);
+                
+                System.Drawing.SolidBrush sampleBrush = new System.Drawing.SolidBrush(myColor);
+                SolidBrush solidBrush = new SolidBrush(Color.FromArgb(50, Color.Black));
+                //字体大小 根据样品孔Rectangle大小
+                float fontSize = m_RegionF.Width / 2;
+                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;//再加一点
+               
+                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)
+            {
+                //设置颜色
+                Color myColor = OTSSamplespaceGraphicsPanelFun.GetColorValue(ColorType.FieldColor);
+             
+                //设置画笔
+                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<PointF> PolygonPointF = new List<PointF>();
+                    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  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<PointF> GetVertexPoints()
+        {
+            List<PointF> vertexPoint = new List<PointF>();
+            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<PointF> 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<PointF> GetOriginalPolygonPointFList()
+        { return m_originalPolygonPoints; }
+        public void SetOriginalPolygonPointFList(List<PointF> value)
+        {
+            if (m_zoomNum != 1)
+            {
+                var ps = new List<PointF>();
+                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<PointF> GetPolygonPointFList()
+        { return m_PolygonPoints; }
+        public void SetPolygonPointFList(List<PointF> value)
+        {
+            if (m_zoomNum != 1)
+            {
+                var ps = new List<PointF>();
+                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<CDisplayGDIObject> SubItems()
+        {
+            if (subItems == null) subItems = new List<CDisplayGDIObject>();
+            return subItems;
+        }
+        public void AddSubItems(CDisplayGDIObject item)
+        {
+            if (subItems == null) subItems = new List<CDisplayGDIObject>();
+            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;
+          
+
+            var scalePs = new List<PointF>();
+            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<PointF>();
+            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<PointF>();
+            var OriginalPs = new List<PointF>();
+            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  CDisplayGDIObject Duplicate(CreateRectangleType newType)
+        {
+            CDisplayGDIObject r = new CDisplayGDIObject();
+            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(CDisplayGDIObject 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<PointF> m_PolygonPoints=new List<PointF>();
+        //绘制时与移动缩放时记录的位置
+        private List<PointF> m_originalPolygonPoints = new List<PointF>();
+
+        private List<CDisplayGDIObject> subItems=new List<CDisplayGDIObject>();
+
+      
+        protected float m_zoomNum=1;
+
+        private PointF m_refPoint=new PointF(0,0);
+
+        
+    }
+
+  
+    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
+    {
+        FieldColor,//帧图fd8f8f
+        RoundRectangleColor,//c8c8c8圆角矩形
+        SampleBackGroundColor,//c0c0c0圆角矩形
+        FontColor,//90ee90文字颜色
+        SampleColor,//f4f4f4 样品未选择
+        SampleSelColor//505050 样品选择后
+    }
+    
+    public enum GrayLevel
+    {
+        Min=0,
+        Max=255
+    }
+}