public abstract class DynamicComponentBase extends RenderableComponentBase implements DynamicComponent
ModelComponent.NavpanelVisibilityenforceUniqueCompositeNames, enforceUniqueNames, myNumber, myProps, NULL_OBJ, useCompactPathNamesTG_ARTICULATED, TG_DRAGGER, TG_PRESERVE_ORIENTATION, TG_SIMULATINGTRANSPARENT, TWO_DIMENSIONAL| Constructor and Description | 
|---|
| DynamicComponentBase() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addConstrainer(Constrainer c)Adds a Constrainer to the list returned by  DynamicComponent.getConstrainers(). | 
| void | addMasterAttachment(DynamicAttachment a)Add a DynamicAttachment to the list of master attachments associated
 with this component. | 
| abstract void | addSolveBlock(SparseNumberedBlockMatrix S) | 
| void | addTransformableDependencies(TransformGeometryContext context,
                            int flags)Adds to  contextany transformable components which should be
 transformed as the same time as this component. | 
| ModelComponent | copy(int flags,
    java.util.Map<ModelComponent,ModelComponent> copyMap) | 
| DynamicAttachment | getAttachment()Returns the slave attachment associated with this component, if any. | 
| java.util.List<Constrainer> | getConstrainers()Returns a list of Constrainers associated with this component. | 
| void | getInverseMass(Matrix Minv,
              Matrix M)Inverts a mass for this component. | 
| java.util.LinkedList<DynamicAttachment> | getMasterAttachments()Returns a list of the attachments for which this component is a master, or
 null if there are no such attachments. | 
| int | getSolveIndex() | 
| boolean | hasState()Queries if this component has state. | 
| boolean | isActive()Returns true if this component is active. | 
| boolean | isAttached()Returns true if this component is attached. | 
| boolean | isControllable()Returns true is this component is active, or it is attached to one
 or more other components which ultimately are attached to at least
 one active component. | 
| boolean | isDynamic()Returns true if this component is dynamic. | 
| boolean | isParametric()Returns true if the state of this component is determined parametrically;
 i.e., it is neither dynamic nor attached. | 
| boolean | removeConstrainer(Constrainer c)Removes a Constrainer from the list returned by  DynamicComponent.getConstrainers(). | 
| void | removeMasterAttachment(DynamicAttachment a)Removes a DynamicAttachment from the list of master attachments associated
 with this component. | 
| void | setAttached(DynamicAttachment attachment)Attach this component to another via a DynamicAttachment object. | 
| void | setSolveIndex(int idx) | 
| void | transformGeometry(AffineTransform3dBase X)Applies an affine transformation to the geometry of this component. | 
| void | transformGeometry(GeometryTransformer gtr,
                 TransformGeometryContext context,
                 int flags)Transforms the geometry of this component, using the geometry transformer
  gtrto transform its individual attributes. | 
createRenderProps, getRenderHints, getRenderProps, getSelection, isSelectable, numSelectionQueriesNeeded, prerender, render, setRenderProps, updateBounds, updateRenderPropscheckFlag, checkName, checkNameUniqueness, clearFlag, clone, connectToHierarchy, createTempFlag, disconnectFromHierarchy, getAllPropertyInfo, getChildren, getGrandParent, getHardReferences, getName, getNameRange, getNavpanelVisibility, getNavpanelVisibility, getNumber, getParent, getProperty, getSoftReferences, hasChildren, isConnectedToHierarchy, isFixed, isMarked, isSelected, isWritable, makeValidName, makeValidName, notifyParentOfChange, postscan, printReferences, recursivelyContained, recursivelyContains, removeTempFlag, scan, setFixed, setFlag, setMarked, setName, setNavpanelVisibility, setNavpanelVisibility, setNumber, setParent, setSelected, updateReferences, writeequals, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitaddPosImpulse, applyExternalForces, applyGravity, checkFlag, clearFlag, createMassBlock, getEffectiveMass, getEffectiveMassForces, getForce, getMass, getMass, getPosDerivative, getPosState, getPosStateSize, getVelState, getVelStateSize, isMassConstant, mulInverseEffectiveMass, resetEffectiveMass, setFlag, setForce, setPosState, setVelState, velocityLimitExceeded, zeroExternalForces, zeroForcesconnectToHierarchy, disconnectFromHierarchy, getHardReferences, getName, getNavpanelVisibility, getNumber, getParent, getSoftReferences, isFixed, isMarked, isSelected, notifyParentOfChange, postscan, scan, setFixed, setMarked, setName, setNumber, setParent, setSelected, updateReferencesgetAllPropertyInfo, getPropertygetChildren, hasChildrenisWritable, writeaddPosJacobian, addSolveBlocks, addVelJacobian, applyForces, getJacobianTypepublic DynamicAttachment getAttachment()
DynamicComponentgetAttachment in interface DynamicComponentpublic boolean isDynamic()
DynamicComponentisDynamic in interface DynamicComponentpublic void setAttached(DynamicAttachment attachment)
DynamicComponentsetAttached in interface DynamicComponentattachment - Specifies the attachment relationship between
 this component and its master(s)public boolean isActive()
