Css.DisplayablePropertyGroup Class Reference

Detailed Description

Some properties like background and text-shadow can have multiple renderers. When that happens, a group of those properties is created.

Inheritance diagram for Css.DisplayablePropertyGroup:
Css.DisplayableProperty

Public Member Functions

 DisplayablePropertyGroup (RenderableData data, DisplayableProperty a, DisplayableProperty b)
 
override void Paint (LayoutBox box, Renderman renderer)
 Called when a paint event occurs. Paint events don't relocate the whole UI so are quick and efficient. More...
 
override void ApplyTransform (Matrix4x4 delta, Renderman renderer)
 Transforms all the verts by the given delta matrix. Used during a Paint only. More...
 
override void OnBatchDestroy ()
 Called when the isolation batch for this property gets removed. More...
 
- Public Member Functions inherited from Css.DisplayableProperty
 DisplayableProperty (RenderableData data)
 Creates a new displayable property for the given render data. More...
 
MeshBlock GetFirstBlock (Renderman renderer)
 Gets the first rendered block of this property. Used during Paint passes. More...
 
void SetVisibility (bool visible)
 Call this when the visibility of this property as a whole changes. More...
 
void Change (string property, Value newValue)
 Called when a named css property changes. More...
 
void ClearBlocks ()
 Clears all mesh blocks that this property has allocated. More...
 
void WentOffScreen ()
 
virtual bool Render (bool first, LayoutBox box, Renderman renderer)
 Make this property visible by forcing it to redraw. More...
 
virtual void RequestPaint ()
 Requests for a paint event to occur. Note that paint events are more efficient than a layout as they only refresh the mesh colours and uvs rather than the whole mesh. More...
 
void SetBatchMaterial (Renderman renderer, Material material)
 Sets the current batches material. More...
 
void RequestLayout ()
 Requests for a layout event to occur. Note that paint events are more efficient than a layout as they only refresh the mesh colours and uvs rather than the whole mesh. More...
 
MeshBlock Add (Renderman renderer)
 
virtual void PostProcess (LayoutBox box, Renderman renderer)
 Called after a render pass. More...
 
void Isolate ()
 Isolates this property from the rest of the UI such that it can have a custom mesh/shader/texture etc. More...
 
void Include ()
 Reverses Css.DisplayableProperty.Isolate by re-including this property in the main UI batch. More...
 
bool IsIsolated ()
 Checks if this is an isolated property - that's one which is seperate and takes its own drawcall. More...
 
AtlasLocation RequireImage (AtlasEntity image)
 

Public Attributes

List< DisplayablePropertyContents =new List<DisplayableProperty>(2)
 The contents of the group. More...
 
- Public Attributes inherited from Css.DisplayableProperty
bool Visible
 True if this is currently visible on screen. More...
 
bool Isolated
 True if this property is isolated and has a seperate mesh and material from everything else. More...
 
short BlockCount
 The number of mesh blocks that this property has allocated. More...
 
RenderableData RenderData
 The parent render data that this is a property of. More...
 
bool GotBatchAlready
 Only applies to Isolated properties. Set to true when this property has allocated a UIBatch on the current layout. More...
 

Package Functions

override void NowOffScreen ()
 Called when this element goes off screen (or is removed from the DOM). More...
 
override bool NowOnScreen ()
 Called when this element goes on screen. More...
 
override void Layout (LayoutBox box, Renderman renderer)
 Called when a layout event occurs. Layout events relocate the whole UI so should be used less frequently than a paint event. More...
 

Properties

override int DrawOrder [get]
 This property's draw order. More...
 
override bool IsBackground [get]
 True if this paints across the whole background of the element. More...
 
- Properties inherited from Css.DisplayableProperty
virtual int DrawOrder [get]
 This property's draw order. More...
 
virtual bool IsBackground [get]
 True if this paints across the whole background of the element. More...
 
bool Paintable [get]
 Checks if this property can be repainted. More...
 

Additional Inherited Members

- Protected Member Functions inherited from Css.DisplayableProperty
virtual void OnChange (string property, Value newValue)
 Called when a named css property changes. More...
 
- Package Attributes inherited from Css.DisplayableProperty
UIBatch Batch
 The batch that this was allocated to. More...
 
int FirstBlockIndex
 The block index in the first buffer. With this, all blocks belonging to this property can be quickly discovered. More...
 

Constructor & Destructor Documentation

Css.DisplayablePropertyGroup.DisplayablePropertyGroup ( RenderableData  data,
DisplayableProperty  a,
DisplayableProperty  b 
)
inline

Member Function Documentation

override void Css.DisplayablePropertyGroup.ApplyTransform ( Matrix4x4  delta,
Renderman  renderer 
)
inlinevirtual

Transforms all the verts by the given delta matrix. Used during a Paint only.

Reimplemented from Css.DisplayableProperty.

override void Css.DisplayablePropertyGroup.Layout ( LayoutBox  box,
Renderman  renderer 
)
inlinepackagevirtual

Called when a layout event occurs. Layout events relocate the whole UI so should be used less frequently than a paint event.

Reimplemented from Css.DisplayableProperty.

override void Css.DisplayablePropertyGroup.NowOffScreen ( )
inlinepackagevirtual

Called when this element goes off screen (or is removed from the DOM).

Reimplemented from Css.DisplayableProperty.

override bool Css.DisplayablePropertyGroup.NowOnScreen ( )
inlinepackagevirtual

Called when this element goes on screen.

Reimplemented from Css.DisplayableProperty.

override void Css.DisplayablePropertyGroup.OnBatchDestroy ( )
inlinevirtual

Called when the isolation batch for this property gets removed.

Reimplemented from Css.DisplayableProperty.

override void Css.DisplayablePropertyGroup.Paint ( LayoutBox  box,
Renderman  renderer 
)
inlinevirtual

Called when a paint event occurs. Paint events don't relocate the whole UI so are quick and efficient.

Reimplemented from Css.DisplayableProperty.

Member Data Documentation

List<DisplayableProperty> Css.DisplayablePropertyGroup.Contents =new List<DisplayableProperty>(2)

The contents of the group.

Property Documentation

override int Css.DisplayablePropertyGroup.DrawOrder
get

This property's draw order.

override bool Css.DisplayablePropertyGroup.IsBackground
get

True if this paints across the whole background of the element.