Freehand
Freehand
Extends
Constructors
new Freehand()
new Freehand():
Freehand
Returns
Overrides
Source
packages/core/src/shapes.ts:2996
Properties
children
children:
Obj[]
Inherited from
Source
packages/core/src/core/obj.ts:14
connectable
connectable:
boolean
Connectable flag
Inherited from
Source
packages/core/src/shapes.ts:218
constraints
constraints:
Constraint[]
Shape’s constraints
Inherited from
Source
packages/core/src/shapes.ts:333
containable
containable:
boolean
Containable flag
Inherited from
Source
packages/core/src/shapes.ts:203
containableFilter
containableFilter:
string
Containable filter
Inherited from
Source
packages/core/src/shapes.ts:208
description
description:
string
Description of the shape
Inherited from
Source
packages/core/src/shapes.ts:163
enable
enable:
boolean
Enable flag
Inherited from
Source
packages/core/src/shapes.ts:178
fillColor
fillColor:
string
Fill color
Inherited from
Source
packages/core/src/shapes.ts:263
fillStyle
fillStyle:
FillStyleEnum
Fill style
Inherited from
Source
packages/core/src/shapes.ts:268
fontColor
fontColor:
string
Font color
Inherited from
Source
packages/core/src/shapes.ts:273
fontFamily
fontFamily:
string
Font family
Inherited from
Source
packages/core/src/shapes.ts:278
fontSize
fontSize:
number
Font size
Inherited from
Source
packages/core/src/shapes.ts:283
fontStyle
fontStyle:
string
Font style
Inherited from
Source
packages/core/src/shapes.ts:288
fontWeight
fontWeight:
number
Font weight
Inherited from
Source
packages/core/src/shapes.ts:293
headTaper
headTaper:
number
Taper at the end of the path. The value must be between 0 and 1.
Source
packages/core/src/shapes.ts:2994
height
height:
number
Shape’s height
Inherited from
Source
packages/core/src/shapes.ts:238
id
id:
string
Inherited from
Source
packages/core/src/core/obj.ts:11
left
left:
number
Shape’s left position
Inherited from
Source
packages/core/src/shapes.ts:223
link
link:
string
Link
Inherited from
Source
packages/core/src/shapes.ts:323
movable
movable:
MovableEnum
Indicate how this shape can be moved
Inherited from
Source
packages/core/src/shapes.ts:188
movableParentFilter
movableParentFilter:
string
Movable parent filter
Inherited from
Source
packages/core/src/shapes.ts:213
name
name:
string
Name of the shape
Inherited from
Source
packages/core/src/shapes.ts:158
opacity
opacity:
number
Opacity
Inherited from
Source
packages/core/src/shapes.ts:298
parent
parent:
null|Obj
Inherited from
Source
packages/core/src/core/obj.ts:13
path
path:
number[][]
Inherited from
Source
packages/core/src/shapes.ts:1980
pathEditable
pathEditable:
boolean
Inherited from
Source
packages/core/src/shapes.ts:1979
properties
properties:
Property[]
Shape’s properties
Inherited from
Source
packages/core/src/shapes.ts:338
proto
proto:
boolean
The flag to indicate this shape is a prototype or not
Inherited from
Source
packages/core/src/shapes.ts:168
reference
reference:
null|Shape
A reference to shape
Inherited from
Source
packages/core/src/shapes.ts:328
rotatable
rotatable:
boolean
Rotatable flag
Inherited from
Source
packages/core/src/shapes.ts:198
rotate
rotate:
number
Shape’s rotation angle (in degree)
Inherited from
Source
packages/core/src/shapes.ts:243
roughness
roughness:
number
Roughness
Inherited from
Source
packages/core/src/shapes.ts:303
scripts
scripts:
Script[]
Shape’s scripts
Inherited from
Source
packages/core/src/shapes.ts:343
shadow
shadow:
boolean
Shadow
Inherited from
Source
packages/core/src/shapes.ts:308
shadowColor
shadowColor:
string
Shadow color
Inherited from
Source
packages/core/src/shapes.ts:313
shadowOffset
shadowOffset:
number[]
Shadow offset
Inherited from
Source
packages/core/src/shapes.ts:318
sizable
sizable:
SizableEnum
Indicate how this shape can be resized
Inherited from
Source
packages/core/src/shapes.ts:193
strokeColor
strokeColor:
string
Stroke color
Inherited from
Source
packages/core/src/shapes.ts:248
strokePattern
strokePattern:
number[]
Stroke pattern
Inherited from
Source
packages/core/src/shapes.ts:258
strokeWidth
strokeWidth:
number
Stroke width
Inherited from
Source
packages/core/src/shapes.ts:253
tags
tags:
string[]
Tags
Inherited from
Source
packages/core/src/shapes.ts:173
tailTaper
tailTaper:
number
Taper at the start of the path. The value must be between 0 and 1.
Source
packages/core/src/shapes.ts:2989
thinning
thinning:
number
Thinning
Source
packages/core/src/shapes.ts:2984
top
top:
number
Shape’s top position
Inherited from
Source
packages/core/src/shapes.ts:228
type
type:
string
Inherited from
Source
packages/core/src/core/obj.ts:12
visible
visible:
boolean
Visible flag
Inherited from
Source
packages/core/src/shapes.ts:183
width
width:
number
Shape’s width
Inherited from
Source
packages/core/src/shapes.ts:233
Accessors
bottom
getbottom():number
Returns
number
Source
packages/core/src/shapes.ts:576
right
getright():number
Returns
number
Source
packages/core/src/shapes.ts:572
Methods
assignStyles()
assignStyles(
canvas):void
Assign styles to memoization canvas.
Parameters
• canvas: MemoizationCanvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:686
canContain()
canContain(
shape):boolean
Determine a given shape can be contained in this shape
Parameters
• shape: Shape
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:1144
computeOpacity()
computeOpacity():
number
Returns
number
Inherited from
Source
packages/core/src/shapes.ts:676
containsPoint()
containsPoint(
canvas,point):boolean
Determines whether this shape contains a point in GCS
Parameters
• canvas: Canvas
• point: number[]
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:2034
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
Inherited from
Source
packages/core/src/shapes.ts:832
drawLink()
drawLink(
canvas,showDOM):void
Draw link
Parameters
• canvas: Canvas
• showDOM: boolean= false
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:846
finalize()
finalize(
canvas):void
Finalize shape
Parameters
• canvas: Canvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:596
find()
find(
pred):null|Obj
Find an shape in breath-first order
Parameters
• pred
Returns
null | Obj
Inherited from
Source
packages/core/src/core/obj.ts:372
findAllByQuery()
findAllByQuery(
queryString):Shape[]
Find all shapes matched with the query string
Parameters
• queryString: string
Returns
Shape[]
Inherited from
Source
packages/core/src/shapes.ts:1134
findByQuery()
findByQuery(
queryString):null|Shape
Find a shape first matched with the query string
Parameters
• queryString: any
Returns
null | Shape
Inherited from
Source
packages/core/src/shapes.ts:1121
findDepthFirst()
findDepthFirst(
pred):null|Obj
Find an shape in depth-first order
Parameters
• pred
Returns
null | Obj
Inherited from
Source
packages/core/src/core/obj.ts:385
findParent()
findParent(
pred):null|Obj
Find a shape along with the parent-chain
Parameters
• pred
Returns
null | Obj
Inherited from
Source
packages/core/src/core/obj.ts:398
fromJSON()
fromJSON(
json):void
Import shape from JSON
Parameters
• json: any
Returns
void
Overrides
Source
packages/core/src/shapes.ts:3016
getBoundingRect()
getBoundingRect(
includeAnchorPoints):number[][]
Return a bounding rect.
Parameters
• includeAnchorPoints: boolean= false
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:893
getCenter()
getCenter():
number[]
Returns the center point
Returns
number[]
Inherited from
Source
packages/core/src/shapes.ts:886
getChildrenBoundingRect()
getChildrenBoundingRect():
number[][]
Return a bounding box embracing children shapes
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:954
getContainerAt()
getContainerAt(
canvas,point,exceptions):null|Shape
Pick a container shape at specific position (x, y)
Parameters
• canvas: Canvas
• point: number[]
• exceptions: Shape[]= []
Returns
null | Shape
Inherited from
Source
packages/core/src/shapes.ts:643
getEnclosure()
getEnclosure():
number[][]
Return a enclosure
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:988
getEndSegment()
getEndSegment(
isHead):number[][]
Return a segment of an end
Parameters
• isHead: boolean
Returns
number[][]
segment line to end
Inherited from
Source
packages/core/src/shapes.ts:2025
getOutline()
getOutline():
number[][]
Return outline polygon.
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:821
getPage()
getPage():
null|Page
Return the page that contains this shape
Returns
null | Page
Inherited from
Source
packages/core/src/shapes.ts:568
getProperty()
getProperty(
name):any
Get a property object
Parameters
• name: string
Returns
any
Inherited from
Source
packages/core/src/shapes.ts:1156
getPropertyValue()
getPropertyValue(
name):any
Get a property value
Parameters
• name: string
Returns
any
Inherited from
Source
packages/core/src/shapes.ts:1166
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[][]
Inherited from
Source
packages/core/src/shapes.ts:967
getScript()
getScript(
id):undefined|string
Get a property object
Parameters
• id: string
Returns
undefined | string
Inherited from
Source
packages/core/src/shapes.ts:1174
getSeed()
getSeed():
number
Return the seed number
Returns
number
Inherited from
Source
packages/core/src/shapes.ts:583
getShapeAt()
getShapeAt(
canvas,point,exceptions,allowDisabledAndInvisible):null|Shape
Pick a shape at specific position (x, y)
Parameters
• canvas: Canvas
• point: number[]
• exceptions: Shape[]= []
• allowDisabledAndInvisible: boolean= false
Returns
null | Shape
Inherited from
Source
packages/core/src/shapes.ts:616
getViewport()
getViewport(
canvas):number[][]
Return a viewport in GCS. Viewport is a rect that includes actually drawn area which includes stroke width, arrowheads, etc. So viewport is mostly larger than bounding rect.
Parameters
• canvas: Canvas
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:944
initialze()
initialze(
canvas):void
Initialize shape
Parameters
• canvas: Canvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:591
isClosed()
isClosed():
boolean
Return is the path is closed
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:2016
isDescendant()
isDescendant(
obj):boolean
Test whether the given shape is a descendant
Parameters
• obj: Obj
Returns
boolean
Inherited from
Source
packages/core/src/core/obj.ts:408
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[]
Inherited from
Source
packages/core/src/shapes.ts:722
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[]
Inherited from
Source
packages/core/src/shapes.ts:742
localTransform()
localTransform(
canvas,recursive):void
Transform local context to parent’s context
Parameters
• canvas: Canvas
• recursive: boolean= false
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:706
match()
match(
query):boolean
Returns true if query matches this shape
Parameters
• query: object[]
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:1097
overlapClippingArea()
overlapClippingArea(
canvas,rect):boolean
Determines whether the given rect overlaps this shape’s clipping area. If the shape don’t have clipping area, return true. If the shape has clipping area, return true if the rect overlaps the clipping area. (e.g. Frame)
Parameters
• canvas: Canvas
• rect: number[][]
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:1028
overlapRect()
overlapRect(
canvas,rect):boolean
Determines whether this shape overlaps a given rect
Parameters
• canvas: Canvas
• rect: number[][]
Returns
boolean
Inherited from
Source
packages/core/src/shapes.ts:2057
parseQueryString()
parseQueryString(
queryString):any[]
Parse the query-string and returns a query object (JSON)
Query syntax:
e.g.) parseQuery(“@Box|NameText|@Text&#compartment”) —> [{_type: “Box”},{name: “NameText”},{_type: “Text”, tag:“compartment”}]
Parameters
• queryString: string
Returns
any[]
query object
Inherited from
Source
packages/core/src/shapes.ts:1072
readAny()
readAny(
json,field,defaultValue):any
Read an any value from the JSON object, return defaultValue if the field is undefined.
Parameters
• json: any
• field: string
• defaultValue: any
Returns
any
Inherited from
Source
packages/core/src/core/obj.ts:54
readArrayAny()
readArrayAny(
json,field,defaultValue):any[]
Read an array of any value from the JSON object, return defaultValue if the field is not an array.
Parameters
• json: any
• field: string
• defaultValue: any[]
Returns
any[]
Inherited from
Source
packages/core/src/core/obj.ts:65
readArrayBoolean()
readArrayBoolean(
json,field,defaultValue,length?):boolean[]
Read an array of boolean from the JSON object, return defaultValue if the field is not an array of boolean.
Parameters
• json: any
• field: string
• defaultValue: boolean[]
• length?: number
Returns
boolean[]
Inherited from
Source
packages/core/src/core/obj.ts:148
readArrayNumber()
readArrayNumber(
json,field,defaultValue,length?):number[]
Read a number field from the JSON object, return defaultValue if the field is not a number.
Parameters
• json: any
• field: string
• defaultValue: number[]
• length?: number
Returns
number[]
Inherited from
Source
packages/core/src/core/obj.ts:87
readArrayPoint()
readArrayPoint(
json,field,defaultValue): [number,number][]
Read a, array of point value from the JSON object, return defaultValue if the field is not an array of point.
Parameters
• json: any
• field: string
• defaultValue: [number, number][]
Returns
[number, number][]
Inherited from
Source
packages/core/src/core/obj.ts:259
readArrayString()
readArrayString(
json,field,defaultValue):string[]
Read an array of string from the JSON object, return defaultValue if the field is not an array of string.
Parameters
• json: any
• field: string
• defaultValue: string[]
Returns
string[]
Inherited from
Source
packages/core/src/core/obj.ts:123
readBoolean()
readBoolean(
json,field,defaultValue):boolean
Read a boolean field from the JSON object, return defaultValue if the field is not a boolean.
Parameters
• json: any
• field: string
• defaultValue: boolean
Returns
boolean
Inherited from
Source
packages/core/src/core/obj.ts:137
readColor()
readColor(
json,field,defaultValue):string
Read a color field from the JSON object, return defaultValue if the field is not a string or not a valid color.
Parameters
• json: any
• field: string
• defaultValue: string
Returns
string
Inherited from
Source
packages/core/src/core/obj.ts:170
readEnum()
readEnum(
json,field,enumType,defaultValue):string
Read an enum value from the JSON object, return defaultValue if the field is not a valid enum value.
Parameters
• json: any
• field: string
• enumType: any
• defaultValue: string
Returns
string
Inherited from
Source
packages/core/src/core/obj.ts:185
readNumber()
readNumber(
json,field,defaultValue):number
Read a number field from the JSON object, return defaultValue if the field is not a number.
Parameters
• json: any
• field: string
• defaultValue: number
Returns
number
Inherited from
Source
packages/core/src/core/obj.ts:76
readPoint()
readPoint(
json,field,defaultValue): [number,number]
Read a point value from the JSON object, return defaultValue if the field is not a point.
Parameters
• json: any
• field: string
• defaultValue: [number, number]
Returns
[number, number]
Inherited from
Source
packages/core/src/core/obj.ts:216
readPointOrNull()
readPointOrNull(
json,field,defaultValue):null| [number,number]
Read a point or null value from the JSON object, return defaultValue if the field is not a point or null.
Parameters
• json: any
• field: string
• defaultValue: null | [number, number]
Returns
null | [number, number]
Inherited from
Source
packages/core/src/core/obj.ts:236
readRef()
readRef(
json,field):null|string|Obj
Read a reference to object from the JSON object, return defaultValue if the field is not string (obj’s id) or null.
Parameters
• json: any
• field: string
Returns
null | string | Obj
Inherited from
Source
packages/core/src/core/obj.ts:202
readString()
readString(
json,field,defaultValue):string
Read a string field from the JSON object, return defaultValue if the field is not a string.
Parameters
• json: any
• field: string
• defaultValue: string
Returns
string
Inherited from
Source
packages/core/src/core/obj.ts:112
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
Inherited from
Source
packages/core/src/shapes.ts:765
renderDefault()
renderDefault(
canvas):void
Default render this shape
Parameters
• canvas: MemoizationCanvas
Returns
void
Overrides
Source
packages/core/src/shapes.ts:3023
renderOutline()
renderOutline(
canvas):void
Render this shape’s outline
Parameters
• canvas: MemoizationCanvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:790
renderOutlineDefault()
renderOutlineDefault(
canvas):number[][]
Return default outline
Parameters
• canvas: MemoizationCanvas
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:2068
renderShadow()
renderShadow(
canvas):void
Render shadow
Parameters
• canvas: MemoizationCanvas
Returns
void
Overrides
Source
packages/core/src/shapes.ts:3040
renderViewport()
renderViewport(
canvas):void
Return this shape’s viewport
Parameters
• canvas: MemoizationCanvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:903
renderViewportDefault()
renderViewportDefault(
canvas):number[][]
Render default viewport
Parameters
• canvas: MemoizationCanvas
Returns
number[][]
Inherited from
Source
packages/core/src/shapes.ts:922
resolveRefs()
resolveRefs(
idMap,nullIfNotFound):void
Resolve references
Parameters
• idMap: Record<string, Shape>
id to object map
• nullIfNotFound: boolean= false
assign null if not found
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:554
setJson()
setJson(
json,field,value,defaultValue,enforce):void
Set a field in the JSON object only if the value is defined and not equal to the default value.
Parameters
• json: any
The JSON object to set the field in.
• field: string
The field name to set.
• value: any
The value to set.
• defaultValue: any
The default value to compare against.
• enforce: boolean= false
If true, the field will be set even if it is equal to the default value.
Returns
void
Inherited from
Source
packages/core/src/core/obj.ts:31
toJSON()
toJSON(
recursive,keepRefs,enforce):any
Export shape to JSON
Parameters
• recursive: boolean= false
• keepRefs: boolean= false
• enforce: boolean= false
Returns
any
Overrides
Source
packages/core/src/shapes.ts:3004
traverse()
traverse(
fun,parent):void
Traverse all objects in breath-first order
Parameters
• fun
• parent: null | Obj= null
Returns
void
Inherited from
Source
packages/core/src/core/obj.ts:326
traverseDepthFirst()
traverseDepthFirst(
fun,parent):void
Traverse all shapes in depth-first order
Parameters
• fun
• parent: null | Obj= null
Returns
void
Inherited from
Source
packages/core/src/core/obj.ts:340
traverseDepthFirstSequence()
traverseDepthFirstSequence():
Obj[]
Returns an array of shapes in order of traverse sequence.
Returns
Obj[]
Inherited from
Path.traverseDepthFirstSequence
Source
packages/core/src/core/obj.ts:363
traverseSequence()
traverseSequence():
Obj[]
Returns an array of shapes in order of traverse sequence.
Returns
Obj[]
Inherited from
Source
packages/core/src/core/obj.ts:354
update()
update(
canvas):void
Update shape
Parameters
• canvas: Canvas
Returns
void
Inherited from
Source
packages/core/src/shapes.ts:606
visit()
visit(
fun,parent):void
Visit all shapes in breath-first order. The difference from traverse() is that each shape determine visit into children or not. (e.g. Group and Frame doens’t visit into children)
Parameters
• fun
• parent: null | Shape= null
Returns
void