Skip to main content

SpringNode

@physion/app / Exports / SpringNode

Class: SpringNode

IMPORTANT: x, y and angle properties don't make sense for SpringNode.

Hierarchy

Constructors

constructor

new SpringNode(bodyNodeAid?, bodyNodeBid?, anchorA?, anchorB?, length?): SpringNode

Parameters

NameTypeDefault value
bodyNodeAidstringdefaultBodyNodeId
bodyNodeBidstringdefaultBodyNodeId
anchorAIPointundefined
anchorBIPointundefined
lengthnumberdefaultLength

Returns

SpringNode

Overrides

GraphicsNode.constructor

Properties

userData

userData: Record\<string, unknown>

Inherited from

GraphicsNode.userData


EVT_CHILD_ADDED

Static Readonly EVT_CHILD_ADDED: "childAdded"

The name of the event that is emitted whenever a child is added to this node.

The argument supplied is the child that was just added to this node.

Inherited from

GraphicsNode.EVT_CHILD_ADDED


EVT_CHILD_REMOVED

Static Readonly EVT_CHILD_REMOVED: "childRemoved"

The name of the event that is emitted whenever a child is removed from this node.

The argument supplied is the child that was just removed from this node.

Inherited from

GraphicsNode.EVT_CHILD_REMOVED


EVT_CHILD_REORDERED

Static Readonly EVT_CHILD_REORDERED: "childReordered"

The name of the event that is emitted whenever a child of this node is reordered.

The arguments supplied are: (1) The child that was just reordered (2) the old index of the child and (3) the new index of the child.

Inherited from

GraphicsNode.EVT_CHILD_REORDERED


EVT_NAME_CHANGED

Static Readonly EVT_NAME_CHANGED: "nameChanged"

The name of the event that is emitted whenever the name of this object changes.

The argument suplied is the new CoreObject.name of the object.

Inherited from

GraphicsNode.EVT_NAME_CHANGED


EVT_PROPERTY_CHANGED

Static Readonly EVT_PROPERTY_CHANGED: "propertyChanged"

The name of the event that is emitted whenever a property of this object changes.

The arguments supplied are: (1) The name of the property that has changed and (2) the new value of that property.

Inherited from

GraphicsNode.EVT_PROPERTY_CHANGED


EVT_TRANSFORM_CHANGED

Static Readonly EVT_TRANSFORM_CHANGED: "transformChanged"

The name of the event that is emitted whenever the x, y or angle properties of this Node are changed.

Note that this event is not emitted when x, y or angle properties are changed as a result of an update().

Inherited from

GraphicsNode.EVT_TRANSFORM_CHANGED

Accessors

alpha

get alpha(): number

Node's alpha

This value is between 0 (transparent) and 1.0 (opaque). This property can be considered as the "master" opacity of the node. Defaults to 1 (fully opaque)

Returns

number

Inherited from

GraphicsNode.alpha

