move namespace Diagrams to BrightSharp.Diagrams

This commit is contained in:
2017-08-31 12:55:09 +03:00
parent b3f14b4637
commit 4e40c7281a
22 changed files with 193 additions and 162 deletions

View File

@@ -60,12 +60,19 @@
<Generator>MSBuild:Compile</Generator> <Generator>MSBuild:Compile</Generator>
<SubType>Designer</SubType> <SubType>Designer</SubType>
</ApplicationDefinition> </ApplicationDefinition>
<Compile Include="ControlContainer.xaml.cs">
<DependentUpon>ControlContainer.xaml</DependentUpon>
</Compile>
<Compile Include="TestPage2.xaml.cs"> <Compile Include="TestPage2.xaml.cs">
<DependentUpon>TestPage2.xaml</DependentUpon> <DependentUpon>TestPage2.xaml</DependentUpon>
</Compile> </Compile>
<Compile Include="TestPage.xaml.cs"> <Compile Include="TestPage.xaml.cs">
<DependentUpon>TestPage.xaml</DependentUpon> <DependentUpon>TestPage.xaml</DependentUpon>
</Compile> </Compile>
<Page Include="ControlContainer.xaml">
<SubType>Designer</SubType>
<Generator>MSBuild:Compile</Generator>
</Page>
<Page Include="CustomWindow.xaml"> <Page Include="CustomWindow.xaml">
<SubType>Designer</SubType> <SubType>Designer</SubType>
<Generator>MSBuild:Compile</Generator> <Generator>MSBuild:Compile</Generator>

View File

@@ -0,0 +1,12 @@
<Window x:Class="BrightSharp.Ui.Tests.ControlContainer"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:BrightSharp.Ui.Tests"
mc:Ignorable="d"
Title="ControlContainer" Height="300" Width="300">
<Grid>
</Grid>
</Window>

View File

@@ -0,0 +1,26 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Shapes;
namespace BrightSharp.Ui.Tests
{
/// <summary>
/// Interaction logic for ControlContainer.xaml
/// </summary>
public partial class ControlContainer : Window
{
public ControlContainer() {
InitializeComponent();
}
}
}

View File

@@ -1,5 +1,4 @@
using BrightSharp.Converters; using BrightSharp.Diagrams;
using Diagrams;
using System; using System;
using System.Text.RegularExpressions; using System.Text.RegularExpressions;
using System.Windows; using System.Windows;

View File

@@ -1,6 +1,5 @@
using System; using System;
using System.Collections; using System.Collections;
using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Windows; using System.Windows;
using System.Windows.Controls; using System.Windows.Controls;

View File

@@ -2,10 +2,9 @@
using System.Windows; using System.Windows;
using System.Windows.Controls; using System.Windows.Controls;
using System.Windows.Documents; using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media; using System.Windows.Media;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class ResizeRotateAdorner : Adorner public class ResizeRotateAdorner : Adorner
@@ -17,7 +16,7 @@ namespace Diagrams
{ {
get get
{ {
return this.visuals.Count; return visuals.Count;
} }
} }
@@ -25,24 +24,24 @@ namespace Diagrams
: base(designerItem) : base(designerItem)
{ {
SnapsToDevicePixels = true; SnapsToDevicePixels = true;
this.chrome = new ResizeRotateChrome(); chrome = new ResizeRotateChrome();
this.chrome.DataContext = designerItem; chrome.DataContext = designerItem;
this.visuals = new VisualCollection(this); visuals = new VisualCollection(this);
this.visuals.Add(this.chrome); visuals.Add(chrome);
this.Focusable = true; Focusable = true;
} }
protected override Size ArrangeOverride(Size arrangeBounds) protected override Size ArrangeOverride(Size arrangeBounds)
{ {
this.chrome.Arrange(new Rect(arrangeBounds)); chrome.Arrange(new Rect(arrangeBounds));
return arrangeBounds; return arrangeBounds;
} }
protected override Visual GetVisualChild(int index) protected override Visual GetVisualChild(int index)
{ {
return this.visuals[index]; return visuals[index];
} }
} }

View File

@@ -2,7 +2,7 @@
using System.Windows; using System.Windows;
using System.Windows.Controls; using System.Windows.Controls;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class ResizeRotateChrome : Control public class ResizeRotateChrome : Control

View File

