Detailed Description

Some nodes in CPU mode have to cache their complete input in order to apply their effect. An example is blur. These are 'bitmap' nodes.

Inheritance diagram for Loonim.BitmapNode:
Loonim.TextureNode Loonim.Blur Loonim.Percentile

Public Member Functions

 BitmapNode ()
 
 BitmapNode (int src)
 
void Clear (DrawInfo info)
 
override UnityEngine.Color GetColour (double x, double y)
 Gets this nodes colour output. More...
 
override double GetWrapped (double x, double y, int wrap)
 Gets a wrapped value from this node. Range of +/- 1. More...
 
override double GetValue (double x, double y, double z)
 Gets the value from this node. This is required at a minimum. Range of +/- 1. More...
 
override double GetValue (double x, double y)
 Gets the value from this node. This is required at a minimum. Range of +/- 1. More...
 
- Public Member Functions inherited from Loonim.TextureNode
float[] Bake (int size)
 Bakes the x axis of this node as a 1D image. More...
 
void Bake (float[] values)
 Bakes the x axis of this node as a 1D image. More...
 
void Bake (Color[] values)
 Bakes the x axis of this node as a 1D image. Note that the red channel is the most important. More...
 
override string ToString ()
 
string ToString (int depth)
 
List< Material > CollectMaterials ()
 
void CollectMaterials (List< Material > into)
 
void AddSource (TextureNode source)
 Adds a new source to this node. More...
 
 TextureNode ()
 
 TextureNode (int sourceCount)
 Create a texture node with the given number of inputs. More...
 
void SubMaterialChanged ()
 Called when this nodes SubMaterialID has changed. More...
 
virtual void Draw (DrawInfo info)
 Allocates GPU drawing meta now. More...
 
virtual DrawStackNode Allocate (DrawInfo info, ref int stackID)
 Allocates GPU drawing meta now. More...
 
void PreAllocate (DrawInfo info)
 Allocates now. More...
 
void DrawGPU (DrawInfo info)
 Draws this node now (but doesn't transfer it into a texture). More...
 
void Draw (DrawInfo info, Texture2D image, ref Color[] pixels)
 Draws this node into the given texture and pixel buffer now. Note that the pixels buffer might not get used, so initially pass in null and cache the resulting one if you wish. More...
 
void DrawCPU (DrawInfo info, Color[] pixels)
 Draws this node using the CPU. More...
 
TextureNode GetLayer (int id, int count)
 Gets the node with the given ID. More...
 
virtual void Prepare (DrawInfo info)
 Gets the node ready to draw. More...
 
virtual void Read (TextureReader reader)
 Reads sources from the given reader into this node. More...
 
virtual double GetValue (double t)
 Gets the 1D value from this node. Equiv to GetValue(t,0). Required for all graph nodes. More...
 

Public Attributes

double MapX
 Maps 0 to 1 x into 0 to (Width-1). More...
 
double MapY
 Maps 0 to 1 y into 0 to (Height-1). More...
 
int Width
 Raster width. More...
 
int Height
 Raster height. More...
 
Color[] Buffer
 The raw buffer. More...
 
BitmapNode NextToClear
 Linked list of modules to clear. More...
 
- Public Attributes inherited from Loonim.TextureNode
int InstanceID
 Unique ID for this node in its parent tree. More...
 
TextureNode[] Sources
 Inputs to this node. May be null. More...
 
bool AllocateRequired =true
 True when this node changes. Note that it does not get set to true if the image draw size changes. More...
 
DrawStackNode DrawStore
 

Protected Member Functions

void Setup (DrawInfo info)
 Sets up the buffer and mapX/mapY values (used in CPU mode). More...
 
- Protected Member Functions inherited from Loonim.TextureNode
void AllocateSources (Material material, DrawInfo info, int targetStack, int count)
 

Additional Inherited Members

- Static Protected Member Functions inherited from Loonim.TextureNode
static Shader GetShader (int type, int subType)
 Gets a shader of the given node ID and it's sub-type. More...
 
static Material GetMaterial (int type, int subType)
 Gets a sub-material of the given node ID. More...
 
- Properties inherited from Loonim.TextureNode
TextureNode SourceModule [get, set]
 First input to this node. Errors if it doesn't exist. More...
 
TextureNode SourceModule1 [get, set]
 First input to this node. Errors if it doesn't exist. More...
 
TextureNode SourceModule2 [get, set]
 Second input to this node. Errors if it doesn't exist. More...
 
TextureNode SourceModule3 [get, set]
 Third input to this node. Errors if it doesn't exist. More...
 
virtual int SubMaterialID [get]
 By default, materials are named Loonim/Texture_node_id, however some nodes have "sub-materials" where they essentially have a bunch of different shaders. An example is the Blend node. More...
 
virtual int MaterialID [get]
 By default, materials are named Loonim/Texture_node_id. This allows nodes to essentially share shaders. More...
 
virtual int OutputDimensions [get]
 The dimensions of the image that gets output from this node. A constant has 0 dimensions, a graph has 1 dimension and your ordinary image node has 2. Note that they vary based on inputs; for example an ADD node could add two graphs together (resulting in a 1D output) or it could add two images together (2D output). More...
 
virtual int TypeID [get]
 A globally constant ID for a given type of module. More...
 

Constructor & Destructor Documentation

Loonim.BitmapNode.BitmapNode ( )
inline
Loonim.BitmapNode.BitmapNode ( int  src)
inline

Member Function Documentation

void Loonim.BitmapNode.Clear ( DrawInfo  info)
inline
override UnityEngine.Color Loonim.BitmapNode.GetColour ( double  x,
double  y 
)
inlinevirtual

Gets this nodes colour output.

Reimplemented from Loonim.TextureNode.

override double Loonim.BitmapNode.GetValue ( double  x,
double  y,
double  z 
)
inlinevirtual

Gets the value from this node. This is required at a minimum. Range of +/- 1.

Reimplemented from Loonim.TextureNode.

override double Loonim.BitmapNode.GetValue ( double  x,
double  y 
)
inlinevirtual

Gets the value from this node. This is required at a minimum. Range of +/- 1.

Reimplemented from Loonim.TextureNode.

override double Loonim.BitmapNode.GetWrapped ( double  x,
double  y,
int  wrap 
)
inlinevirtual

Gets a wrapped value from this node. Range of +/- 1.

Reimplemented from Loonim.TextureNode.

void Loonim.BitmapNode.Setup ( DrawInfo  info)
inlineprotected

Sets up the buffer and mapX/mapY values (used in CPU mode).

Member Data Documentation

Color [] Loonim.BitmapNode.Buffer

The raw buffer.

int Loonim.BitmapNode.Height

Raster height.

double Loonim.BitmapNode.MapX

Maps 0 to 1 x into 0 to (Width-1).

double Loonim.BitmapNode.MapY

Maps 0 to 1 y into 0 to (Height-1).

BitmapNode Loonim.BitmapNode.NextToClear

Linked list of modules to clear.

int Loonim.BitmapNode.Width

Raster width.