diff --git a/DeedyDesigner/Deedy.Activity/DeedyVisual/VisualLayout.cs b/DeedyDesigner/Deedy.Activity/DeedyVisual/VisualLayout.cs index 155cc57..4c52ff8 100644 --- a/DeedyDesigner/Deedy.Activity/DeedyVisual/VisualLayout.cs +++ b/DeedyDesigner/Deedy.Activity/DeedyVisual/VisualLayout.cs @@ -7,11 +7,16 @@ using System.Runtime.CompilerServices; using System.Text; using System.Threading.Tasks; using System.Windows; +using System.Windows.Controls; namespace Deedy.Activity { - public class VisualLayout : IVisualLayout + public class VisualLayout : Control, IVisualLayout { + static VisualLayout() + { + DefaultStyleKeyProperty.OverrideMetadata(typeof(VisualLayout), new FrameworkPropertyMetadata(typeof(VisualLayout))); + } public ExpandoMapping ExpandoMapping { get; set; } = new ExpandoMapping(); public VisualLayout() { } public string Class { get; protected internal set; } = ""; diff --git a/DeedyDesigner/Deedy.Activity/Helpers/VisualHelper.cs b/DeedyDesigner/Deedy.Activity/Helpers/VisualHelper.cs index 6d0105b..3c52f40 100644 --- a/DeedyDesigner/Deedy.Activity/Helpers/VisualHelper.cs +++ b/DeedyDesigner/Deedy.Activity/Helpers/VisualHelper.cs @@ -26,56 +26,45 @@ namespace Deedy.Activity.Helpers public static void Help_DrawDropAdorner(this UIElement ui, DrawingContext dc, DropPlacement dropPlacement, LayoutDirection parentLayout) { if (ui == null || dc == null || dropPlacement == DropPlacement.UnDragged) return; - Pen pen = new Pen(Brushes.Red, 3); + Pen pen = new Pen(Brushes.Transparent, 0); pen.Freeze(); + Brush brush = new SolidColorBrush(Colors.Red) { Opacity = 0.5 }; + Size size = ui.RenderSize; + ThemeResources res = new(); switch (dropPlacement) { case DropPlacement.Rejected: - { - - } + dc.DrawGeometry(brush, pen, res.DropIcon_RejectDragDrop); break; case DropPlacement.Uncertain: - { - - } + dc.DrawGeometry(brush, pen, res.DropIcon_LinkWithOneself); break; case DropPlacement.BeforeMe: { if (parentLayout == LayoutDirection.Horizontal) - { - } + dc.DrawRectangle(brush, pen, new(0, 0, 4, size.Height)); else if (parentLayout == LayoutDirection.Vertical) - { - } + dc.DrawRectangle(brush, pen, new(0, 0, size.Width, 4)); else if (parentLayout == LayoutDirection.Stacked) - { - } - else { } + dc.DrawGeometry(brush, pen, res.DropIcon_BringForward); } break; case DropPlacement.BehindMe: { if (parentLayout == LayoutDirection.Horizontal) - { - } + dc.DrawRectangle(brush, pen, new(size.Width - 4, 0, 4, size.Height)); else if (parentLayout == LayoutDirection.Vertical) - { - } + dc.DrawRectangle(brush, pen, new(size.Height - 4, 0, size.Width, 4)); else if (parentLayout == LayoutDirection.Stacked) - { - } - else { } + dc.DrawGeometry(brush, pen, res.DropIcon_SendBackward); } break; case DropPlacement.WithinMe: - { - } + dc.DrawGeometry(brush, pen, res.DropIcon_InsideOneself); break; case DropPlacement.ReplaceMe: - { - } + dc.DrawGeometry(brush, pen, res.DropIcon_ReplaceOneself); break; default: break; //DropPlacement.UnDragged;不需要绘制任何图样 } @@ -96,7 +85,7 @@ namespace Deedy.Activity.Helpers DropPlacement result = DropPlacement.UnDragged; if (ui != null) { - System.Windows.Size size = ui.RenderSize; + Size size = ui.RenderSize; double horRuler = size.Width / 3; if (horRuler > 20) horRuler = 20; double verRuler = size.Height / 3; @@ -171,10 +160,13 @@ namespace Deedy.Activity.Helpers newGeometry.Transform = new TransformGroup { Children = { - new RotateTransform(angle,newGeometry.Bounds.Left + newGeometry.Bounds.Width/2, - newGeometry.Bounds.Top + newGeometry.Bounds.Height/2), // 顺时针旋转90度 - new ScaleTransform(rectangle.Width/newGeometry.Bounds.Width, rectangle.Height/newGeometry.Bounds.Height), // 宽度放大2倍,高度放大1.5倍 - new TranslateTransform(rectangle.Left-newGeometry.Bounds.Left, rectangle.Top-newGeometry.Bounds.Top), // X/Y方向位移 + new RotateTransform(angle, // 顺时针旋转 + newGeometry.Bounds.Left + newGeometry.Bounds.Width/2, // X 方向旋转中心 + newGeometry.Bounds.Top + newGeometry.Bounds.Height/2), // Y 方向旋转中心 + new ScaleTransform(rectangle.Width/newGeometry.Bounds.Width, // X 方向缩放 + rectangle.Height/newGeometry.Bounds.Height), // Y 方向缩放 + new TranslateTransform(rectangle.Left-newGeometry.Bounds.Left, // X 方向位移 + rectangle.Top-newGeometry.Bounds.Top), // Y 方向位移 } }; return newGeometry; diff --git a/DeedyDesigner/Deedy.Activity/Resources/ThemeKeys.cs b/DeedyDesigner/Deedy.Activity/Resources/ThemeKeys.cs index 52383d1..cb7473f 100644 --- a/DeedyDesigner/Deedy.Activity/Resources/ThemeKeys.cs +++ b/DeedyDesigner/Deedy.Activity/Resources/ThemeKeys.cs @@ -27,7 +27,6 @@ namespace Deedy.Activity public const string DropIcon_BringForward = "DropIcon_BringForward"; // 上移一层 public const string DropIcon_SendBackward = "DropIcon_SendBackward"; // 下移一层 public const string DropIcon_InsideOneself = "DropIcon_InsideOneself"; // 自身内部 - public const string DropIcon_BeforeOrBehind = "DropIcon_BeforeOrBehind"; // 自身前后 public const string DropIcon_ReplaceOneself = "DropIcon_ReplaceOneself"; // 替换自身 public const string DropIcon_LinkWithOneself = "DropIcon_LinkWithOneself"; // 链接自身 public const string DropIcon_RejectDragDrop = "DropIcon_RejectDragDrop"; // 决绝拖放 @@ -55,7 +54,6 @@ namespace Deedy.Activity public static ComponentResourceKey DropIcon_BringForward = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_BringForward); public static ComponentResourceKey DropIcon_SendBackward = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_SendBackward); public static ComponentResourceKey DropIcon_InsideOneself = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_InsideOneself); - public static ComponentResourceKey DropIcon_BeforeOrBehind = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_BeforeOrBehind); public static ComponentResourceKey DropIcon_ReplaceOneself = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_ReplaceOneself); public static ComponentResourceKey DropIcon_LinkWithOneself = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_LinkWithOneself); public static ComponentResourceKey DropIcon_RejectDragDrop = new ComponentResourceKey(typeof(ThemeKeys), Keys.DropIcon_RejectDragDrop); diff --git a/DeedyDesigner/Deedy.Activity/Resources/ThemeResources.cs b/DeedyDesigner/Deedy.Activity/Resources/ThemeResources.cs index 2cde4ba..7ae481b 100644 --- a/DeedyDesigner/Deedy.Activity/Resources/ThemeResources.cs +++ b/DeedyDesigner/Deedy.Activity/Resources/ThemeResources.cs @@ -25,7 +25,6 @@ namespace Deedy.Activity public PathGeometry? DropIcon_BringForward => this[ThemeKeys.DropIcon_BringForward] as PathGeometry; public PathGeometry? DropIcon_SendBackward => this[ThemeKeys.DropIcon_SendBackward] as PathGeometry; public PathGeometry? DropIcon_InsideOneself => this[ThemeKeys.DropIcon_InsideOneself] as PathGeometry; - public PathGeometry? DropIcon_BeforeOrBehind => this[ThemeKeys.DropIcon_BeforeOrBehind] as PathGeometry; public PathGeometry? DropIcon_ReplaceOneself => this[ThemeKeys.DropIcon_ReplaceOneself] as PathGeometry; public PathGeometry? DropIcon_LinkWithOneself => this[ThemeKeys.DropIcon_LinkWithOneself] as PathGeometry; public PathGeometry? DropIcon_RejectDragDrop => this[ThemeKeys.DropIcon_RejectDragDrop] as PathGeometry; diff --git a/DeedyDesigner/Deedy.Activity/Themes/ThemeResources.xaml b/DeedyDesigner/Deedy.Activity/Themes/ThemeResources.xaml index de6bc00..84378c5 100644 --- a/DeedyDesigner/Deedy.Activity/Themes/ThemeResources.xaml +++ b/DeedyDesigner/Deedy.Activity/Themes/ThemeResources.xaml @@ -70,13 +70,10 @@ M 11 0 V 10.5 H 13 V 0 Z M 0 10.5 L 12 15 L 24 10.5 L 16 7.5 A 1 1 0 0 0 16 9 L 20 10.5 L 12 13.5 L 4 10.5 L 8 9 A 1 1 0 0 0 8 7.5 z M 11 16.5 V 20.5 L 6.5 19 L 12 24 V 24 L 17.5 19 L 13 20.5 V 16.5 Z - M0,0H8L16,16L0,8ZM16,16L24,0V24H0Z - - - M0,0H24V4H0ZM12,4L0,16L12,10L24,16ZM12,10L0,24L12,16L24,24Z + M 14 3 H 17 L 12 8 L 7 3 H 10 V 0 H 14 V 3 Z M 10 21 H 7 L 12 16 L 17 21 H 14 V 24 H 10 V 21 Z M 3 10 V 7 L 8 12 L 3 17 V 14 H 0 V 10 H 3 Z M 21 14 V 17 L 16 12 L 21 7 V 10 H 24 V 14 H 21 Z - M0,24V0H24L6,6ZM6,6L12,24V12H24Z + M 23 12 c 0 1.042 -0.154 2.045 -0.425 3 h -2.101 c 0.335 -0.94 0.526 -1.947 0.526 -3 c 0 -4.962 -4.037 -9 -9 -9 c -1.706 0 -3.296 0.484 -4.655 1.314 l 1.858 2.686 h -6.994 l 2.152 -7 l 1.849 2.673 c 1.684 -1.049 3.659 -1.673 5.79 -1.673 c 6.074 0 11 4.925 11 11 z m -6.354 7.692 c -1.357 0.826 -2.944 1.308 -4.646 1.308 c -4.962 0 -9 -4.038 -9 -9 c 0 -1.053 0.191 -2.06 0.525 -3 h -2.1 c -0.271 0.955 -0.425 1.958 -0.425 3 c 0 6.075 4.925 11 11 11 c 2.127 0 4.099 -0.621 5.78 -1.667 l 1.853 2.667 l 2.152 -6.989 h -6.994 l 1.855 2.681 z m -3.646 -5.692 h -2 v -7 h 2 v 7 z m 0 1 h -2 v 2 h 2 v -2 z M 0 0 V 24 H 24 H 0 M 21 9 C 19.344 9 18 10.343 18 12 S 19.344 15 21 15 S 24 13.657 24 12 S 22.656 9 21 9 Z M 6 18 C 4.343 18 3 19.343 3 21 S 4.343 24 6 24 C 7.656 24 9 22.657 9 21 S 7.656 18 6 18 Z M 9 3 C 9 4.657 7.656 6 6 6 S 3 4.657 3 3 S 4.344 0 6 0 S 9 1.343 9 3 Z M 10.588 1.021 L 11 1 C 15.281 1 18.981 3.45 20.8 7.021 C 20.083 7.05 19.41 7.231 18.802 7.532 C 17.247 4.829 14.336 3 11 3 C 11 2.297 10.851 1.628 10.588 1.021 Z M 20.8 16.979 C 18.981 20.55 15.281 23 11 23 L 10.588 22.979 C 10.851 22.372 11 21.703 11 21 C 14.336 21 17.247 19.171 18.802 16.468 C 19.41 16.77 20.083 16.951 20.8 16.979 Z M 1.89 18.165 C 0.697 16.406 0 14.285 0 12 S 0.697 7.594 1.89 5.835 C 2.282 6.401 2.791 6.874 3.377 7.238 C 2.51 8.621 2 10.25 2 12 S 2.51 15.379 3.377 16.762 C 2.791 17.126 2.281 17.599 1.89 18.165 Z