DynamicComponentisActive in interface DynamicComponentpublic boolean isAttached()
DynamicComponentisAttached in interface DynamicComponentpublic boolean isParametric()
DynamicComponentisParametric in interface DynamicComponentpublic boolean isControllable()
DynamicComponentisControllable in interface DynamicComponentpublic int getSolveIndex()
getSolveIndex in interface DynamicComponentpublic void setSolveIndex(int idx)
setSolveIndex in interface DynamicComponentpublic abstract void addSolveBlock(SparseNumberedBlockMatrix S)
addSolveBlock in interface DynamicComponentpublic void getInverseMass(Matrix Minv, Matrix M)
DynamicComponentgetInverseMass in interface DynamicComponentMinv - matrix to return the inverse mass inM - matrix containing the mass to be invertedpublic void addMasterAttachment(DynamicAttachment a)
DynamicComponentaddMasterAttachment in interface DynamicComponenta - master attachment to addpublic void removeMasterAttachment(DynamicAttachment a)
DynamicComponentremoveMasterAttachment in interface DynamicComponenta - master attachment to removepublic java.util.LinkedList<DynamicAttachment> getMasterAttachments()
DynamicComponentgetMasterAttachments in interface DynamicComponentpublic java.util.List<Constrainer> getConstrainers()
DynamicComponenttransformGeometry() on this component may require some of
 its contrainers to be updated.getConstrainers in interface DynamicComponentpublic void addConstrainer(Constrainer c)
DynamicComponentDynamicComponent.getConstrainers().
 This method is intended for internal use by the Constrainer components
 themselves.addConstrainer in interface DynamicComponentc - Constrainer to add the constrainer list.public boolean removeConstrainer(Constrainer c)
DynamicComponentDynamicComponent.getConstrainers().  This method is intended for internal use by the
 Constrainer components themselves.removeConstrainer in interface DynamicComponentc - Constrainer to remove from the constrainer list.true if the constrainer was present in the list.public ModelComponent copy(int flags, java.util.Map<ModelComponent,ModelComponent> copyMap)
copy in class RenderableComponentBasepublic boolean hasState()
hasState in interface ModelComponenthasState in class ModelComponentBasetrue if this component has statepublic void transformGeometry(AffineTransform3dBase X)
TransformableGeometryTransformGeometryContext.transform (this, X, 0);
transformGeometry in interface TransformableGeometryX - affine transformation to apply to the componentpublic void addTransformableDependencies(TransformGeometryContext context, int flags)
TransformableGeometrycontext any transformable components which should be
 transformed as the same time as this component. This will generally
 include descendant components, and may also include other components to
 which this component is connected in some way.
 
 This method is generally called from with the 
 TransformGeometryContext.apply(maspack.geometry.GeometryTransformer, int) method of a 
 TransformGeometryContext.
addTransformableDependencies in interface TransformableGeometrycontext - context information, to which the dependent components
 are added.flags - specifies conditions associated with the transformationpublic void transformGeometry(GeometryTransformer gtr, TransformGeometryContext context, int flags)
TransformableGeometrygtr to transform its individual attributes. The
 context argument supplies information about what other
 components are currently being transformed, and also allows the
 requesting of update actions to be performed after all transform called
 have completed. The context is also the usual entity that calls
 this method, from within its TransformGeometryContext.apply(maspack.geometry.GeometryTransformer, int)
 method. The argument flags provides flags to specify
 various conditions associated with the the transformation. 
 At present, the available flags are TransformableGeometry.TG_SIMULATING and 
 TransformableGeometry.TG_ARTICULATED.
 This method is not usually called directly by applications. 
 Instead, it is typically called from within the 
 TransformGeometryContext.apply(maspack.geometry.GeometryTransformer, int) method of the context,
 which takes care of the various operations needed for a
 complete transform operation, including calling 
 TransformableGeometry.addTransformableDependencies(artisynth.core.modelbase.TransformGeometryContext, int) to collect other 
 components that should be transformed, calling 
 TransformableGeometry.transformGeometry(maspack.matrix.AffineTransform3dBase) for each component, notifying
 component parents that the geometry has changed, and calling
 any requested TransformGeometryActions. More details
 are given in the documentation for 
 TransformGeometryContext.apply(maspack.geometry.GeometryTransformer, int).
 
 
TransformGeometryContext provides a number of
 static convenience transform methods
 which take care of building the context and calling
 apply() for a specified set of components.
 
 
This method should not
 generally call transformGeometry() for its descendant
 components. Instead, descendants needing transformation should be
 specified by adding them to the context in the method TransformableGeometry.addTransformableDependencies(artisynth.core.modelbase.TransformGeometryContext, int).
transformGeometry in interface TransformableGeometrygtr - transformer implementing the transformcontext - context information, including what other components
 are being transformedflags - specifies conditions associated with the transformation