set alpha(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.alpha


anchorA

get anchorA(): IPoint

Returns

IPoint

set anchorA(v): void

Parameters

NameType
vIPoint

Returns

void


anchorB

get anchorB(): IPoint

Returns

IPoint

set anchorB(v): void

Parameters

NameType
vIPoint

Returns

void


angle

get angle(): number

Node's angle (in degrees)

Returns

number

Overrides

GraphicsNode.angle

set angle(v): void

Parameters

NameType
vnumber

Returns

void

Overrides

GraphicsNode.angle


blendMode

get blendMode(): BLEND_MODES

Returns

BLEND_MODES

Inherited from

GraphicsNode.blendMode

set blendMode(v): void

Parameters

NameType
vBLEND_MODES

Returns

void

Inherited from

GraphicsNode.blendMode


bodyNodeA

get bodyNodeA(): undefined | BodyNode

Returns

undefined | BodyNode


bodyNodeAid

get bodyNodeAid(): string

Returns

string

set bodyNodeAid(v): void

Parameters

NameType
vstring

Returns

void


bodyNodeB

get bodyNodeB(): undefined | BodyNode

Returns

undefined | BodyNode


bodyNodeBid

get bodyNodeBid(): string

Returns

string

set bodyNodeBid(v): void

Parameters

NameType
vstring

Returns

void


childCount

get childCount(): number

Returns the number of children this node contains.

Returns

number

Inherited from

GraphicsNode.childCount


children

get children(): Node[]

Returns the children of this node.

Returns

Node[]

Inherited from

GraphicsNode.children


damping

get damping(): number

Returns

number

set damping(v): void

Parameters

NameType
vnumber

Returns

void


fillAlpha

get fillAlpha(): number

Returns

number

Inherited from

GraphicsNode.fillAlpha

set fillAlpha(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.fillAlpha


fillColor

get fillColor(): number

Returns

number

Inherited from

GraphicsNode.fillColor

set fillColor(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.fillColor


fillMatrix

get fillMatrix(): IMatrix

Returns

IMatrix

Inherited from

GraphicsNode.fillMatrix

set fillMatrix(v): void

Parameters

NameType
vIMatrix

Returns

void

Inherited from

GraphicsNode.fillMatrix


fillStyle

get fillStyle(): FillStyle

Returns

FillStyle

Inherited from

GraphicsNode.fillStyle


fillTexture

get fillTexture(): string

Returns

string

Inherited from

GraphicsNode.fillTexture

set fillTexture(v): void

Parameters

NameType
vstring

Returns

void

Inherited from

GraphicsNode.fillTexture


flags

get flags(): CoreObjectFlags

Returns

CoreObjectFlags

Inherited from

GraphicsNode.flags


graphics

get graphics(): Graphics

Returns

Graphics

Inherited from

GraphicsNode.graphics


id

get id(): string

Object's (unique) id

Note that the id of the object cannot be set (it is automatically assigned upon construction)

Returns

string

Inherited from

GraphicsNode.id


k

get k(): number

Returns

number

set k(v): void

Parameters

NameType
vnumber

Returns

void


length

get length(): number

Returns

number

set length(v): void

Parameters

NameType
vnumber

Returns

void


lineAlignment

get lineAlignment(): number

Returns

number

Inherited from

GraphicsNode.lineAlignment

set lineAlignment(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.lineAlignment


lineAlpha

get lineAlpha(): number

The line alpha used when drawing the graphics.

Returns

number

Inherited from

GraphicsNode.lineAlpha

set lineAlpha(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.lineAlpha


lineColor

get lineColor(): number

The line color used when drawing the graphics.

Returns

number

Inherited from

GraphicsNode.lineColor

set lineColor(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.lineColor


lineNative

get lineNative(): boolean

Returns

boolean

Inherited from

GraphicsNode.lineNative

set lineNative(v): void

Parameters

NameType
vboolean

Returns

void

Inherited from

GraphicsNode.lineNative


lineStyle

get lineStyle(): LineStyle

Returns

LineStyle

Inherited from

GraphicsNode.lineStyle


lineWidth

get lineWidth(): number

The line width used when drawing the graphics.

Returns

number

Inherited from

GraphicsNode.lineWidth

set lineWidth(v): void

Parameters

NameType
vnumber

Returns

void

Inherited from

GraphicsNode.lineWidth


metaObject

get metaObject(): MetaObject

Returns the MetaObject that describes this class

Returns

MetaObject

Overrides

GraphicsNode.metaObject


name

get name(): string

The object's name

The object's name is a free text value which defaults to an empty string.

Note that when the name of the object changes, the CoreObject.EVT_NAME_CHANGED signal will be emitted.

Returns

string

Inherited from

GraphicsNode.name

set name(v): void

Parameters

NameType
vstring

Returns

void

Inherited from

GraphicsNode.name


parent

get parent(): undefined | Node

Returns the parent of this node (or undefined if this node has no parent).

Returns

undefined | Node

Inherited from

GraphicsNode.parent


scene

get scene(): undefined | Scene

Returns

undefined | Scene


scripts

get scripts(): string[]

Returns

string[]

Inherited from

GraphicsNode.scripts

set scripts(v): void

Parameters

NameType
vstring[]

Returns

void

Inherited from

GraphicsNode.scripts


width

get width(): number

Returns

number

set width(v): void

Parameters

NameType
vnumber

Returns

void


x

get x(): number

Node's x position (in meters)

Returns

number

Overrides

GraphicsNode.x

set x(v): void

Parameters

NameType
vnumber

Returns

void

Overrides

GraphicsNode.x


y

get y(): number

Node's y position (in meters)

Returns

number

Overrides

GraphicsNode.y

set y(v): void

Parameters

NameType
vnumber

Returns

void

Overrides

GraphicsNode.y

Methods

addChild

addChild(child): boolean

Adds the given child to this node.

If the given child is already contained in this node or it already has a Node.parent then this method will fail (false will be returned).

Otherwise the child will be added to this node and the Node.EVT_CHILD_ADDED signal will be emitted.

Parameters

NameTypeDescription
childNodeThe child to be added to this node.

Returns

boolean

True on success otherwise false.

Inherited from

GraphicsNode.addChild


addChildren

addChildren(children): void

Convenience method for adding multiple children to this node.

Parameters

NameType
childrenNode[]

Returns

void

Inherited from

GraphicsNode.addChildren


autoAdjustFillTexture

autoAdjustFillTexture(): void

Returns

void

Inherited from

GraphicsNode.autoAdjustFillTexture


canAddChild

canAddChild(child): boolean

Returns true if the given child can be added to this node

Parameters

NameType
childNode

Returns

boolean

Inherited from

GraphicsNode.canAddChild


canRemoveChild

canRemoveChild(child): boolean

Returns true if the given child can be removed from this node

Parameters

NameType
childNode

Returns

boolean

Inherited from

GraphicsNode.canRemoveChild


childIndex

childIndex(child): number

Returns the index of the given child (or -1 if child is not contained in thie node).

Parameters

NameType
childNode

Returns

number

Inherited from

GraphicsNode.childIndex


clone

clone(): Node

Creates and returns a clone of this node.

The clone returned will have the same property values as this node except from its CoreObject.id.

Returns

Node

A clone of this node.

Inherited from

GraphicsNode.clone


containsChild

containsChild(child): boolean

Returns true if this node contains the given child

Parameters

NameType
childNode

Returns

boolean

Inherited from

GraphicsNode.containsChild


destroy

destroy(): void

Returns

void

Inherited from

GraphicsNode.destroy


findAncestorByClassName

findAncestorByClassName(className): undefined | Node

Parameters

NameType
classNamestring

Returns

undefined | Node

Inherited from

GraphicsNode.findAncestorByClassName


findChildById

findChildById(id): undefined | Node

Finds and returns the child with the given id.

Parameters

NameTypeDescription
idstringThe CoreObject.id of the child to search for.

Returns

undefined | Node

The child with the given id or undefined if no such child exists.

Inherited from

GraphicsNode.findChildById


findChildByName

findChildByName(name): undefined | Node

Finds and returns the first child node with the given name.

Parameters

NameTypeDescription
namestringThe CoreObject.name of the child to search for.

Returns

undefined | Node

The first child with the given name or undefined if no such child exists.

Inherited from

GraphicsNode.findChildByName


findDescendantById

findDescendantById(id): undefined | Node

Finds and returns the descendant with the given id.

Parameters

NameTypeDescription
idstringThe CoreObject.id of the descendant to search for.

Returns

undefined | Node

The descendant with the given id or undefined if no such descendant exists.

Inherited from

GraphicsNode.findDescendantById


findSceneAssetById

findSceneAssetById(id): undefined | Asset

Finds and returns the asset specified by the given id. Note that the node needs to be parented to a Scene for this method to work.

Parameters

NameTypeDescription
idstringThe id of the asset to search for.

Returns

undefined | Asset

The matched Asset of undefined if no such asset exists in the scene.

Inherited from

GraphicsNode.findSceneAssetById


findSceneNode

findSceneNode(): undefined | Node

Uses the Node.findAncestorByClassName to find the Scene that this node is added to. If this node has not yet been added to a scene then this method will return undefined.

Returns

undefined | Node

Inherited from

GraphicsNode.findSceneNode


fromScreen

fromScreen(position, from?, skipUpdate?): IPointData

Parameters

NameType
positionIPoint
from?Node
skipUpdate?boolean

Returns

IPointData

Inherited from

GraphicsNode.fromScreen


getAncestors

getAncestors(): Node[]

Returns the ancestors of this node

Returns

Node[]

Inherited from

GraphicsNode.getAncestors


getAssetIds

getAssetIds(): string[]

Returns the ids of the assets that are used by this Node.

Returns

string[]

The ids of the assets that are used by this Node.

Inherited from

GraphicsNode.getAssetIds


getBoundingRect

getBoundingRect(): Rectangle

Returns the bounding rectangle of this node in local coordinates.

The default implementation returns the local bounds of the underlying PIXI container but subclasses can re-implement this method to return their custom bounding rectangle.

Returns

Rectangle

Inherited from

GraphicsNode.getBoundingRect


getDescendants

getDescendants(reversed?): Node[]

Returns the descendants of this node.

A descendant is node that has this node as an ancestor. Consider for example the following tree of nodes:

  • NodeA
    • NodeB
      • NodeD
      • NodeE
    • NodeC

If we ask for the descendants of NodeA we'll get back: [NodeB, NodeD, NodeE, NodeC]

If reversed is set to true then this method will return the reversed descendants. For the example above, that would be: [NodeC, NodeE, NodeD, NodeB, NodeA]. Note that the first item of the reversed descendants has the highest z-index.

Parameters

NameTypeDefault value
reversedbooleanfalse

Returns

Node[]

A list of this node's descendants

Inherited from

GraphicsNode.getDescendants


getExtras

getExtras(): any

Returns any extra data that this object needs to save during serialization.

In some cases an object might need to save some extra data without necessarily this extra data being part of its state (e.g. the AssetsLibrary of a Scene). In these cases subclasses can re-implement this method and return the data required.

The default implementation returns undefined meaning that no extra data needs to be saved during serialization.

Returns

any

Inherited from

GraphicsNode.getExtras


getFilteredDescendants

getFilteredDescendants\<T>(cls): T[]

Returns the descendants of this node that are instances of the class cls

Type parameters

NameType
Textends Node

Parameters

NameType
clsConstructor\<T>

Returns

T[]

Inherited from

GraphicsNode.getFilteredDescendants


getFilteredDescendantsByClassName

getFilteredDescendantsByClassName(className): Node[]

Returns the descendants of this node that are instances of the class className

Parameters

NameType
classNamestring

Returns

Node[]

Inherited from

GraphicsNode.getFilteredDescendantsByClassName


getLocalTransform

getLocalTransform(): Matrix

Returns a copy of this node's (local) transformation matrix.

Returns

Matrix

Inherited from

GraphicsNode.getLocalTransform


getNodeScript

getNodeScript(assetId): undefined | NodeScript

Returns the NodeScript that corresponds to the given asset id.

Parameters

NameType
assetIdstring

Returns

undefined | NodeScript

Inherited from

GraphicsNode.getNodeScript


getNodeScriptByClassName

getNodeScriptByClassName(className): undefined | NodeScript

Returns the NodeScript that corresponds to the given class name.

Parameters

NameType
classNamestring

Returns

undefined | NodeScript

Inherited from

GraphicsNode.getNodeScriptByClassName


getNodeScripts

getNodeScripts(): NodeScript[]

Returns all NodeScripts of this Node.

Returns

NodeScript[]

Inherited from

GraphicsNode.getNodeScripts


getPosition

getPosition(): IPoint

Convenience method which returns the node's position as a x,y object

Returns

IPoint

Inherited from

GraphicsNode.getPosition


getSceneBoundingRect

getSceneBoundingRect(): Rectangle

Returns the bounding rect of this node in scene coordinates.

Returns

Rectangle

Inherited from

GraphicsNode.getSceneBoundingRect


getScenePosition

getScenePosition(): IPoint

Returns the Node's position in Scene coordinates.

Returns

IPoint

Inherited from

GraphicsNode.getScenePosition


getSceneTransform

getSceneTransform(): Matrix

Returns a copy of this node's scene transformation matrix. Use this matrix to map coordinates from this node's local coordinate system to the scene's coordinate system. To map coordinates from the scene, you must first invert the returned matrix.

Unlike getLocalTransform(), which returns only the local transformation, this function includes the node's (and any parents') position, and all the transfomation properties.

Returns

Matrix

Inherited from

GraphicsNode.getSceneTransform


getShape

getShape(): Polygon

Returns the shape of this Node in local coordinates.

Note that the returned shape might be empty.

The shape of a Node is used for many things, including boolean operations and selection.

The default implementation calls getBoundingRect() to return a simple rectangular shape, but subclasses can reimplement this function to return a more accurate shape for non-rectangular items.

Returns

Polygon

Overrides

GraphicsNode.getShape


getSnapPoints

getSnapPoints(snapMode): ISnapPoint[]

Snap Points

Parameters

NameType
snapModenumber

Returns

ISnapPoint[]

Overrides

GraphicsNode.getSnapPoints


getState

getState(minified?): any

Returns this object's state

The object's state is an object containing key/value pairs corresponding to this object's properties. For example:

{
id: "Ssba4ch5ruok",
name: "Circle",
radius: 2,
// ...
}

To avoid including properties that are currently in their default value you can set minified = true when calling getState.

Note that read-only properties are not part of the object's state (with the exception of the id)

Parameters

NameTypeDefault valueDescription
minifiedbooleanfalseWhether to return a minified state or not

Returns

any

Inherited from

GraphicsNode.getState


getTransformedShape

getTransformedShape(): Polygon

Returns the shape of this Node in scene coordinates.

Note that the returned shape might be empty.

Returns

Polygon

Inherited from

GraphicsNode.getTransformedShape


getWorldAnchorA

getWorldAnchorA(): undefined | IPoint

Returns the "world anchor A" of this SpringNode (which might be undefined)

Returns

undefined | IPoint


getWorldAnchorB

getWorldAnchorB(): undefined | IPoint

Returns the "world anchor B" of this SpringNode (which might be undefined)

Returns

undefined | IPoint


index

index(): number

Returns the index of this Node relatively to its parent. If this Node has no parent then -1 is returned.

Returns

number

Inherited from

GraphicsNode.index


initGraphicsNode

initGraphicsNode(x, y, angle, lineStyle?, fillStyle?): void

Parameters

NameType
xnumber
ynumber
anglenumber
lineStyle?LineStyle
fillStyle?FillStyle

Returns

void

Inherited from

GraphicsNode.initGraphicsNode


initNode

initNode(x?, y?, angle?): void

Convenience method for setting node's Node.x, Node.y and Node.angle

Parameters

NameTypeDefault value
xnumber0
ynumber0
anglenumber0

Returns

void

Inherited from

GraphicsNode.initNode


insertChild

insertChild(child, index): boolean

Parameters

NameType
childNode
indexnumber

Returns

boolean

Inherited from

GraphicsNode.insertChild


isDestroyed

isDestroyed(): boolean

Returns true if this node has been destroyed via destroy(). A destroyed Node should not be used.

Returns

boolean

Inherited from

GraphicsNode.isDestroyed


isSelected

isSelected(): boolean

Returns true if this node is currently selected.

Returns

boolean

Inherited from

GraphicsNode.isSelected


move

move(d): void

Moves this node by the given d.x, d.y

Parameters

NameType
dIPoint

Returns

void

Inherited from

GraphicsNode.move


removeAllChildren

removeAllChildren(): void

Convenience method which removes all children of this node

Returns

void

Inherited from

GraphicsNode.removeAllChildren


removeChild

removeChild(child): boolean

Parameters

NameType
childNode

Returns

boolean

Inherited from

GraphicsNode.removeChild


removeChildren

removeChildren(children): void

Convenience method for removing multiple children from this node.

Parameters

NameType
childrenNode[]

Returns

void

Inherited from

GraphicsNode.removeChildren


reorderChild

reorderChild(child, newIndex): boolean

Moves a child node to a different position (order) among the other children If the operation is successul then the EVT_CHILD_REORDERED signal will be emitted

Parameters

NameTypeDescription
childNodeThe child node to be moved
newIndexnumberThe new index where the child node will be moved

Returns

boolean

true on success otherwise false

Inherited from

GraphicsNode.reorderChild


setExtras

setExtras(_x): boolean

Sets any extra data that this object needs during de-serialization.

Returns true on success, otherwise returns false.

The default implementation does nothing and returns true.

Parameters

NameType
_xany

Returns

boolean

Inherited from

GraphicsNode.setExtras


setFlag

setFlag(flag, on?): void

Parameters

NameTypeDefault value
flagCoreObjectFlagsundefined
onbooleantrue

Returns

void

Inherited from

GraphicsNode.setFlag


setPosition

setPosition(v): void

Convenience method for setting the node's position to the given x,y

Parameters

NameType
vIPoint

Returns

void

Inherited from

GraphicsNode.setPosition


setScenePosition

setScenePosition(v): void

Sets the Node's scene position.

Parameters

NameType
vIPoint

Returns

void

Inherited from

GraphicsNode.setScenePosition


setSelected

setSelected(selected): void

Parameters

NameType
selectedboolean

Returns

void

Inherited from

GraphicsNode.setSelected


setState

setState(state, updateId?): boolean

Sets the object's state

Parameters

NameTypeDefault valueDescription
stateanyundefinedThe state to be set
updateIdbooleantrueWhether to also update the id property

Returns

boolean

True on success otherwise false

Inherited from

GraphicsNode.setState


testFlag

testFlag(flag): boolean

Parameters

NameType
flagCoreObjectFlags

Returns

boolean

Inherited from

GraphicsNode.testFlag


toGlobal

toGlobal(position): Point

Parameters

NameType
positionIPoint

Returns

Point

Inherited from

GraphicsNode.toGlobal


toLocal

toLocal(position): Point

Parameters

NameType
positionIPoint

Returns

Point

Inherited from

GraphicsNode.toLocal


toScreen

toScreen(position, skipUpdate?): IPointData

Parameters

NameType
positionIPoint
skipUpdate?boolean

Returns

IPointData

Inherited from

GraphicsNode.toScreen


update

update(delta): void

Updates this node.

The default update will do the following:

  • If this node has a script attached to it then it will call the script's update method
  • Call update for each child of this node.

Parameters

NameTypeDescription
deltanumberNot currently used

Returns

void

Overrides

GraphicsNode.update