Struct InitContext | Data Flow Graph | 0.17.0-preview.4
docs.unity3d.com
    Show / Hide Table of Contents

    Struct InitContext

    A unique initialization context provided to a node on instantiation that allows it to internally configure its specific instance. Allows forwarding port declarations to another node instance on a port of the same type. The effect is that any external connection made to those forwarded ports are converted into a direct connection between the 3rd party and the the node forwarded to. This is invisible to anyone external to the node, and handled transparently by the node set. This system allows a node to create sub graphs that appear as single node to everyone else. Init(InitContext)

    Inherited Members
    ValueType.Equals(Object)
    ValueType.GetHashCode()
    ValueType.ToString()
    Object.Equals(Object, Object)
    Object.ReferenceEquals(Object, Object)
    Object.GetType()
    Namespace: Unity.DataFlowGraph
    Syntax
    public struct InitContext
    Remarks

    Any port forwarding actions only take effect after Init(InitContext) has returned.

    Fields

    Set

    The NodeSetAPI associated with this context.

    Declaration
    public readonly NodeSetAPI Set
    Field Value
    Type Description
    NodeSetAPI

    Properties

    Handle

    A handle uniquely identifying the currently initializing node.

    Declaration
    public NodeHandle Handle { get; }
    Property Value
    Type Description
    NodeHandle

    Methods

    EmitMessage<T, TNodeDefinition>(MessageOutput<TNodeDefinition, T>, T)

    Emit a message from yourself on a port. Everything connected to it will receive your message.

    Declaration
    public void EmitMessage<T, TNodeDefinition>(MessageOutput<TNodeDefinition, T> port, in T msg)
        where TNodeDefinition : NodeDefinition
    Parameters
    Type Name Description
    MessageOutput<TNodeDefinition, T> port
    T msg
    Type Parameters
    Name Description
    T
    TNodeDefinition

    EmitMessage<T, TNodeDefinition>(PortArray<MessageOutput<TNodeDefinition, T>>, Int32, T)

    Emit a message from yourself on a port array. Everything connected to it will receive your message.

    Declaration
    public void EmitMessage<T, TNodeDefinition>(PortArray<MessageOutput<TNodeDefinition, T>> port, int arrayIndex, in T msg)
        where TNodeDefinition : NodeDefinition
    Parameters
    Type Name Description
    PortArray<MessageOutput<TNodeDefinition, T>> port
    Int32 arrayIndex
    T msg
    Type Parameters
    Name Description
    T
    TNodeDefinition

    ForwardInput<TDefinition, TForwardedDefinition, TType>(DataInput<TDefinition, TType>, NodeHandle<TForwardedDefinition>, DataInput<TForwardedDefinition, TType>)

    See ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageInput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardInput<TDefinition, TForwardedDefinition, TType>(DataInput<TDefinition, TType> origin, NodeHandle<TForwardedDefinition> replacedNode, DataInput<TForwardedDefinition, TType> replacement)
        where TDefinition : NodeDefinition where TForwardedDefinition : NodeDefinition where TType : struct
    Parameters
    Type Name Description
    DataInput<TDefinition, TType> origin
    NodeHandle<TForwardedDefinition> replacedNode
    DataInput<TForwardedDefinition, TType> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TType

    ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageInput<TForwardedDefinition, TMsg>)

    Sets up forwarding of the given input port to another input port on a different (sub) node.

    Declaration
    public void ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg> origin, NodeHandle<TForwardedDefinition> replacedNode, MessageInput<TForwardedDefinition, TMsg> replacement)
        where TDefinition : NodeDefinition, new()
        where TForwardedDefinition : NodeDefinition
    Parameters
    Type Name Description
    MessageInput<TDefinition, TMsg> origin
    NodeHandle<TForwardedDefinition> replacedNode
    MessageInput<TForwardedDefinition, TMsg> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TMsg

    ForwardInput<TDefinition, TForwardedDefinition, TType>(PortArray<DataInput<TDefinition, TType>>, NodeHandle<TForwardedDefinition>, PortArray<DataInput<TForwardedDefinition, TType>>)

    See ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageInput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardInput<TDefinition, TForwardedDefinition, TType>(PortArray<DataInput<TDefinition, TType>> origin, NodeHandle<TForwardedDefinition> replacedNode, PortArray<DataInput<TForwardedDefinition, TType>> replacement)
        where TDefinition : NodeDefinition where TForwardedDefinition : NodeDefinition where TType : struct
    Parameters
    Type Name Description
    PortArray<DataInput<TDefinition, TType>> origin
    NodeHandle<TForwardedDefinition> replacedNode
    PortArray<DataInput<TForwardedDefinition, TType>> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TType

    ForwardInput<TDefinition, TForwardedDefinition, TMsg>(PortArray<MessageInput<TDefinition, TMsg>>, NodeHandle<TForwardedDefinition>, PortArray<MessageInput<TForwardedDefinition, TMsg>>)

    See ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageInput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardInput<TDefinition, TForwardedDefinition, TMsg>(PortArray<MessageInput<TDefinition, TMsg>> origin, NodeHandle<TForwardedDefinition> replacedNode, PortArray<MessageInput<TForwardedDefinition, TMsg>> replacement)
        where TDefinition : NodeDefinition, new()
        where TForwardedDefinition : NodeDefinition
    Parameters
    Type Name Description
    PortArray<MessageInput<TDefinition, TMsg>> origin
    NodeHandle<TForwardedDefinition> replacedNode
    PortArray<MessageInput<TForwardedDefinition, TMsg>> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TMsg

    ForwardInput<TDefinition, TForwardedDefinition, TDSLDefinition, IDSL>(DSLInput<TDefinition, TDSLDefinition, IDSL>, NodeHandle<TForwardedDefinition>, DSLInput<TForwardedDefinition, TDSLDefinition, IDSL>)

    See ForwardInput<TDefinition, TForwardedDefinition, TMsg>(MessageInput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageInput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardInput<TDefinition, TForwardedDefinition, TDSLDefinition, IDSL>(DSLInput<TDefinition, TDSLDefinition, IDSL> origin, NodeHandle<TForwardedDefinition> replacedNode, DSLInput<TForwardedDefinition, TDSLDefinition, IDSL> replacement)
        where TDefinition : NodeDefinition, IDSL where TForwardedDefinition : NodeDefinition, IDSL where TDSLDefinition : DSLHandler<IDSL>, new()
        where IDSL : class
    Parameters
    Type Name Description
    DSLInput<TDefinition, TDSLDefinition, IDSL> origin
    NodeHandle<TForwardedDefinition> replacedNode
    DSLInput<TForwardedDefinition, TDSLDefinition, IDSL> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TDSLDefinition
    IDSL

    ForwardOutput<TDefinition, TForwardedDefinition, TType>(DataOutput<TDefinition, TType>, NodeHandle<TForwardedDefinition>, DataOutput<TForwardedDefinition, TType>)

    See ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(MessageOutput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageOutput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardOutput<TDefinition, TForwardedDefinition, TType>(DataOutput<TDefinition, TType> origin, NodeHandle<TForwardedDefinition> replacedNode, DataOutput<TForwardedDefinition, TType> replacement)
        where TDefinition : NodeDefinition where TForwardedDefinition : NodeDefinition where TType : struct
    Parameters
    Type Name Description
    DataOutput<TDefinition, TType> origin
    NodeHandle<TForwardedDefinition> replacedNode
    DataOutput<TForwardedDefinition, TType> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TType

    ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(MessageOutput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageOutput<TForwardedDefinition, TMsg>)

    Sets up forwarding of the given output port to another output port on a different (sub) node.

    Declaration
    public void ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(MessageOutput<TDefinition, TMsg> origin, NodeHandle<TForwardedDefinition> replacedNode, MessageOutput<TForwardedDefinition, TMsg> replacement)
        where TDefinition : NodeDefinition, new()
        where TForwardedDefinition : NodeDefinition
    Parameters
    Type Name Description
    MessageOutput<TDefinition, TMsg> origin
    NodeHandle<TForwardedDefinition> replacedNode
    MessageOutput<TForwardedDefinition, TMsg> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TMsg

    ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(PortArray<MessageOutput<TDefinition, TMsg>>, NodeHandle<TForwardedDefinition>, PortArray<MessageOutput<TForwardedDefinition, TMsg>>)

    See ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(MessageOutput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageOutput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(PortArray<MessageOutput<TDefinition, TMsg>> origin, NodeHandle<TForwardedDefinition> replacedNode, PortArray<MessageOutput<TForwardedDefinition, TMsg>> replacement)
        where TDefinition : NodeDefinition, new()
        where TForwardedDefinition : NodeDefinition
    Parameters
    Type Name Description
    PortArray<MessageOutput<TDefinition, TMsg>> origin
    NodeHandle<TForwardedDefinition> replacedNode
    PortArray<MessageOutput<TForwardedDefinition, TMsg>> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TMsg

    ForwardOutput<TDefinition, TForwardedDefinition, TDSLDefinition, IDSL>(DSLOutput<TDefinition, TDSLDefinition, IDSL>, NodeHandle<TForwardedDefinition>, DSLOutput<TForwardedDefinition, TDSLDefinition, IDSL>)

    See ForwardOutput<TDefinition, TForwardedDefinition, TMsg>(MessageOutput<TDefinition, TMsg>, NodeHandle<TForwardedDefinition>, MessageOutput<TForwardedDefinition, TMsg>).

    Declaration
    public void ForwardOutput<TDefinition, TForwardedDefinition, TDSLDefinition, IDSL>(DSLOutput<TDefinition, TDSLDefinition, IDSL> origin, NodeHandle<TForwardedDefinition> replacedNode, DSLOutput<TForwardedDefinition, TDSLDefinition, IDSL> replacement)
        where TDefinition : NodeDefinition, IDSL where TForwardedDefinition : NodeDefinition, IDSL where TDSLDefinition : DSLHandler<IDSL>, new()
        where IDSL : class
    Parameters
    Type Name Description
    DSLOutput<TDefinition, TDSLDefinition, IDSL> origin
    NodeHandle<TForwardedDefinition> replacedNode
    DSLOutput<TForwardedDefinition, TDSLDefinition, IDSL> replacement
    Type Parameters
    Name Description
    TDefinition
    TForwardedDefinition
    TDSLDefinition
    IDSL

    RegisterForUpdate()

    Registers Handle for regular updates every time Update() is called. This only takes effect after the next Update(). Update(UpdateContext) RemoveFromUpdate()

    Declaration
    public void RegisterForUpdate()
    Remarks

    A node will automatically be removed from the update list when it is destroyed.

    Exceptions
    Type Condition
    InvalidNodeDefinitionException

    Will be thrown if the Handle does not support updating.

    InvalidOperationException

    Thrown if Handle is already registered for updating.

    RemoveFromUpdate()

    Deregisters Handle from updating every time Update() is called. This only takes effect after the next Update(). RegisterForUpdate()

    Declaration
    public void RemoveFromUpdate()
    Exceptions
    Type Condition
    InvalidOperationException

    Thrown if Handle is not registered for updating.

    SetKernelBufferSize<TGraphKernel>(TGraphKernel)

    Set the size of a Buffer<T> appearing in this node's IGraphKernel<TKernelData, TKernelPortDefinition>. Pass an instance of the node's IGraphKernel<TKernelData, TKernelPortDefinition> as the requestedSize parameter with Buffer<T> instances within it having been set using SizeRequest(Int32). Any Buffer<T> instances within the given struct that have not been set using SizeRequest(Int32) will be unaffected by the call.

    Declaration
    public void SetKernelBufferSize<TGraphKernel>(in TGraphKernel requestedSize)
        where TGraphKernel : IGraphKernel
    Parameters
    Type Name Description
    TGraphKernel requestedSize
    Type Parameters
    Name Description
    TGraphKernel

    UpdateKernelData<TKernelData>(TKernelData)

    Updates the associated TKernelData asynchronously, to be available in a IGraphKernel in the next render.

    Declaration
    public void UpdateKernelData<TKernelData>(in TKernelData data)
        where TKernelData : struct, IKernelData
    Parameters
    Type Name Description
    TKernelData data
    Type Parameters
    Name Description
    TKernelData
    Back to top
    Copyright © 2023 Unity Technologies — Terms of use
    • Legal
    • Privacy Policy
    • Cookies
    • Do Not Sell or Share My Personal Information
    • Your Privacy Choices (Cookie Settings)
    "Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
    Generated by DocFX on 18 October 2023