mirror of
https://gitee.com/akwkevin/aistudio.-wpf.-diagram
synced 2026-04-06 01:06:37 +08:00
Mind
This commit is contained in:
@@ -30,6 +30,11 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
{
|
||||
// we only move DesignerItems
|
||||
designerItems = designerItem.Root.SelectedItems.ToList();
|
||||
if (designerItem is IGroupable groupable)
|
||||
{
|
||||
designerItems.AddRange(designerItem.Root.SelectionService.GetGroupMembers(groupable).OfType<SelectableDesignerItemViewModelBase>());
|
||||
}
|
||||
|
||||
if (designerItem is ConnectionViewModel connector)
|
||||
{
|
||||
designerItems.Add(connector.SourceConnectorInfo.DataItem);
|
||||
@@ -44,6 +49,8 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
designerItems = new List<SelectableDesignerItemViewModelBase> { designerItem };
|
||||
}
|
||||
|
||||
designerItems = designerItems.Distinct().ToList();
|
||||
|
||||
foreach (DesignerItemViewModelBase item in designerItems.OfType<DesignerItemViewModelBase>())
|
||||
{
|
||||
item.BeginDo = true;
|
||||
|
||||
@@ -115,7 +115,7 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
|
||||
private void DragLeft(double scale, DesignerItemViewModelBase item, SelectionService selectionService)
|
||||
{
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item).Cast<DesignerItemViewModelBase>();
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item, false).Cast<DesignerItemViewModelBase>();
|
||||
|
||||
double groupLeft = item.Left + item.ItemWidth;
|
||||
foreach (DesignerItemViewModelBase groupItem in groupItems)
|
||||
@@ -129,7 +129,7 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
|
||||
private void DragTop(double scale, DesignerItemViewModelBase item, SelectionService selectionService)
|
||||
{
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item).Cast<DesignerItemViewModelBase>();
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item, false).Cast<DesignerItemViewModelBase>();
|
||||
double groupBottom = item.Top + item.ItemHeight;
|
||||
foreach (DesignerItemViewModelBase groupItem in groupItems)
|
||||
{
|
||||
@@ -142,7 +142,7 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
|
||||
private void DragRight(double scale, DesignerItemViewModelBase item, SelectionService selectionService)
|
||||
{
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item).Cast<DesignerItemViewModelBase>();
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item, false).Cast<DesignerItemViewModelBase>();
|
||||
|
||||
double groupLeft = item.Left;
|
||||
foreach (DesignerItemViewModelBase groupItem in groupItems)
|
||||
@@ -157,7 +157,7 @@ namespace AIStudio.Wpf.DiagramDesigner.Controls
|
||||
|
||||
private void DragBottom(double scale, DesignerItemViewModelBase item, SelectionService selectionService)
|
||||
{
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item).Cast<DesignerItemViewModelBase>();
|
||||
IEnumerable<DesignerItemViewModelBase> groupItems = selectionService.GetGroupMembers(item, false).Cast<DesignerItemViewModelBase>();
|
||||
double groupTop = item.Top;
|
||||
foreach (DesignerItemViewModelBase groupItem in groupItems)
|
||||
{
|
||||
|
||||
@@ -415,6 +415,13 @@
|
||||
</MultiDataTrigger.Conditions>
|
||||
<Setter TargetName="PART_ResizeDecorator" Property="Visibility" Value="Visible"/>
|
||||
</MultiDataTrigger>
|
||||
<MultiDataTrigger>
|
||||
<MultiDataTrigger.Conditions>
|
||||
<Condition Value="True" Binding="{Binding IsSelected}"/>
|
||||
<Condition Value="True" Binding="{Binding AlwayForResized}"/>
|
||||
</MultiDataTrigger.Conditions>
|
||||
<Setter TargetName="PART_ResizeDecorator" Property="Visibility" Value="Visible"/>
|
||||
</MultiDataTrigger>
|
||||
<Trigger Property="IsMouseOver"
|
||||
Value="true">
|
||||
<Setter TargetName="PART_ConnectorDecorator" Property="Visibility" Value="Visible"/>
|
||||
|
||||
@@ -315,6 +315,24 @@ namespace AIStudio.Wpf.DiagramDesigner
|
||||
|
||||
public bool ShowArrow { get; set; } = true;
|
||||
|
||||
public bool ShowResized
|
||||
{
|
||||
get; set;
|
||||
}
|
||||
|
||||
private bool alwayForResized;
|
||||
public bool AlwayForResized
|
||||
{
|
||||
get
|
||||
{
|
||||
return alwayForResized;
|
||||
}
|
||||
set
|
||||
{
|
||||
SetProperty(ref alwayForResized, value);
|
||||
}
|
||||
}
|
||||
|
||||
private bool enabledForConnection = true;
|
||||
public bool EnabledForConnection
|
||||
{
|
||||
|
||||
@@ -48,7 +48,7 @@ namespace AIStudio.Wpf.DiagramDesigner
|
||||
}
|
||||
}
|
||||
|
||||
internal List<IGroupable> GetGroupMembers(IGroupable item)
|
||||
internal List<IGroupable> GetGroupMembers(IGroupable item, bool withchildren=true)
|
||||
{
|
||||
IEnumerable<IGroupable> list = DiagramViewModel.Items.OfType<IGroupable>();
|
||||
IGroupable rootItem = GetRoot(list, item);
|
||||
@@ -56,7 +56,18 @@ namespace AIStudio.Wpf.DiagramDesigner
|
||||
{
|
||||
return new List<IGroupable>();
|
||||
}
|
||||
return GetGroupMembers(list, rootItem);
|
||||
|
||||
if (rootItem.IsGroup)//分组状态下,获取全部成员
|
||||
{
|
||||
return GetGroupMembers(list, rootItem);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (withchildren)
|
||||
return GetGroupMembers(list, item);//普通的Parent关系,获取其Children
|
||||
else
|
||||
return new List<IGroupable>() { item };
|
||||
}
|
||||
}
|
||||
|
||||
internal IGroupable GetGroupRoot(IGroupable item)
|
||||
@@ -98,5 +109,7 @@ namespace AIStudio.Wpf.DiagramDesigner
|
||||
|
||||
return groupMembers;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -172,7 +172,7 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
|
||||
public MindDiagramViewModel()
|
||||
{
|
||||
MindNode level1node = new MindNode(this) { Left = 200, Top = 200, Text = "思维导图" };
|
||||
MindNode level1node = new MindNode(this) { Root = this, Id = Guid.NewGuid(), Left = 200, Top = 200, Text = "思维导图" };
|
||||
level1node.InitLayout(true);
|
||||
Items.Add(level1node);
|
||||
level1node.IsSelected = true;
|
||||
|
||||
@@ -54,6 +54,7 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
base.Init(root);
|
||||
|
||||
EnabledForConnection = false;
|
||||
AlwayForResized = true;
|
||||
|
||||
AddChildCommand = (Root as IMindDiagramViewModel)?.AddChildCommand;
|
||||
AddParentCommand = (Root as IMindDiagramViewModel)?.AddParentCommand;
|
||||
@@ -100,22 +101,6 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
return mindNodeModel;
|
||||
}
|
||||
|
||||
public override void AddToSelection(bool selected)
|
||||
{
|
||||
if (NodeLevel == 0)
|
||||
{
|
||||
base.AddToSelection(selected);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
foreach (SelectableDesignerItemViewModelBase item in Root.SelectedItems.ToList())
|
||||
item.IsSelected = false;
|
||||
|
||||
this.IsSelected= true;
|
||||
}
|
||||
}
|
||||
|
||||
#region 属性
|
||||
public IMindLayout MindLayout
|
||||
{
|
||||
@@ -389,11 +374,14 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
this.Children.Add(item);
|
||||
}
|
||||
item.Parent = this;
|
||||
item.ParentId = this.Id;
|
||||
item.InitLayout(true);
|
||||
|
||||
ConnectionViewModel connector = MindLayout?.GetOrSetConnectionViewModel(this, item);
|
||||
Root?.DirectAddItemCommand.Execute(new SelectableDesignerItemViewModelBase[] { item, connector });
|
||||
connector.ZIndex = -1;
|
||||
connector.IsSelected = false;
|
||||
item.IsSelected = false;
|
||||
this.IsSelected = true;
|
||||
}
|
||||
|
||||
@@ -450,14 +438,9 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
{
|
||||
if (e is ValuePropertyChangedEventArgs valuePropertyChangedEventArgs)
|
||||
{
|
||||
if (NodeLevel == 0)
|
||||
{
|
||||
//LayoutUpdated();
|
||||
}
|
||||
else
|
||||
if (NodeLevel > 0 && IsSelected)
|
||||
{
|
||||
UpdateOffsetX((double)valuePropertyChangedEventArgs.OldValue, (double)valuePropertyChangedEventArgs.NewValue);
|
||||
//LayoutUpdated();
|
||||
}
|
||||
}
|
||||
break;
|
||||
@@ -466,14 +449,9 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
{
|
||||
if (e is ValuePropertyChangedEventArgs valuePropertyChangedEventArgs)
|
||||
{
|
||||
if (NodeLevel == 0)
|
||||
{
|
||||
//LayoutUpdated();
|
||||
}
|
||||
else
|
||||
if (NodeLevel > 0 && IsSelected)
|
||||
{
|
||||
UpdateOffsetY((double)valuePropertyChangedEventArgs.OldValue, (double)valuePropertyChangedEventArgs.NewValue);
|
||||
//LayoutUpdated();
|
||||
}
|
||||
}
|
||||
break;
|
||||
@@ -487,6 +465,14 @@ namespace AIStudio.Wpf.Mind.ViewModels
|
||||
}
|
||||
}
|
||||
|
||||
public override void AddToSelection(bool selected)
|
||||
{
|
||||
foreach (SelectableDesignerItemViewModelBase item in Root.SelectedItems.ToList())
|
||||
item.IsSelected = false;
|
||||
|
||||
Root.SelectedItems.Clear();
|
||||
IsSelected = selected;
|
||||
}
|
||||
#region 布局相关
|
||||
public MindNode GetLevel1Node()
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user