@@ -4,7 +4,7 @@ using System.Windows.Controls;
using System.Windows.Documents; using System.Windows.Documents;
using System.Windows.Media; using System.Windows.Media;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class SizeAdorner : Adorner public class SizeAdorner : Adorner
@@ -17,29 +17,29 @@ namespace Diagrams
{ {
get get
{ {
return this.visuals.Count; return visuals.Count;
} }
} }
public SizeAdorner(ContentControl designerItem) public SizeAdorner(ContentControl designerItem)
: base(designerItem) : base(designerItem)
{ {
this.SnapsToDevicePixels = true; SnapsToDevicePixels = true;
this.designerItem = designerItem; this.designerItem = designerItem;
this.chrome = new SizeChrome(); chrome = new SizeChrome();
this.chrome.DataContext = designerItem; chrome.DataContext = designerItem;
this.visuals = new VisualCollection(this); visuals = new VisualCollection(this);
this.visuals.Add(this.chrome); visuals.Add(chrome);
} }
protected override Visual GetVisualChild(int index) protected override Visual GetVisualChild(int index)
{ {
return this.visuals[index]; return visuals[index];
} }
protected override Size ArrangeOverride(Size arrangeBounds) protected override Size ArrangeOverride(Size arrangeBounds)
{ {
this.chrome.Arrange(new Rect(new Point(0.0, 0.0), arrangeBounds)); chrome.Arrange(new Rect(new Point(0.0, 0.0), arrangeBounds));
return arrangeBounds; return arrangeBounds;
} }
} }

View File

@@ -5,7 +5,7 @@ using System.Windows;
using System.Windows.Controls; using System.Windows.Controls;
using System.Windows.Data; using System.Windows.Data;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
@@ -13,7 +13,7 @@ namespace Diagrams
{ {
static SizeChrome() static SizeChrome()
{ {
FrameworkElement.DefaultStyleKeyProperty.OverrideMetadata(typeof(SizeChrome), new FrameworkPropertyMetadata(typeof(SizeChrome))); DefaultStyleKeyProperty.OverrideMetadata(typeof(SizeChrome), new FrameworkPropertyMetadata(typeof(SizeChrome)));
} }
} }

View File

@@ -1,16 +1,12 @@
using System; using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Controls; using System.Windows.Controls;
using System.Windows.Documents; using System.Windows.Documents;
using System.Windows; using System.Windows;
using System.Windows.Media; using System.Windows.Media;
using System.Windows.Input;
using System.Windows.Media.Animation; using System.Windows.Media.Animation;
using System.ComponentModel; using System.ComponentModel;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class DesignerItemDecorator : Control public class DesignerItemDecorator : Control
@@ -29,63 +25,63 @@ namespace Diagrams
public DesignerItemDecorator() public DesignerItemDecorator()
{ {
Unloaded += new RoutedEventHandler(this.DesignerItemDecorator_Unloaded); Unloaded += new RoutedEventHandler(DesignerItemDecorator_Unloaded);
} }
private void HideAdorner() private void HideAdorner()
{ {
if (this.adorner != null) if (adorner != null)
{ {
this.adorner.Visibility = Visibility.Hidden; adorner.Visibility = Visibility.Hidden;
} }
} }
private void ShowAdorner() private void ShowAdorner()
{ {
if (this.adorner == null) if (adorner == null)
{ {
AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this); AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this);
if (adornerLayer != null) if (adornerLayer != null)
{ {
ContentControl designerItem = this.DataContext as ContentControl; ContentControl designerItem = DataContext as ContentControl;
Canvas canvas = VisualTreeHelper.GetParent(designerItem) as Canvas; Canvas canvas = VisualTreeHelper.GetParent(designerItem) as Canvas;
this.adorner = new ResizeRotateAdorner(designerItem); adorner = new ResizeRotateAdorner(designerItem);
adornerLayer.Add(this.adorner); adornerLayer.Add(adorner);
if (this.ShowDecorator) if (ShowDecorator)
{ {
this.adorner.Visibility = Visibility.Visible; adorner.Visibility = Visibility.Visible;
var anim = new DoubleAnimation(0, 1, TimeSpan.FromSeconds(.2)); var anim = new DoubleAnimation(0, 1, TimeSpan.FromSeconds(.2));
this.adorner.BeginAnimation(OpacityProperty, anim); adorner.BeginAnimation(OpacityProperty, anim);
} }
else else
{ {
this.adorner.Visibility = Visibility.Hidden; adorner.Visibility = Visibility.Hidden;
} }
} }
} }
else else
{ {
this.adorner.Visibility = Visibility.Visible; adorner.Visibility = Visibility.Visible;
var anim = new DoubleAnimation(0, 1, TimeSpan.FromSeconds(.2)); var anim = new DoubleAnimation(0, 1, TimeSpan.FromSeconds(.2));
this.adorner.BeginAnimation(OpacityProperty, anim); adorner.BeginAnimation(OpacityProperty, anim);
} }
} }
private void DesignerItemDecorator_Unloaded(object sender, RoutedEventArgs e) private void DesignerItemDecorator_Unloaded(object sender, RoutedEventArgs e)
{ {
if (this.adorner != null) if (adorner != null)
{ {
AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this); AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this);
if (adornerLayer != null) if (adornerLayer != null)
{ {
adornerLayer.Remove(this.adorner); adornerLayer.Remove(adorner);
} }
this.adorner = null; adorner = null;
} }
} }

