Options
All
  • Public
  • Public/Protected
  • All
Menu

Class InteractiveCanvas

Hierarchy

Implements

Index

Constructors

constructor

Properties

Protected _ctx

_ctx: CanvasRenderingContext2D

Private _handles

_handles: Map<DiagramElement<any>, Handle[]>

Private _hoveredElement

_hoveredElement: DiagramElement<any> | null

Private _resizeListeners

_resizeListeners: Map<DiagramElement<any>, Function>

Private _selectedElements

_selectedElements: Set<DiagramElement<any>>

Accessors

background

  • get background(): string | any
  • set background(value: string | any): void

cursor

diagram

  • get diagram(): Diagram | null
  • set diagram(val: Diagram | null): void

grid

  • get grid(): boolean
  • set grid(val: boolean): void

gridX

  • get gridX(): number

gridY

  • get gridY(): number

height

  • get height(): number

hoveredElement

offsetX

  • get offsetX(): number

offsetY

  • get offsetY(): number

selectedElements

width

  • get width(): number

zoom

  • get zoom(): number
  • set zoom(value: number): void

zoomHeight

  • get zoomHeight(): number

zoomWidth

  • get zoomWidth(): number

Methods

addSelection

clearSelection

  • clearSelection(): void

clipRectangle

  • clipRectangle(bounds: Bounds): void

deleteSelection

drawLine

drawRectangle

  • drawRectangle(bounds: Bounds): void

drawSimpleLine

  • drawSimpleLine(x1: number, y1: number, x2: number, y2: number, stroke: Stroke): void

drawText

  • drawText(text: string, x: number, y: number, font: Font, maxWidth?: undefined | number, hAlign?: TextAlign, vAlign?: Baseline): void
  • Draws a text

    Parameters

    • text: string

      The text to draw

    • x: number

      The text X position

    • y: number

      The text Y position

    • font: Font

      The font to use

    • Optional maxWidth: undefined | number

      The maximum width of the text

    • Default value hAlign: TextAlign = "left"

      The horizontal alignment

    • Default value vAlign: Baseline = "middle"

      The vertical alignment

    Returns void

fillRectangle

getElementByPosition

  • getElementByPosition(x: number, y: number): DiagramElement<any> | null

Protected getElementCoordinates

  • getElementCoordinates(target: DiagramElement<any>): [number, number]

getHandleByPosition

  • getHandleByPosition(x: number, y: number): Handle | null

Protected invalidate

  • invalidate(): void

isSelected

labelLine

  • labelLine(line: Line, font: Font, label: string, position?: number): void

measureTextWidth

  • measureTextWidth(text: string, font: Font): number

moveElement

  • moveElement(element: DiagramElement<any>, dx: number, dy: number): void

moveOffset

  • moveOffset(dx: number, dy: number): void

popCanvasStack

  • popCanvasStack(): void

pushCanvasStack

  • pushCanvasStack(): void

Protected render

  • render(): this

rerender

  • rerender(): this

resize

  • resize(width: number, height: number): this

strokeRectangle

translate

  • translate(offset: Point): void

Protected updateHandles

zoom100

  • zoom100(x?: undefined | number, y?: undefined | number): void

Protected zoomCanvas

  • zoomCanvas(newZoom: number, x?: undefined | number, y?: undefined | number): void

zoomIn

  • zoomIn(x?: undefined | number, y?: undefined | number): void

zoomOut

  • zoomOut(x?: undefined | number, y?: undefined | number): void
  • Zooms out of the diagram

    Parameters

    • Optional x: undefined | number
    • Optional y: undefined | number

    Returns void

Generated using TypeDoc