Skip to content

Shape

Shape object. A shape object has following features:

  1. can be serialized (store and copy-paste)
  2. can have many children shapes
  3. can have multple scripts
  4. can have multiple constraints
  5. can have a manipulator
  6. has it’s own coordinate system (rotate)

Extends

Constructors

new Shape()

new Shape(): Shape

Returns

Shape

Overrides

Obj.constructor

Source

shapes.ts:327

Properties

children

children: Obj[]

Inherited from

Obj.children

Source

core/obj.ts:14


connectable

connectable: boolean

Connectable flag

Source

shapes.ts:200


constraints

constraints: Constraint[]

Shape’s constraints

Source

shapes.ts:295


containable

containable: boolean

Containable flag

Source

shapes.ts:190


containableFilter

containableFilter: string

Containable filter

Source

shapes.ts:195


description

description: string

Description of the shape

Source

shapes.ts:150


enable

enable: boolean

Enable flag

Source

shapes.ts:165


fillColor

fillColor: string

Fill color

Source

shapes.ts:245


fillStyle

fillStyle: string

Fill style

Source

shapes.ts:250


fontColor

fontColor: string

Font color

Source

shapes.ts:255


fontFamily

fontFamily: string

Font family

Source

shapes.ts:260


fontSize

fontSize: number

Font size

Source

shapes.ts:265


fontStyle

fontStyle: string

Font style

Source

shapes.ts:270


fontWeight

fontWeight: number

Font weight

Source

shapes.ts:275


height

height: number

Shape’s height

Source

shapes.ts:220


id

id: string

Inherited from

Obj.id

Source

core/obj.ts:11


left

left: number

Shape’s left position

Source

shapes.ts:205


link: string

Link

Source

shapes.ts:290


movable

movable: MovableEnum

Indicate how this shape can be moved

Source

shapes.ts:175


name

name: string

Name of the shape

Source

shapes.ts:145


opacity

opacity: number

Opacity

Source

shapes.ts:280


parent

parent: null | Obj

Inherited from

Obj.parent

Source

core/obj.ts:13


properties

properties: Property[]

Shape’s properties

Source

shapes.ts:300


proto

proto: boolean

The flag to indicate this shape is a prototype or not

Source

shapes.ts:155


rotatable

rotatable: boolean

Rotatable flag

Source

shapes.ts:185


rotate

rotate: number

Shape’s rotation angle (in degree)

Source

shapes.ts:225


roughness

roughness: number

Roughness

Source

shapes.ts:285


scripts

scripts: Script[]

Shape’s scripts

Source

shapes.ts:305


sizable

sizable: SizableEnum

Indicate how this shape can be resized

Source

shapes.ts:180


strokeColor

strokeColor: string

Stroke color

Source

shapes.ts:230


strokePattern

strokePattern: number[]

Stroke pattern

Source

shapes.ts:240


strokeWidth

strokeWidth: number

Stroke width

Source

shapes.ts:235


tags

tags: string[]

Tags

Source

shapes.ts:160


top

top: number

Shape’s top position

Source

shapes.ts:210


type

type: string

Inherited from

Obj.type

Source

core/obj.ts:12


visible

visible: boolean

Visible flag

Source

shapes.ts:170


width

width: number

Shape’s width

Source

shapes.ts:215

Accessors

bottom

get bottom(): number

Returns

number

Source

shapes.ts:455


get right(): number

Returns

number

Source

shapes.ts:451

Methods

assignStyles()

assignStyles(canvas): void

Assign styles to memoization canvas.

Parameters

canvas: MemoizationCanvas

Returns

void

Source

shapes.ts:516


canContain()

canContain(shape): boolean

Determine a given shape can be contained in this shape

Parameters

shape: Shape

Returns

boolean

Source

shapes.ts:908


containsPoint()

containsPoint(canvas, point): boolean

Determines whether this shape contains a point in GCS

Parameters

canvas: Canvas

point: number[]

Returns

boolean

Source

shapes.ts:785


draw()

draw(canvas, showDOM): void

Draw this shape

Render vs Draw

  • Render: computing geometries how to draw the shape
  • Draw: actual drawing the computed geometries of the shape on the canvas

Parameters

canvas: Canvas

showDOM: boolean= false

Returns

void

Source

shapes.ts:651


drawLink(canvas, showDOM): void

Draw link

Parameters

canvas: Canvas

showDOM: boolean= false

Returns

void

Source

shapes.ts:665


finalize()

finalize(canvas): void

Finalize shape

Parameters

canvas: Canvas

Returns

void

Source

shapes.ts:472


find()

find(pred): null | Obj

Find an shape in breath-first order

Parameters

pred

Returns

null | Obj

Inherited from

Obj.find

Source

core/obj.ts:106


findAllByQuery()

findAllByQuery(queryString): Shape[]

Find all shapes matched with the query string

Parameters

queryString: string

Returns

Shape[]

Source

shapes.ts:898


findByQuery()

findByQuery(queryString): null | Shape

Find a shape first matched with the query string

Parameters

queryString: any

Returns

null | Shape

Source

shapes.ts:885


findDepthFirst()

findDepthFirst(pred): null | Obj

Find an shape in depth-first order

Parameters

pred

Returns

null | Obj

Inherited from

Obj.findDepthFirst

Source

core/obj.ts:119


findParent()

findParent(pred): null | Obj

Find a shape along with the parent-chain

Parameters

pred

Returns

null | Obj

Inherited from

Obj.findParent

Source

core/obj.ts:132


fromJSON()

fromJSON(json): void

Import shape from JSON

Parameters

json: any

Returns

void

Overrides

Obj.fromJSON

Source

shapes.ts:414


getBoundingRect()

getBoundingRect(includeAnchorPoints): number[][]

Return a bounding rect.

Parameters

includeAnchorPoints: boolean= false

Returns

number[][]

Source

shapes.ts:712


getCenter()

getCenter(): number[]

Returns the center point

Returns

number[]

Source

shapes.ts:705


getChildrenBoundingRect()

getChildrenBoundingRect(): number[][]

Return a bounding box embracing children shapes

Returns

number[][]

Source

shapes.ts:738


getEnclosure()

getEnclosure(): number[][]

Return a enclosure

Returns

number[][]

Source

shapes.ts:772


getOutline()

getOutline(): number[][]

Return outline polygon.

Returns

number[][]

Source

shapes.ts:640


getProperty()

getProperty(name): any

Get a property object

Parameters

name: string

Returns

any

Source

shapes.ts:920


getPropertyValue()

getPropertyValue(name): any

Get a property value

Parameters

name: string

Returns

any

Source

shapes.ts:930


getRectInDCS()

getRectInDCS(canvas, includeAnchorPoints): number[][]

Return a bounding box in DOM coord.

[Note] If you want to place DOM elements over the canvas, use this method. and don’t forget to apply transform scale to the DOM element.

Parameters

canvas: Canvas

includeAnchorPoints: boolean= false

Returns

number[][]

Source

shapes.ts:751


getScript()

getScript(id): undefined | string

Get a property object

Parameters

id: string

Returns

undefined | string

Source

shapes.ts:938


getSeed()

getSeed(): number

Returns

number

Source

shapes.ts:459


getShapeAt()

getShapeAt(canvas, point, exceptions): null | Shape

Pick a shape at specific position (x, y)

Parameters

canvas: Canvas

point: number[]

exceptions: Shape[]= []

Returns

null | Shape

Source

shapes.ts:491


getViewRect()

getViewRect(canvas): number[][]

Return a view rect in GCS. View rect is a rect that includes actually drawn area which includes stroke width, arrowheads, etc. So view rect is mostly larger than bounding rect.

Parameters

canvas: Canvas

Returns

number[][]

Source

shapes.ts:725


inGroup()

inGroup(): null | Obj

Return true if this shape is contained by a group (recursively)

Returns

null | Obj

Source

shapes.ts:509


initialze()

initialze(canvas): void

Initialize shape

Parameters

canvas: Canvas

Returns

void

Source

shapes.ts:467


isDescendant()

isDescendant(obj): boolean

Test whether the given shape is a descendant

Parameters

obj: Obj

Returns

boolean

Inherited from

