Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/miroiu/nodify
Highly performant and modular controls for node-based editors designed for data-binding and MVVM.
https://github.com/miroiu/nodify
calculator controls editor flow-based-programming good-first-issue graph graph-control infinite-canvas mvvm net6 node-editor node-graph node-network panning state-machine visual-programming vpl wpf zooming
Last synced: about 21 hours ago
JSON representation
Highly performant and modular controls for node-based editors designed for data-binding and MVVM.
- Host: GitHub
- URL: https://github.com/miroiu/nodify
- Owner: miroiu
- License: mit
- Created: 2020-08-27T15:42:36.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2025-01-24T18:24:50.000Z (28 days ago)
- Last Synced: 2025-02-13T18:00:43.499Z (8 days ago)
- Topics: calculator, controls, editor, flow-based-programming, good-first-issue, graph, graph-control, infinite-canvas, mvvm, net6, node-editor, node-graph, node-network, panning, state-machine, visual-programming, vpl, wpf, zooming
- Language: C#
- Homepage: https://miroiu.github.io/nodify
- Size: 4.78 MB
- Stars: 1,477
- Watchers: 30
- Forks: 237
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-node-based-uis - nodify - A collection of WPF controls for node based editors designed for MVVM. (.NET Libraries / Renderers)
README
# Nodify
[data:image/s3,"s3://crabby-images/cba14/cba149bae9b1bab5789f281876e8f7c15a5b8286" alt="NuGet"](https://www.nuget.org/packages/Nodify/)
[data:image/s3,"s3://crabby-images/a625b/a625be73b0e88038a35d6c85c847ed3af5fbc9f9" alt="NuGet"](https://www.nuget.org/packages/Nodify)
[data:image/s3,"s3://crabby-images/6f99e/6f99eb7f4098b886a7f7b4d013b9ff28fe7556ff" alt="License"](https://github.com/miroiu/nodify/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/fd0df/fd0dfbfd72b35d825a67e7ffbeaf8d2d1e1983c0" alt="C#"](https://github.com/miroiu/nodify/wiki)A collection of highly performant controls for node-based editors designed for MVVM.
> [!TIP]
> There is now a fantastic Avalonia port available! You can check it out [here](https://github.com/BAndysc/nodify-avalonia). Huge thanks to [BAndysc](https://github.com/BAndysc) who made this possible!## 🚀 Examples of node-based applications
🔶 A canvas application where you can draw and connect shapes.
> [Examples/Nodify.Shapes](Examples/Nodify.Shapes)
data:image/s3,"s3://crabby-images/ab1bb/ab1bbb890db3b9f62d97dd255d369a9e2b5e00aa" alt="Canvas"
🎨 A playground application where you can try all the available settings.
> [Examples/Nodify.Playground](Examples/Nodify.Playground)
data:image/s3,"s3://crabby-images/41cf3/41cf3d8ee42937956117073f18dae1156fbfce45" alt="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](Examples/Nodify.StateMachine)
data:image/s3,"s3://crabby-images/7b14e/7b14e67311728a841da8e405aad5838b7d698c6c" alt="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](Examples/Nodify.Calculator)
data:image/s3,"s3://crabby-images/4f857/4f857e853126dda1600210f803c5b05486853509" alt="Calculator"
## 📥 Installation
Use the NuGet package manager to install Nodify.```
Install-Package Nodify
```## ⭐️ Features
- Designed from the start to work with **MVVM**
- **No dependencies** other than WPF
- **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**](Examples/Nodify.Playground), 🌓 [**State machine**](Examples/Nodify.StateMachine), 💻 [**Calculator**](Examples/Nodify.Calculator), 🔶 [**Canvas**](Examples/Nodify.Shapes)
## 📝 DocumentationCheck out the [wiki](https://github.com/miroiu/nodify/wiki) and the [changelog](CHANGELOG.md) in github.
## ❤️ [Contributing](CONTRIBUTING.md)
Helping with documentation, bug reports, pull requests or anything else is very welcome.