|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.hdcookbook.grin.Feature com.hdcookbook.grin.features.Group com.hdcookbook.grin.features.SEGroup
public class SEGroup
Field Summary |
---|
Fields inherited from class com.hdcookbook.grin.Feature |
---|
name, show |
Constructor Summary | |
---|---|
SEGroup(SEShow show)
|
|
SEGroup(SEShow show,
java.lang.String name)
|
Method Summary | |
---|---|
void |
accept(SEShowVisitor visitor)
Calls the visit method corresponding to this node type. |
void |
changeFeatureReference(Feature from,
Feature to)
Change a feature reference from one feature to a new one. |
java.lang.String |
getRuntimeClassName()
Returns the class that should be constructed at Show runtime to represent this SENode. |
void |
postProcess(ShowBuilder builder)
Do any needed post-processing in this show. |
void |
scaleBy(int xScale,
int yScale,
int xOffset,
int yOffset)
Scale this node by the given scale factor, and apply the given offset. |
void |
setParts(Feature[] parts)
Set the parts that make up this group. |
void |
setup(Feature[] parts)
Called from the parser |
java.lang.String |
toString()
|
void |
writeInstanceData(GrinDataOutputStream out)
Record this node information to the binary file format. |
Methods inherited from class com.hdcookbook.grin.features.Group |
---|
addDisplayAreas, addSubgraph, createClone, destroy, getParts, getX, getY, initialize, initializeClone, markDisplayAreasChanged, needsMoreSetup, nextFrame, paintFrame, readInstanceData, resetVisibleParts, resetVisiblePartsNoAssert, setActivateMode, setSetupMode |
Methods inherited from class com.hdcookbook.grin.Feature |
---|
activate, cloneCommands, clonedReference, cloneSubgraph, deactivate, destroyClonedSubgraph, getName, isSetup, makeNewClone, resetFeature, sendFeatureSetup, setName, setup, unsetup |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public SEGroup(SEShow show)
public SEGroup(SEShow show, java.lang.String name)
Method Detail |
---|
public void setup(Feature[] parts)
public void setParts(Feature[] parts)
setParts
in class Group
public void writeInstanceData(GrinDataOutputStream out) throws java.io.IOException
SENode
writeInstanceData
in interface SENode
out
- The stream to write out.
java.io.IOException
- if error occurs.GrinDataOutputStream.writeSuperClassData(Feature)
,
GrinDataOutputStream.writeSuperClassData(RCHandler)
,
GrinDataOutputStream.writeSuperClassData(Segment)
,
GrinDataOutputStream.writeSuperClassData(Command)
public java.lang.String getRuntimeClassName()
SENode
getRuntimeClassName
in interface SENode
public void accept(SEShowVisitor visitor)
SENode
If you are defining a user-defined feature, there are some
restrictions that you'll want to follow. If your extension is
a feature that has children, then you should make it a subclass
of one of the built-in feature types, Assembly, Modifer or Group.
That's because the GRIN compiler defines visitors that need to
visit every node in the tree, but these built-in visitors don't
know about your extension types. By making your extension type
a subclass of one of the standard ones, and by making your
accept()
method call either
visitAssembly()
, visitGroup()
or
visitUserDefinedModifier()
, as appropriate,
you'll ensure that all the children get visited.
accept
in interface SENode
visitor
- SEShowVisitor object.SEShowVisitor
public void postProcess(ShowBuilder builder) throws java.io.IOException
During the post-process phase, a node can add new features to the
show, by calling ShowBuilder.addSyntheticFeature()
,
and it can insert a new feature as the parent of a given feature,
by calling ShowBuilder.injectParent()
. It can also
add segments and handlers by calling the appropriate builder methods.
When a parent is injected, the ShowBuilder calls postProcess() on all nodes automatically, including nodes that are created during the execution of postProcess() in another node.
postProcess
in interface SENode
builder
- The builder that holds state for the show
java.io.IOException
- if an error is encounteredShowBuilder.addSyntheticFeature(Feature)
,
ShowBuilder.injectParent(Feature, Feature)
public void changeFeatureReference(Feature from, Feature to)
from
, it should be
changed to refer to to
. This is called for every node
in an SEShow when SENode.injectParent
is used.
The ShowBuilder calls changeFeatureReference() on all nodes automatically, including nodes that are created during the execution of postProcess().
changeFeatureReference
in interface SENode
SENode.changeFeatureReference(Feature, Feature)
public void scaleBy(int xScale, int yScale, int xOffset, int yOffset)
scaleBy
in interface SEScalableNode
xScale
- x scale factor in millsyScale
- y scale factor in millsxOffset
- x offset in pixelsyOffset
- y offset in pixelspublic java.lang.String toString()
toString
in class Feature
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |