NodifyAvalonia

February 14, 2026 ยท View on GitHub

NuGet NuGet License C#

This is a direct port of Nodify by miroiu to Avalonia.

A collection of highly performant controls for node-based editors designed for MVVM.

The goal of the port is to keep the codebase as similar to the original code as possible, to the point, where merges from the upstream are not a problem.

๐Ÿš€ Examples of node-based applications

๐Ÿ”ถ A canvas application where you can draw and connect shapes.

Examples/Nodify.Shapes

โžœ Open a WASM ๐ŸŒ browser version of the shapes demo in your browser, without downloading! ๐Ÿš€

(Note: C# in a browser is still much slower than standalone desktop C#, the performance is much better when used in a standalone application.)

Canvas

๐ŸŽจ A playground application where you can try all the available settings.

Examples/Nodify.Playground

Playground

๐ŸŒ“ A state machine where each state represents an executable action, and each transition represents a condition for executing the next action.

Examples/Nodify.StateMachine

StateMachine

๐Ÿ’ป A simple "real-time" calculator where each node represents an operation that takes input and feeds its output into other node's input.

Examples/Nodify.Calculator

Calculator

๐Ÿ“ฅ Installation

Use the NuGet package manager to install NodifyAvalonia.

Install-Package NodifyAvalonia

And include Nodify resources:

<ResourceInclude Source="avares://Nodify/Theme.axaml" />

โš ๏ธโš ๏ธ Please do not confuse with Nodify.Avalonia which is a different package โš ๏ธโš ๏ธ

Avalonia version compatibility chart:

Nodify versionAvalonia version
6.6.011.1.0
6.5.011.1.0
6.2.011.1.0
6.1.011.1.0
6.0.011.1.0-beta-2
5.3.011.1.0-beta-2
5.2.011.1.0-beta-1

โญ๏ธ Features

  • Designed from the start to work with MVVM
  • No dependencies other than WPF Avalonia
  • Optimized for interactions with hundreds of nodes at once
  • Built-in dark and light themes
  • Selecting, zooming, panning with auto panning when close to edge
  • Select, move and connect nodes
  • Lots of configurable dependency properties
  • Ready for undo/redo
  • Example applications: ๐ŸŽจ Playground, ๐ŸŒ“ State machine, ๐Ÿ’ป Calculator, ๐Ÿ”ถ Canvas

๐Ÿ˜ฟ Unsupported Features

๐Ÿ“ Documentation

For the wiki please refer to the original miroiu's Wiki since the API is identical, but please report bugs here. However, if you find a bug, please try to check if it also occurs in the original WPF's version.

Note


Avalonia.Point should be used in place of System.Windows.Point (Anchor points).

โค๏ธ Contributing

If you find a bug in Avalonia port, bug reports, PRs are more than welcome. If you think this might be not related to Avalonia, please try to reproduce it first in the original WPF's version.