FlowChart.NET version 6.8 contains the following new features and improvements -
Spatial indexSet the EnableSpatialIndex property of Diagram to create an index of item positions for faster hit-testing and viewport clipping queries. This should greatly improve user interaction and rendering speed for diagrams containing tens of thousands or more items.
// it will take some time to populate the diagram with a million nodes,
// but subsequent redraws and hit-tests should be very fast
diagram.ValidityChecks = false;
diagram.SelectAfterCreate = false;
for (int c = 0; c < 1000; c++)
{
for (int r = 0; r < 1000; r++)
{
var node = diagram.Factory.CreateShapeNode(
20 + c * 40, 20 + r * 40, 25, 25);
node.Text = diagram.Nodes.Count.ToString();
}
}
diagram.ResizeToFitItems(20);
diagram.EnableSpatialIndex = true;
diagramView.Diagram = diagram;
Note that rendering speed improves only when showing a smaller part of the diagram inside DiagramView's viewport. Rendering a lot of items at small zoom levels or in overview's fit-all mode will still need a lot of processing, so you might want to apply constraints on minimal zoom level of diagram view and overview controls for large diagrams.
Pattern routerNew PatternRouter class routes links by applying patterns of segment and turn sequences and accepting them when resulting paths do not cross nodes. A path is accepted if its final segment ends in target point and is orthogonal to respective side of target node. If there are several possible paths, the router selects the shortest one. The MinimumDistance property specifies minimum allowed distance of link segments from nodes. The PreferredDistance property specifies distance of first or last link bend from associated node. PatternRouter includes several predefined patterns designed to create consistent-looking paths, and allows creation of custom patterns. Custom patterns can be defined as sequence of RouteStep objects specifying whether the path advances by relative or absolute distance, or changes direction:
var rightZigzag = new RoutePattern();
rightZigzag.Steps.Add(
new RouteStep(RouteStepKind.AdvanceRelative, 0.5f));
rightZigzag.Steps.Add(
new RouteStep(RouteStepKind.TurnRight));
rightZigzag.Steps.Add(
new RouteStep(RouteStepKind.AdvanceRelative, 1));
rightZigzag.Steps.Add(
new RouteStep(RouteStepKind.TurnLeft));
rightZigzag.Steps.Add(
new RouteStep(RouteStepKind.AdvanceRelative, 0.5f));
router.Patterns.Add(rightZigzag);
Composite routerThe CompositeRouter class lets you chain link routers (objects implementing ILinkRouter interface) so that a link passes through the sequence until it gets routed successfully. Diagram's default router is now set to a CompositeRouter instance containing a PatternRouter and GridRouter sequence. This applies the several standard pattern paths when possible, and otherwise routes links using the cost minimizing heuristics-based grid router.
API changes~ Suspend and Resume methods removed from ILinkRouter. Call Diagram's SuspendLinkRouter and ResumeLinkRouter methods instead.
~ Default Diagram.LinkRouter changed from QuickRouter to CompositeRouter instance.
~ bool SmartPolylineEnds property of RoutingOptions replaced by PolylineRouting enum property, which also provides an option to prevent inclined link segments for LinkShape.Polyline routes.
If anyone is interested in trying the beta version, please download this archive containing updated assembly files -
https://mindfusion.eu/_beta/fcnet68.zipAny comments, questions and general feedback are welcome.