From cdf12e1954c78e187b142c7d7a460ec7387067f7 Mon Sep 17 00:00:00 2001
From: xcd <834800634@qq.com>
Date: 星期五, 10 七月 2020 15:17:57 +0800
Subject: [PATCH] 配置变动和界面显示联动

---
 src/Bro.M071.Process/UI/KeyIndicator.cs |   73 +++++++++++++++++++++++++++++-------
 1 files changed, 58 insertions(+), 15 deletions(-)

diff --git a/src/Bro.M071.Process/UI/KeyIndicator.cs b/src/Bro.M071.Process/UI/KeyIndicator.cs
index 3e66348..8d43b6b 100644
--- a/src/Bro.M071.Process/UI/KeyIndicator.cs
+++ b/src/Bro.M071.Process/UI/KeyIndicator.cs
@@ -30,20 +30,6 @@
         [Browsable(false)]
         public override bool IsEnabled { get => base.IsEnabled; set => base.IsEnabled = value; }
 
-
-        //[Category("鏄剧ず璁剧疆")]
-        //[Description("宸︿笂/寮�濮嬬偣浣�")]
-        //[TypeConverter(typeof(ComplexObjectConvert))]
-        //[Editor(typeof(PropertyObjectEditor), typeof(UITypeEditor))]
-        //[Browsable(false)]
-        //public CustomizedPoint StartPoint { get; set; } = new CustomizedPoint();
-
-        //[Category("鏄剧ず璁剧疆")]
-        //[Description("鏄剧ず鍖哄煙澶у皬")]
-        //[TypeConverter(typeof(ComplexObjectConvert))]
-        //[Editor(typeof(PropertyObjectEditor), typeof(UITypeEditor))]
-        //public CustomizedPoint Size { get; set; } = new CustomizedPoint();
-
         [Category("鏄剧ず璁剧疆")]
         [Description("鏍囩鏄剧ず鍖哄煙")]
         [DisplayName("鏍囩鏄剧ず鍖哄煙")]
@@ -68,6 +54,11 @@
             {
                 DisplayRect = this.DisplayRect,
             };
+        }
+
+        protected override void SetSelectedPen()
+        {
+            Pen = new Pen(Color.Red, 3);
         }
 
         public override void Draw(Graphics g)
@@ -108,7 +99,12 @@
 
         public override bool IsMouseInSide(Point p)
         {
-            return false;
+            return p.X >= DisplayRect.X && p.X <= DisplayRect.X + DisplayRect.Width && p.Y >= DisplayRect.Y && p.Y <= DisplayRect.Y + DisplayRect.Height;
+        }
+
+        public override bool IsMouseCanMoveElement(Point p)
+        {
+            return IsMouseInSide(p);
         }
 
         public override void OnKeyDown(object sender, KeyEventArgs e)
@@ -133,6 +129,53 @@
 
         public override void Translate(int x, int y)
         {
+            DisplayRect = new Rectangle(DisplayRect.X + x, DisplayRect.Y + y, DisplayRect.Width, DisplayRect.Height);
+        }
+
+        public override void Relocate(Point point)
+        {
+            DisplayRect = new Rectangle(point.X - DisplayRect.Width / 2, point.Y - DisplayRect.Height / 2, DisplayRect.Width, DisplayRect.Height);
+        }
+
+        public override bool IsMouseCanStretchBottom(Point p)
+        {
+
+            return Math.Abs(p.X - (DisplayRect.X + DisplayRect.Width / 2)) < (DisplayRect.Width / 3) && Math.Abs(p.Y - DisplayRect.Y - DisplayRect.Height) < (DisplayRect.Height / 3);
+        }
+
+        public override bool IsMouseCanStretchRight(Point p)
+        {
+            return Math.Abs(p.X - (DisplayRect.X + DisplayRect.Width)) < (DisplayRect.Width / 3) && Math.Abs(p.Y - (DisplayRect.Y + DisplayRect.Height / 2)) < (DisplayRect.Height / 3);
+        }
+
+        public override bool IsMouseCanStretchRightLowerCorner(Point p)
+        {
+            return Math.Abs(p.X - (DisplayRect.X + DisplayRect.Width)) < (DisplayRect.Width / 3) && Math.Abs(p.Y - (DisplayRect.Y + DisplayRect.Height)) < (DisplayRect.Height / 3);
+        }
+
+        int x, y = 0;
+        public override void StretchBottom(Point p)
+        {
+            if (p.Y > DisplayRect.Y)
+            {
+                DisplayRect = new Rectangle(DisplayRect.X, DisplayRect.Y, DisplayRect.Width, p.Y - DisplayRect.Y);
+            }
+        }
+
+        public override void StretchRight(Point p)
+        {
+            if (p.X > DisplayRect.X)
+            {
+                DisplayRect = new Rectangle(DisplayRect.X, DisplayRect.Y, p.X - DisplayRect.X, DisplayRect.Height);
+            }
+        }
+
+        public override void StretchRightLowerCorner(Point p)
+        {
+            if (p.X > DisplayRect.X && p.Y > DisplayRect.Y)
+            {
+                DisplayRect = new Rectangle(DisplayRect.X, DisplayRect.Y, p.X - DisplayRect.X, p.Y - DisplayRect.Y);
+            }
         }
 
         protected override void DrawResult(Graphics g)

--
Gitblit v1.8.0