Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Oaz/AvaloniaGraphControl

A graph layout panel for AvaloniaUI
https://github.com/Oaz/AvaloniaGraphControl

Last synced: about 2 months ago
JSON representation

A graph layout panel for AvaloniaUI

Awesome Lists containing this project

README

        

# AvaloniaGraphControl
A graph layout panel for [AvaloniaUI](https://github.com/AvaloniaUI/Avalonia)

## Usage
Each individual graph is displayed through the GraphPanel control included in the assembly
```xml

```

The layout is internally implemented with [MSAGL (Microsoft Automatic Graph Layout)](https://github.com/microsoft/automatic-graph-layout).

The following layout methods are available in MSAGL and can be set in the GraphPanel control independently of the graph model:
* [SugiyamaScheme](https://en.wikipedia.org/wiki/Layered_graph_drawing)
* [MDS](https://en.wikipedia.org/wiki/Stress_majorization)
* Ranking
* IncrementalLayout

The GraphPanel control and the MSAGL assemblies are bundled in [a nuget package](https://www.nuget.org/packages/AvaloniaGraphControl/).
The existing MSAGL nuget packages are dedicated to the .NET Framework and do not include any netstandard assembly.

### MVVM

The GraphPanel control leverages the [MVVM pattern used by AvaloniaUI](https://docs.avaloniaui.net/docs/next/concepts/the-mvvm-pattern/).
Each node of the graph view can be customized according to the underlying view model in the graph definition.

```xml










```

### Cross-platform

As shown in the demo, this graph panel can be used in cross-platform AvaloniaUI applications.
It was successfully tested on Linux Desktop, Windows Desktop, Android and Browser (web assembly) environments.

## Example of graph definition

```C#
public static Graph MyGraph
{
get
{
var graph = new Graph();
graph.Edges.Add(new Edge("A", "B"));
graph.Edges.Add(new Edge("A", "D"));
graph.Edges.Add(new Edge("A", "E"));
graph.Edges.Add(new Edge("B", "C"));
graph.Edges.Add(new Edge("B", "D"));
graph.Edges.Add(new Edge("D", "A"));
graph.Edges.Add(new Edge("D", "E"));
return graph;
}
}
```
![Outcome of graph example](doc/images/Simple_Graph.png?raw=true)

## Some graphs from the sample application

![Family Tree](doc/images/Family_Tree.png?raw=true)

![State Machine](doc/images/State_Machine.png?raw=true)