» Generic Nodes
This site relies heavily on Javascript. You should enable it if you want the full experience. Learn more.

Generic Nodes

There are several nodes in vvvv which are programmed in a generic way. This means that the functionality is defined once in the project GenericNodes and every developer can get over 20 nodes with just some clicks for his own data type.

You can browse the nodes and their source code here: Generic Nodes on github

Source Code Structure

Most generic nodes are pure spread operations and do not need to know anything about the type on which they operate, we called them basic nodes. However, there are some nodes which need to check whether two instances are equal in order to execute their functionality. Other, more specialized nodes need to clone an instance or calculate the distance between two instances of the type on which they operate.

We decided to sort the source code according to the method which is required for the data type, so each developer can decide which nodes make sense for his data type.

Every generic node definition should be in its own file and should be located in the folder with the name of the method it needs to operate.

Adding nodes for you own data type

First reference the GenericNodes project in your own project. Either use the nuget package or the project directly if you are working in the Addonpack.sln. Then the only thing you have to do is to copy the code from our template files and replace the string 'REPLACEME_CLASS' with your own data type and the string 'NODECATEGORY' with the category in which the nodes should land in the node browser.

For example, if your type is called BooleanShape in the category BooleanGeometry then the Cons node would look like this:

[PluginInfo(Name = "Cons",
                Category = "BooleanGeometry",
                Help = "Concatenates all input spreads to one output spread.",
                Tags = "generic, spreadop"
                )]
    public class BooleanGeometryConsNode : Cons<BooleanShape> {}

We even made an easy to use convvvverter patch which does this for you. It is also located in the GenericNodes project and called TemplateConvvvverter.v4p. Open it and follow the instructions in the patch.

Contributing a new Generic Node

If you have a generic node which you want to add to the GenericNodes project, fork the vvvv-sdk sources on github and add the generic node in the same way as the other ones:

1.) Create a .cs file named after your node in the folder with the name of the method you need for the node.

2.) Add a dummy instantiation of your node to the template files

3.) Open a pull request from your fork

If the method you need for your node doesn't exist, create a new folder and a new template file with the same naming convention.

anonymous user login

Shoutbox

~3d ago

joreg: absolutely. if it is for a repo that is public, just submit a pullrequest. otherwise please start a forum thread.

~3d ago

benjawmino: @joreg I ended up figuring out BezierSegment yesterday, so nevermind! Tell me, could a user submit a help patch? :)

~3d ago

joreg: @benjawmino please elaborate on this question a bit in a new forum thread. otherwise it is hard to answer..

~4d ago

benjawmino: so are there no splines/curves in gamma yet??

~8d ago

skyliner: wanna do drone shows or applications? then check this super cool project of our man e1n

~12d ago

NoseBleedIndustries: Thanks Joreg! The few minutes I was able to see, very good workshops!

~12d ago

joreg: @NoseBleedIndustries please give us some days, we'll have an announcement soon...

~12d ago

NoseBleedIndustries: I could not assist the Node20 (workshops ) Any Idea when we will have access to the links of the recordings?

~14d ago

bjoern: unity has c# bindings for usd, under apache license: https://github.com/Unity-Technologies/usd-unity-sdk