2023-01-26 18:27:17 +08:00
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
using System.Windows;
|
2023-01-31 22:45:50 +08:00
|
|
|
|
using System.Windows.Media;
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
|
|
|
|
|
namespace AIStudio.Wpf.DiagramDesigner.Demo.ViewModels
|
|
|
|
|
|
{
|
2023-01-27 14:54:03 +08:00
|
|
|
|
class PathAnimationViewModel : BaseViewModel
|
2023-01-26 18:27:17 +08:00
|
|
|
|
{
|
2023-01-27 14:54:03 +08:00
|
|
|
|
public PathAnimationViewModel()
|
2023-01-26 18:27:17 +08:00
|
|
|
|
{
|
2023-01-27 14:54:03 +08:00
|
|
|
|
Title = "Path Animation";
|
|
|
|
|
|
Info = "Line flow motion animation.";
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
|
|
|
|
|
DiagramViewModel = new DiagramViewModel();
|
2023-05-11 19:14:39 +08:00
|
|
|
|
DiagramViewModel.DiagramOption.LayoutOption.PageSizeType = PageSizeType.Custom;
|
|
|
|
|
|
DiagramViewModel.DiagramOption.LayoutOption.PageSize = new Size(double.NaN, double.NaN);
|
2023-01-27 14:54:03 +08:00
|
|
|
|
DiagramViewModel.ColorViewModel = new ColorViewModel();
|
|
|
|
|
|
DiagramViewModel.ColorViewModel.FillColor.Color = System.Windows.Media.Colors.Orange;
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
2023-01-27 14:54:03 +08:00
|
|
|
|
DefaultDesignerItemViewModel node1 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 50, Top = 50, Text = "1" };
|
2023-03-25 22:29:02 +08:00
|
|
|
|
DiagramViewModel.Add(node1);
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
2023-05-03 17:14:47 +08:00
|
|
|
|
DefaultDesignerItemViewModel node2 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 400, Top = 50, Text = "2" };
|
2023-03-25 22:29:02 +08:00
|
|
|
|
DiagramViewModel.Add(node2);
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
2023-05-03 17:14:47 +08:00
|
|
|
|
ConnectionViewModel connector1 = new ConnectionViewModel(DiagramViewModel, node1.RightConnector, node2.LeftConnector);
|
|
|
|
|
|
connector1.ShapeViewModel.SourceMarker = SharpPath.Arrow;
|
|
|
|
|
|
connector1.ShapeViewModel.SinkMarker = SharpPath.Arrow;
|
|
|
|
|
|
connector1.AddLabel("Arrow");
|
|
|
|
|
|
connector1.AnimationViewModel.Duration = 3;
|
|
|
|
|
|
connector1.AnimationViewModel.Animation = LineAnimation.PathAnimation;
|
|
|
|
|
|
connector1.AnimationViewModel.AnimationPath = SharpPath.Arrow;
|
|
|
|
|
|
DiagramViewModel.Add(connector1);
|
|
|
|
|
|
|
|
|
|
|
|
node1 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 50, Top = 160, Text = "1" };
|
|
|
|
|
|
DiagramViewModel.Add(node1);
|
|
|
|
|
|
|
|
|
|
|
|
node2 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 400, Top = 160, Text = "2" };
|
|
|
|
|
|
DiagramViewModel.Add(node2);
|
|
|
|
|
|
|
|
|
|
|
|
connector1 = new ConnectionViewModel(DiagramViewModel, node1.RightConnector, node2.LeftConnector);
|
|
|
|
|
|
connector1.ShapeViewModel.SourceMarker = SharpPath.Circle;
|
|
|
|
|
|
connector1.ShapeViewModel.SinkMarker = SharpPath.Circle;
|
|
|
|
|
|
connector1.AddLabel("Circle");
|
|
|
|
|
|
connector1.AnimationViewModel.Duration = 3;
|
|
|
|
|
|
connector1.AnimationViewModel.Animation = LineAnimation.PathAnimation;
|
|
|
|
|
|
connector1.AnimationViewModel.AnimationPath = SharpPath.Circle;
|
|
|
|
|
|
DiagramViewModel.Add(connector1);
|
|
|
|
|
|
|
|
|
|
|
|
node1 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 50, Top = 270, Text = "1" };
|
|
|
|
|
|
DiagramViewModel.Add(node1);
|
|
|
|
|
|
|
|
|
|
|
|
node2 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 400, Top = 270, Text = "2" };
|
|
|
|
|
|
DiagramViewModel.Add(node2);
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
2023-05-03 17:14:47 +08:00
|
|
|
|
connector1 = new ConnectionViewModel(DiagramViewModel, node1.RightConnector, node2.LeftConnector);
|
|
|
|
|
|
connector1.ShapeViewModel.SourceMarker = SharpPath.Square;
|
|
|
|
|
|
connector1.ShapeViewModel.SinkMarker = SharpPath.Square;
|
|
|
|
|
|
connector1.AddLabel("Square");
|
|
|
|
|
|
connector1.AnimationViewModel.Duration = 3;
|
2023-04-29 18:36:50 +08:00
|
|
|
|
connector1.AnimationViewModel.Animation = LineAnimation.PathAnimation;
|
2023-05-03 17:14:47 +08:00
|
|
|
|
connector1.AnimationViewModel.AnimationPath = SharpPath.Square;
|
2023-03-25 22:29:02 +08:00
|
|
|
|
DiagramViewModel.Add(connector1);
|
2023-01-26 18:27:17 +08:00
|
|
|
|
|
2023-05-03 17:14:47 +08:00
|
|
|
|
node1 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 50, Top = 380, Text = "1" };
|
|
|
|
|
|
DiagramViewModel.Add(node1);
|
|
|
|
|
|
|
|
|
|
|
|
node2 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 400, Top = 380, Text = "2" };
|
|
|
|
|
|
DiagramViewModel.Add(node2);
|
|
|
|
|
|
|
|
|
|
|
|
connector1 = new ConnectionViewModel(DiagramViewModel, node1.RightConnector, node2.LeftConnector);
|
|
|
|
|
|
connector1.ShapeViewModel.SourceMarker = SharpPath.NewRectangle(10, 20);
|
|
|
|
|
|
connector1.ShapeViewModel.SinkMarker = SharpPath.NewArrow(20, 10);
|
|
|
|
|
|
connector1.AddLabel("Factory");
|
|
|
|
|
|
connector1.AnimationViewModel.Duration = 3;
|
|
|
|
|
|
connector1.AnimationViewModel.Animation = LineAnimation.PathAnimation;
|
|
|
|
|
|
connector1.AnimationViewModel.AnimationPath = SharpPath.NewRectangle(10, 20);
|
|
|
|
|
|
DiagramViewModel.Add(connector1);
|
|
|
|
|
|
|
|
|
|
|
|
node1 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 50, Top = 490, Text = "1" };
|
|
|
|
|
|
DiagramViewModel.Add(node1);
|
|
|
|
|
|
|
|
|
|
|
|
node2 = new DefaultDesignerItemViewModel(DiagramViewModel) { Left = 400, Top = 490, Text = "2" };
|
|
|
|
|
|
DiagramViewModel.Add(node2);
|
|
|
|
|
|
|
|
|
|
|
|
connector1 = new ConnectionViewModel(DiagramViewModel, node1.RightConnector, node2.LeftConnector);
|
|
|
|
|
|
connector1.ShapeViewModel.SourceMarker = new SharpPath("M 0 -8 L 3 -8 3 8 0 8 z M 4 -8 7 -8 7 8 4 8 z M 8 -8 16 0 8 8 z", 16, 16, PathStyle.Arrow, SizeStyle.ExtraLarge);
|
|
|
|
|
|
connector1.ShapeViewModel.SinkMarker = new SharpPath("M 0 -8 L 8 -8 4 0 8 8 0 8 4 0 z", 8, 8, PathStyle.Arrow, SizeStyle.Small);
|
|
|
|
|
|
connector1.AddLabel("Custom");
|
|
|
|
|
|
connector1.AnimationViewModel.Duration = 3;
|
|
|
|
|
|
connector1.AnimationViewModel.Animation = LineAnimation.PathAnimation;
|
|
|
|
|
|
connector1.AnimationViewModel.AnimationPath = new SharpPath("M 0 -8 L 3 -8 3 8 0 8 z M 4 -8 7 -8 7 8 4 8 z M 8 -8 16 0 8 8 z", 16, 16, PathStyle.Arrow, SizeStyle.ExtraLarge);
|
|
|
|
|
|
DiagramViewModel.Add(connector1);
|
2023-01-26 18:27:17 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|