View File

@@ -1,6 +1,6 @@
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="clr-namespace:Diagrams"> xmlns:s="clr-namespace:BrightSharp.Diagrams">
<ResourceDictionary.MergedDictionaries> <ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="SizeChrome.xaml"/> <ResourceDictionary Source="SizeChrome.xaml"/>

View File

@@ -1,6 +1,6 @@
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="clr-namespace:Diagrams"> xmlns:s="clr-namespace:BrightSharp.Diagrams">
<BooleanToVisibilityConverter x:Key="btvc" /> <BooleanToVisibilityConverter x:Key="btvc" />
<Style TargetType="{x:Type Shape}" x:Key="ThumbCorner"> <Style TargetType="{x:Type Shape}" x:Key="ThumbCorner">
<Setter Property="SnapsToDevicePixels" Value="true" /> <Setter Property="SnapsToDevicePixels" Value="true" />

View File

@@ -1,6 +1,6 @@
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="clr-namespace:Diagrams"> xmlns:s="clr-namespace:BrightSharp.Diagrams">
<s:DoubleFormatConverter x:Key="doubleFormatConverter"/> <s:DoubleFormatConverter x:Key="doubleFormatConverter"/>

View File

@@ -3,9 +3,8 @@ using System.Linq;
using System.Windows; using System.Windows;
using System.Windows.Controls; using System.Windows.Controls;
using System.Windows.Controls.Primitives; using System.Windows.Controls.Primitives;
using System;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
public static class SelectionBehavior public static class SelectionBehavior
{ {

View File

@@ -5,7 +5,7 @@ using System.Windows.Controls;
using System.Windows.Controls.Primitives; using System.Windows.Controls.Primitives;
using System.Windows.Media; using System.Windows.Media;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class MoveThumb : Thumb public class MoveThumb : Thumb
@@ -25,10 +25,10 @@ namespace Diagrams
} }
private void MoveThumb_DragStarted(object sender, DragStartedEventArgs e) { private void MoveThumb_DragStarted(object sender, DragStartedEventArgs e) {
this.designerItem = DataContext as ContentControl; designerItem = DataContext as ContentControl;
if (this.designerItem != null) { if (designerItem != null) {
this.rotateTransform = this.designerItem.RenderTransform as RotateTransform; rotateTransform = designerItem.RenderTransform as RotateTransform;
if (designerItem.GetBindingExpression(Panel.ZIndexProperty) == null) { if (designerItem.GetBindingExpression(Panel.ZIndexProperty) == null) {
zIndex = Math.Max(zIndex ?? 0, Panel.GetZIndex(designerItem)); zIndex = Math.Max(zIndex ?? 0, Panel.GetZIndex(designerItem));
Panel.SetZIndex(designerItem, zIndex.Value + 1); Panel.SetZIndex(designerItem, zIndex.Value + 1);
@@ -37,17 +37,17 @@ namespace Diagrams
} }
private void MoveThumb_DragDelta(object sender, DragDeltaEventArgs e) { private void MoveThumb_DragDelta(object sender, DragDeltaEventArgs e) {
if (this.designerItem != null) { if (designerItem != null) {
Point dragDelta = new Point(e.HorizontalChange, e.VerticalChange); Point dragDelta = new Point(e.HorizontalChange, e.VerticalChange);
if (this.rotateTransform != null) { if (rotateTransform != null) {
dragDelta = this.rotateTransform.Transform(dragDelta); dragDelta = rotateTransform.Transform(dragDelta);
} }
if (double.IsNaN(Canvas.GetLeft(this.designerItem))) Canvas.SetLeft(this.designerItem, 0); if (double.IsNaN(Canvas.GetLeft(designerItem))) Canvas.SetLeft(designerItem, 0);
if (double.IsNaN(Canvas.GetTop(this.designerItem))) Canvas.SetTop(this.designerItem, 0); if (double.IsNaN(Canvas.GetTop(designerItem))) Canvas.SetTop(designerItem, 0);
Canvas.SetLeft(this.designerItem, Canvas.GetLeft(this.designerItem) + dragDelta.X); Canvas.SetLeft(designerItem, Canvas.GetLeft(designerItem) + dragDelta.X);
Canvas.SetTop(this.designerItem, Canvas.GetTop(this.designerItem) + dragDelta.Y); Canvas.SetTop(designerItem, Canvas.GetTop(designerItem) + dragDelta.Y);
} }

View File

@@ -4,11 +4,10 @@ using System.Windows.Controls;
using System.Windows.Controls.Primitives; using System.Windows.Controls.Primitives;
using System.Windows.Documents; using System.Windows.Documents;
using System.Windows.Media; using System.Windows.Media;
using System.Collections.Generic;
using System.Windows.Input; using System.Windows.Input;
using System.ComponentModel; using System.ComponentModel;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class ResizeThumb : Thumb public class ResizeThumb : Thumb
@@ -22,53 +21,53 @@ namespace Diagrams
public ResizeThumb() public ResizeThumb()
{ {
DragStarted += new DragStartedEventHandler(this.ResizeThumb_DragStarted); DragStarted += new DragStartedEventHandler(ResizeThumb_DragStarted);
DragDelta += new DragDeltaEventHandler(this.ResizeThumb_DragDelta); DragDelta += new DragDeltaEventHandler(ResizeThumb_DragDelta);
DragCompleted += new DragCompletedEventHandler(this.ResizeThumb_DragCompleted); DragCompleted += new DragCompletedEventHandler(ResizeThumb_DragCompleted);
MouseRightButtonDown += new MouseButtonEventHandler(this.ResizeThumb_MouseRightButtonDown); MouseRightButtonDown += new MouseButtonEventHandler(ResizeThumb_MouseRightButtonDown);
} }
private void ResizeThumb_MouseRightButtonDown(object sender, MouseButtonEventArgs e) private void ResizeThumb_MouseRightButtonDown(object sender, MouseButtonEventArgs e)
{ {
this.designerItem = this.designerItem ?? this.DataContext as ContentControl; designerItem = designerItem ?? DataContext as ContentControl;
if (VerticalAlignment == VerticalAlignment.Top || VerticalAlignment == VerticalAlignment.Bottom) if (VerticalAlignment == VerticalAlignment.Top || VerticalAlignment == VerticalAlignment.Bottom)
{ {
this.designerItem.Height = double.NaN; designerItem.Height = double.NaN;
} }
if (HorizontalAlignment == HorizontalAlignment.Left || HorizontalAlignment == HorizontalAlignment.Right) if (HorizontalAlignment == HorizontalAlignment.Left || HorizontalAlignment == HorizontalAlignment.Right)
{ {
this.designerItem.Width = double.NaN; designerItem.Width = double.NaN;
} }
} }
private void ResizeThumb_DragStarted(object sender, DragStartedEventArgs e) private void ResizeThumb_DragStarted(object sender, DragStartedEventArgs e)
{ {
this.designerItem = this.DataContext as ContentControl; designerItem = DataContext as ContentControl;
if (this.designerItem != null) if (designerItem != null)
{ {
this.canvas = VisualTreeHelper.GetParent(this.designerItem) as Canvas; canvas = VisualTreeHelper.GetParent(designerItem) as Canvas;
if (this.canvas != null) if (canvas != null)
{ {
this.transformOrigin = this.designerItem.RenderTransformOrigin; transformOrigin = designerItem.RenderTransformOrigin;
this.rotateTransform = this.designerItem.RenderTransform as RotateTransform; rotateTransform = designerItem.RenderTransform as RotateTransform;
if (this.rotateTransform != null) if (rotateTransform != null)
{ {
this.angle = this.rotateTransform.Angle * Math.PI / 180.0; angle = rotateTransform.Angle * Math.PI / 180.0;
} }
else else
{ {
this.angle = 0.0d; angle = 0.0d;
} }
AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this.canvas); AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(canvas);
if (adornerLayer != null) if (adornerLayer != null)
{ {
this.adorner = new SizeAdorner(this.designerItem); adorner = new SizeAdorner(designerItem);
adornerLayer.Add(this.adorner); adornerLayer.Add(adorner);
} }
} }
} }
@@ -76,29 +75,29 @@ namespace Diagrams
private void ResizeThumb_DragDelta(object sender, DragDeltaEventArgs e) private void ResizeThumb_DragDelta(object sender, DragDeltaEventArgs e)
{ {
if (this.designerItem != null) if (designerItem != null)
{ {
double deltaVertical, deltaHorizontal; double deltaVertical, deltaHorizontal;
if (double.IsNaN(Canvas.GetTop(this.designerItem))) Canvas.SetTop(this.designerItem, 0); if (double.IsNaN(Canvas.GetTop(designerItem))) Canvas.SetTop(designerItem, 0);
if (double.IsNaN(Canvas.GetLeft(this.designerItem))) Canvas.SetLeft(this.designerItem, 0); if (double.IsNaN(Canvas.GetLeft(designerItem))) Canvas.SetLeft(designerItem, 0);
if ((VerticalAlignment == VerticalAlignment.Top || VerticalAlignment == VerticalAlignment.Bottom) && double.IsNaN(this.designerItem.Height)) this.designerItem.Height = this.designerItem.ActualHeight; if ((VerticalAlignment == VerticalAlignment.Top || VerticalAlignment == VerticalAlignment.Bottom) && double.IsNaN(designerItem.Height)) designerItem.Height = designerItem.ActualHeight;
if ((HorizontalAlignment == HorizontalAlignment.Left || HorizontalAlignment == HorizontalAlignment.Right) && double.IsNaN(this.designerItem.Width)) this.designerItem.Width = this.designerItem.ActualWidth; if ((HorizontalAlignment == HorizontalAlignment.Left || HorizontalAlignment == HorizontalAlignment.Right) && double.IsNaN(designerItem.Width)) designerItem.Width = designerItem.ActualWidth;
switch (VerticalAlignment) switch (VerticalAlignment)
{ {
case System.Windows.VerticalAlignment.Bottom: case System.Windows.VerticalAlignment.Bottom:
deltaVertical = Math.Min(-e.VerticalChange, this.designerItem.ActualHeight - this.designerItem.MinHeight); deltaVertical = Math.Min(-e.VerticalChange, designerItem.ActualHeight - designerItem.MinHeight);
deltaVertical = Math.Max(deltaVertical, this.designerItem.ActualHeight - this.designerItem.MaxHeight); deltaVertical = Math.Max(deltaVertical, designerItem.ActualHeight - designerItem.MaxHeight);
Canvas.SetTop(this.designerItem, Canvas.GetTop(this.designerItem) + (this.transformOrigin.Y * deltaVertical * (1 - Math.Cos(-this.angle)))); Canvas.SetTop(designerItem, Canvas.GetTop(designerItem) + (transformOrigin.Y * deltaVertical * (1 - Math.Cos(-angle))));
Canvas.SetLeft(this.designerItem, Canvas.GetLeft(this.designerItem) - deltaVertical * this.transformOrigin.Y * Math.Sin(-this.angle)); Canvas.SetLeft(designerItem, Canvas.GetLeft(designerItem) - deltaVertical * transformOrigin.Y * Math.Sin(-angle));
this.designerItem.Height -= deltaVertical; designerItem.Height -= deltaVertical;
break; break;
case System.Windows.VerticalAlignment.Top: case System.Windows.VerticalAlignment.Top:
deltaVertical = Math.Min(e.VerticalChange, this.designerItem.ActualHeight - this.designerItem.MinHeight); deltaVertical = Math.Min(e.VerticalChange, designerItem.ActualHeight - designerItem.MinHeight);
deltaVertical = Math.Max(deltaVertical, this.designerItem.ActualHeight - this.designerItem.MaxHeight); deltaVertical = Math.Max(deltaVertical, designerItem.ActualHeight - designerItem.MaxHeight);
Canvas.SetTop(this.designerItem, Canvas.GetTop(this.designerItem) + deltaVertical * Math.Cos(-this.angle) + (this.transformOrigin.Y * deltaVertical * (1 - Math.Cos(-this.angle)))); Canvas.SetTop(designerItem, Canvas.GetTop(designerItem) + deltaVertical * Math.Cos(-angle) + (transformOrigin.Y * deltaVertical * (1 - Math.Cos(-angle))));
Canvas.SetLeft(this.designerItem, Canvas.GetLeft(this.designerItem) + deltaVertical * Math.Sin(-this.angle) - (this.transformOrigin.Y * deltaVertical * Math.Sin(-this.angle))); Canvas.SetLeft(designerItem, Canvas.GetLeft(designerItem) + deltaVertical * Math.Sin(-angle) - (transformOrigin.Y * deltaVertical * Math.Sin(-angle)));
this.designerItem.Height -= deltaVertical; designerItem.Height -= deltaVertical;
break; break;
default: default:
break; break;
@@ -107,18 +106,18 @@ namespace Diagrams
switch (HorizontalAlignment) switch (HorizontalAlignment)
{ {
case System.Windows.HorizontalAlignment.Left: case System.Windows.HorizontalAlignment.Left:
deltaHorizontal = Math.Min(e.HorizontalChange, this.designerItem.ActualWidth - this.designerItem.MinWidth); deltaHorizontal = Math.Min(e.HorizontalChange, designerItem.ActualWidth - designerItem.MinWidth);
deltaHorizontal = Math.Max(deltaHorizontal, this.designerItem.ActualWidth - this.designerItem.MaxWidth); deltaHorizontal = Math.Max(deltaHorizontal, designerItem.ActualWidth - designerItem.MaxWidth);
Canvas.SetTop(this.designerItem, Canvas.GetTop(this.designerItem) + deltaHorizontal * Math.Sin(this.angle) - this.transformOrigin.X * deltaHorizontal * Math.Sin(this.angle)); Canvas.SetTop(designerItem, Canvas.GetTop(designerItem) + deltaHorizontal * Math.Sin(angle) - transformOrigin.X * deltaHorizontal * Math.Sin(angle));
Canvas.SetLeft(this.designerItem, Canvas.GetLeft(this.designerItem) + deltaHorizontal * Math.Cos(this.angle) + (this.transformOrigin.X * deltaHorizontal * (1 - Math.Cos(this.angle)))); Canvas.SetLeft(designerItem, Canvas.GetLeft(designerItem) + deltaHorizontal * Math.Cos(angle) + (transformOrigin.X * deltaHorizontal * (1 - Math.Cos(angle))));
this.designerItem.Width -= deltaHorizontal; designerItem.Width -= deltaHorizontal;
break; break;
case System.Windows.HorizontalAlignment.Right: case System.Windows.HorizontalAlignment.Right:
deltaHorizontal = Math.Min(-e.HorizontalChange, this.designerItem.ActualWidth - this.designerItem.MinWidth); deltaHorizontal = Math.Min(-e.HorizontalChange, designerItem.ActualWidth - designerItem.MinWidth);
deltaHorizontal = Math.Max(deltaHorizontal, this.designerItem.ActualWidth - this.designerItem.MaxWidth); deltaHorizontal = Math.Max(deltaHorizontal, designerItem.ActualWidth - designerItem.MaxWidth);
Canvas.SetTop(this.designerItem, Canvas.GetTop(this.designerItem) - this.transformOrigin.X * deltaHorizontal * Math.Sin(this.angle)); Canvas.SetTop(designerItem, Canvas.GetTop(designerItem) - transformOrigin.X * deltaHorizontal * Math.Sin(angle));
Canvas.SetLeft(this.designerItem, Canvas.GetLeft(this.designerItem) + (deltaHorizontal * this.transformOrigin.X * (1 - Math.Cos(this.angle)))); Canvas.SetLeft(designerItem, Canvas.GetLeft(designerItem) + (deltaHorizontal * transformOrigin.X * (1 - Math.Cos(angle))));
this.designerItem.Width -= deltaHorizontal; designerItem.Width -= deltaHorizontal;
break; break;
default: default:
break; break;
@@ -130,15 +129,15 @@ namespace Diagrams
private void ResizeThumb_DragCompleted(object sender, DragCompletedEventArgs e) private void ResizeThumb_DragCompleted(object sender, DragCompletedEventArgs e)
{ {
if (this.adorner != null) if (adorner != null)
{ {
AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(this.canvas); AdornerLayer adornerLayer = AdornerLayer.GetAdornerLayer(canvas);
if (adornerLayer != null) if (adornerLayer != null)
{ {
adornerLayer.Remove(this.adorner); adornerLayer.Remove(adorner);
} }
this.adorner = null; adorner = null;
} }
} }
} }

View File

@@ -6,7 +6,7 @@ using System.Windows.Controls.Primitives;
using System.Windows.Input; using System.Windows.Input;
using System.Windows.Media; using System.Windows.Media;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
[ToolboxItem(false)] [ToolboxItem(false)]
public class RotateThumb : Thumb public class RotateThumb : Thumb
@@ -20,8 +20,8 @@ namespace Diagrams
public RotateThumb() public RotateThumb()
{ {
DragDelta += new DragDeltaEventHandler(this.RotateThumb_DragDelta); DragDelta += new DragDeltaEventHandler(RotateThumb_DragDelta);
DragStarted += new DragStartedEventHandler(this.RotateThumb_DragStarted); DragStarted += new DragStartedEventHandler(RotateThumb_DragStarted);
MouseRightButtonDown += RotateThumb_MouseLeftButtonDown; MouseRightButtonDown += RotateThumb_MouseLeftButtonDown;
} }
@@ -29,42 +29,42 @@ namespace Diagrams
{ {
if (e.RightButton == MouseButtonState.Pressed) if (e.RightButton == MouseButtonState.Pressed)
{ {
this.rotateTransform = this.designerItem.RenderTransform as RotateTransform; rotateTransform = designerItem.RenderTransform as RotateTransform;
if (this.rotateTransform != null) if (rotateTransform != null)
{ {
this.rotateTransform.Angle = 0; rotateTransform.Angle = 0;
this.designerItem.InvalidateMeasure(); designerItem.InvalidateMeasure();
} }
} }
} }
private void RotateThumb_DragStarted(object sender, DragStartedEventArgs e) private void RotateThumb_DragStarted(object sender, DragStartedEventArgs e)
{ {
this.designerItem = DataContext as ContentControl; designerItem = DataContext as ContentControl;
if (this.designerItem != null) if (designerItem != null)
{ {
this.canvas = VisualTreeHelper.GetParent(this.designerItem) as Canvas; canvas = VisualTreeHelper.GetParent(designerItem) as Canvas;
if (this.canvas != null) if (canvas != null)
{ {
this.centerPoint = this.designerItem.TranslatePoint( centerPoint = designerItem.TranslatePoint(
new Point(this.designerItem.ActualWidth * this.designerItem.RenderTransformOrigin.X, new Point(designerItem.ActualWidth * designerItem.RenderTransformOrigin.X,
this.designerItem.ActualHeight * this.designerItem.RenderTransformOrigin.Y), designerItem.ActualHeight * designerItem.RenderTransformOrigin.Y),
this.canvas); canvas);
Point startPoint = Mouse.GetPosition(this.canvas); Point startPoint = Mouse.GetPosition(canvas);
this.startVector = Point.Subtract(startPoint, this.centerPoint); startVector = Point.Subtract(startPoint, centerPoint);
this.rotateTransform = this.designerItem.RenderTransform as RotateTransform; rotateTransform = designerItem.RenderTransform as RotateTransform;
if (this.rotateTransform == null) if (rotateTransform == null)
{ {
this.designerItem.RenderTransform = new RotateTransform(0); designerItem.RenderTransform = new RotateTransform(0);
this.initialAngle = 0; initialAngle = 0;
} }
else else
{ {
this.initialAngle = this.rotateTransform.Angle; initialAngle = rotateTransform.Angle;
} }
} }
} }
@@ -72,16 +72,16 @@ namespace Diagrams
private void RotateThumb_DragDelta(object sender, DragDeltaEventArgs e) private void RotateThumb_DragDelta(object sender, DragDeltaEventArgs e)
{ {
if (this.designerItem != null && this.canvas != null) if (designerItem != null && canvas != null)
{ {
Point currentPoint = Mouse.GetPosition(this.canvas); Point currentPoint = Mouse.GetPosition(canvas);
Vector deltaVector = Point.Subtract(currentPoint, this.centerPoint); Vector deltaVector = Point.Subtract(currentPoint, centerPoint);
double angle = Vector.AngleBetween(this.startVector, deltaVector); double angle = Vector.AngleBetween(startVector, deltaVector);
RotateTransform rotateTransform = this.designerItem.RenderTransform as RotateTransform; RotateTransform rotateTransform = designerItem.RenderTransform as RotateTransform;
rotateTransform.Angle = this.initialAngle + Math.Round(angle, 0); rotateTransform.Angle = initialAngle + Math.Round(angle, 0);
this.designerItem.InvalidateMeasure(); designerItem.InvalidateMeasure();
} }
} }
} }

View File

@@ -1,12 +1,11 @@
using BrightSharp; using BrightSharp.Extensions;
using BrightSharp.Extensions;
using System; using System;
using System.Globalization; using System.Globalization;
using System.Windows; using System.Windows;
using System.Windows.Media; using System.Windows.Media;
using System.Windows.Media.Animation; using System.Windows.Media.Animation;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
/// <summary> /// <summary>
/// If starts with a(A) then use animation, /// If starts with a(A) then use animation,

View File

@@ -4,7 +4,7 @@
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:conv="clr-namespace:BrightSharp.Converters" xmlns:conv="clr-namespace:BrightSharp.Converters"
xmlns:bs="clr-namespace:BrightSharp.Extensions" xmlns:bs="clr-namespace:BrightSharp.Extensions"
xmlns:diag="clr-namespace:Diagrams"> xmlns:diag="clr-namespace:BrightSharp.Diagrams">
<ResourceDictionary.MergedDictionaries> <ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="Diagrams/Resources/DesignerItem.xaml" /> <ResourceDictionary Source="Diagrams/Resources/DesignerItem.xaml" />
</ResourceDictionary.MergedDictionaries> </ResourceDictionary.MergedDictionaries>

View File

@@ -1,6 +1,4 @@
using System.Reflection; using System.Reflection;
using System.Resources;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
using System.Windows; using System.Windows;
using System.Windows.Markup; using System.Windows.Markup;
@@ -32,13 +30,13 @@ using System.Windows.Markup;
//[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)] //[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)]
[assembly:ThemeInfo( [assembly: ThemeInfo(
ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located
//(used if a resource is not found in the page, //(used if a resource is not found in the page,
// or application resource dictionaries) // or application resource dictionaries)
ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located
//(used if a resource is not found in the page, //(used if a resource is not found in the page,
// app, or any theme specific resource dictionaries) // app, or any theme specific resource dictionaries)
)] )]
@@ -62,4 +60,4 @@ using System.Windows.Markup;
[assembly: XmlnsPrefix("http://schemas.brightsharp.com/diagrams", "bsDiag")] [assembly: XmlnsPrefix("http://schemas.brightsharp.com/diagrams", "bsDiag")]
[assembly: XmlnsDefinition("http://schemas.brightsharp.com/diagrams", "Diagrams")] [assembly: XmlnsDefinition("http://schemas.brightsharp.com/diagrams", "BrightSharp.Diagrams")]

View File

@@ -1,9 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Text;
using System.Text.RegularExpressions; using System.Text.RegularExpressions;
using System.Threading.Tasks;
using System.Windows; using System.Windows;
namespace BrightSharp namespace BrightSharp

View File

@@ -6,7 +6,7 @@ using System.Windows.Documents;
using System.Windows.Input; using System.Windows.Input;
using System.Windows.Media.Animation; using System.Windows.Media.Animation;
namespace Diagrams namespace BrightSharp.Diagrams
{ {
public partial class ZoomControl : ItemsControl public partial class ZoomControl : ItemsControl
@@ -121,13 +121,13 @@ namespace Diagrams
{ {
DoubleAnimation anim = new DoubleAnimation(newValue, TimeSpan.FromSeconds(.3)); DoubleAnimation anim = new DoubleAnimation(newValue, TimeSpan.FromSeconds(.3));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.RenderZoomProperty, anim); BeginAnimation(ZoomControl.RenderZoomProperty, anim);
} }
else else
{ {
DoubleAnimation anim = new DoubleAnimation(newValue, TimeSpan.FromSeconds(0)); DoubleAnimation anim = new DoubleAnimation(newValue, TimeSpan.FromSeconds(0));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.RenderZoomProperty, anim); BeginAnimation(ZoomControl.RenderZoomProperty, anim);
} }
RaiseZoomChangedEvent(); RaiseZoomChangedEvent();
@@ -138,21 +138,21 @@ namespace Diagrams
{ {
DoubleAnimation anim = new DoubleAnimation(translateXTo, TimeSpan.FromSeconds(.3)); DoubleAnimation anim = new DoubleAnimation(translateXTo, TimeSpan.FromSeconds(.3));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.TranslateXProperty, anim); BeginAnimation(ZoomControl.TranslateXProperty, anim);
anim = new DoubleAnimation(translateYTo, TimeSpan.FromSeconds(.3)); anim = new DoubleAnimation(translateYTo, TimeSpan.FromSeconds(.3));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.TranslateYProperty, anim); BeginAnimation(ZoomControl.TranslateYProperty, anim);
} }
else else
{ {
DoubleAnimation anim = new DoubleAnimation(translateXTo, TimeSpan.FromSeconds(0)); DoubleAnimation anim = new DoubleAnimation(translateXTo, TimeSpan.FromSeconds(0));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.TranslateXProperty, anim); BeginAnimation(ZoomControl.TranslateXProperty, anim);
anim = new DoubleAnimation(translateYTo, TimeSpan.FromSeconds(0)); anim = new DoubleAnimation(translateYTo, TimeSpan.FromSeconds(0));
anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut }; anim.EasingFunction = new SineEase() { EasingMode = EasingMode.EaseInOut };
this.BeginAnimation(ZoomControl.TranslateYProperty, anim); BeginAnimation(ZoomControl.TranslateYProperty, anim);
} }
e.Handled = true; e.Handled = true;