调试中

This commit is contained in:
艾竹
2023-02-21 23:23:03 +08:00
parent c227076076
commit 6d1f2a83fa
9 changed files with 1282 additions and 54 deletions

View File

@@ -31,7 +31,6 @@ namespace AIStudio.Wpf.Mind.Helpers
mindNode.ColorViewModel.LineColor.Color = Color.FromRgb(0x73, 0xa1, 0xbf);
mindNode.FontViewModel.FontColor = Colors.White;
mindNode.FontViewModel.FontSize = 15;
mindNode.Spacing = new SizeBase(50, 15);
mindNode.ShapeViewModel.SinkMarker.PathStyle = ArrowPathStyle.None;
mindNode.ShapeViewModel.SinkMarker.SizeStyle = ArrowSizeStyle.VerySmall;
@@ -80,14 +79,13 @@ namespace AIStudio.Wpf.Mind.Helpers
{
if (mindNode == null) return;
mindNode.LayoutUpdating = true;
mindNode.GetLevel1Node().LayoutUpdating = true;
var size = MeasureOverride(mindNode);
ArrangeOverride(mindNode);
mindNode.Root.BringToFrontCommand.Execute(new SelectableDesignerItemViewModelBase[] { mindNode });
mindNode.Root?.ReconnectLinksToClosestPorts();
mindNode.LayoutUpdating = false;
mindNode.GetLevel1Node().LayoutUpdating = false;
}
@@ -104,13 +102,11 @@ namespace AIStudio.Wpf.Mind.Helpers
else
{
var childrensizes = mindNode.Children.Select(p => MeasureOverride(p, mindNode.IsExpanded && isExpanded)).ToArray();
sizewithSpacing = new SizeBase(sizewithSpacing.Width * 0.5 + childrensizes.Max(p => p.Width), sizewithSpacing.Height + childrensizes.Sum(p => p.Height));
sizewithSpacing = new SizeBase(Math.Max(sizewithSpacing.Width, sizewithSpacing.Width * 0.5 + childrensizes.Max(p => p.Width)), sizewithSpacing.Height + childrensizes.Sum(p => p.Height));
}
}
mindNode.DesiredSize = isExpanded ? sizewithSpacing : new SizeBase(0, 0);
mindNode.Visible = isExpanded;
var connectors = mindNode.Root?.Items.OfType<ConnectionViewModel>().Where(p => p.SinkConnectorInfoFully?.DataItem == mindNode).ToList();
connectors?.ForEach(p => p.Visible = mindNode.Visible);
return mindNode.DesiredSize;
}
@@ -131,6 +127,11 @@ namespace AIStudio.Wpf.Mind.Helpers
left += child.DesiredSize.Width;
ArrangeOverride(child);
var connect = mindNode.Root?.Items.OfType<ConnectionViewModel>().FirstOrDefault(p => p.SourceConnectorInfo?.DataItem == mindNode && p.SinkConnectorInfoFully?.DataItem == child);
connect?.SetSourcePort(mindNode.FirstConnector);
connect?.SetSinkPort(child.TopConnector);
connect.Visible = child.Visible;
}
}
}
@@ -148,6 +149,11 @@ namespace AIStudio.Wpf.Mind.Helpers
top += child.DesiredSize.Height;
ArrangeOverride(child);
var connect = mindNode.Root?.Items.OfType<ConnectionViewModel>().FirstOrDefault(p => p.SourceConnectorInfo?.DataItem == mindNode && p.SinkConnectorInfoFully?.DataItem == child);
connect?.SetSourcePort(mindNode.BottomConnector);
connect?.SetSinkPort(child.LeftConnector);
connect.Visible = child.Visible;
}
}
}