Obj.isDescendant

Source

core/obj.ts:142


localCoordTransform()

localCoordTransform(canvas, point, recursive): number[]

Transform local coord to parent’s coord (LCS —> parent’s LCS) if recursive=true, transform to GCS (Global coord-system).

Parameters

canvas: Canvas

point: number[]

recursive: boolean= false

Returns

number[]

Source

shapes.ts:552


localCoordTransformRev()

localCoordTransformRev(canvas, point, recursive): number[]

Transform parent’s coord to local coord (parent’s LCS —> LCS) if recursive=true, transform GCS (Global coord-system) —> LCS.

Parameters

canvas: Canvas

point: number[]

recursive: boolean= false

Returns

number[]

Source

shapes.ts:572


localTransform()

localTransform(canvas, recursive): void

Transform local context to parent’s context

Parameters

canvas: Canvas

recursive: boolean= false

Returns

void

Source

shapes.ts:536


match()

match(query): boolean

Returns true if query matches this shape

Parameters

query: object[]

Returns

boolean

Source

shapes.ts:860


overlapRect()

overlapRect(canvas, rect): boolean

Determines whether this shape overlaps a given rect

Parameters

canvas: Canvas

rect: number[][]

Returns

boolean

Source

shapes.ts:805


parseQueryString()

parseQueryString(queryString): any[]

Parse the query-string and returns a query object (JSON)

Query syntax: = [”|” ]* = [”&” ]* = | = e.g.) OuterBox, NameText, … = ”@” e.g.) @Box, @Text, @Line, … = ”#” e.g.) #label, #compartment, …

e.g.) parseQuery(“@Box|NameText|@Text&#compartment”) —> [{_type: “Box”},{name: “NameText”},{_type: “Text”, tag:“compartment”}]

Parameters

queryString: string

Returns

any[]

query object

Source

shapes.ts:835


render()

render(canvas): void

Render this shape

Render vs Draw

  • Render: computing geometries how to draw the shape
  • Draw: actual drawing the computed geometries of the shape on the canvas

Parameters

canvas: MemoizationCanvas

Returns

void

Source

shapes.ts:595


renderDefault()

renderDefault(canvas): void

Default render this shape

Parameters

canvas: MemoizationCanvas

Returns

void

Source

shapes.ts:613


renderOutline()

renderOutline(canvas): void

Render this shape’s outline

Parameters

canvas: MemoizationCanvas

Returns

void

Source

shapes.ts:618


renderOutlineDefault()

renderOutlineDefault(): number[][]

Render default outline

Returns

number[][]

Source

shapes.ts:633


resolveRefs()

resolveRefs(idMap, nullIfNotFound): void

Resolve references

Parameters

idMap: Record<string, Obj>

id to object map

nullIfNotFound: boolean= false

assign null if not found

Returns

void

Inherited from

Obj.resolveRefs

Source

core/obj.ts:47


toJSON()

toJSON(recursive, keepRefs): any

Export shape to JSON

Parameters

recursive: boolean= false

keepRefs: boolean= false

Returns

any

Overrides

Obj.toJSON

Source

shapes.ts:373


traverse()

traverse(fun, parent): void

Traverse all objects in breath-first order

Parameters

fun

parent: null | Obj= null

Returns

void

Inherited from

Obj.traverse

Source

core/obj.ts:60


traverseDepthFirst()

traverseDepthFirst(fun, parent): void

Traverse all shapes in depth-first order

Parameters

fun

parent: null | Obj= null

Returns

void

Inherited from

Obj.traverseDepthFirst

Source

core/obj.ts:74


traverseDepthFirstSequence()

traverseDepthFirstSequence(): Obj[]

Returns an array of shapes in order of traverse sequence.

Returns

Obj[]

Inherited from

Obj.traverseDepthFirstSequence

Source

core/obj.ts:97


traverseSequence()

traverseSequence(): Obj[]

Returns an array of shapes in order of traverse sequence.

Returns

Obj[]

Inherited from

Obj.traverseSequence

Source

core/obj.ts:88


update()

update(canvas): void

Update shape

Parameters

canvas: Canvas

Returns

void

Source

shapes.ts:482