@leafer/interface 1.0.0-alpha.9 → 1.0.0-beta

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,3 +1,4 @@
1
+ import { IPathCommandData } from './IPathCommand'
1
2
  export interface IPathDrawer {
2
3
  beginPath?(): void
3
4
 
@@ -7,10 +8,29 @@ export interface IPathDrawer {
7
8
  quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): void
8
9
  closePath(): void
9
10
 
10
- arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, counterclockwise?: boolean): void
11
+ arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void
11
12
  arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): void
12
- ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, counterclockwise?: boolean): void
13
+ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise?: boolean): void
13
14
 
14
15
  rect(x: number, y: number, width: number, height: number): void
15
16
  roundRect(x: number, y: number, width: number, height: number, radius?: number | number[]): void
17
+ }
18
+
19
+ export interface IPathCreator {
20
+ path: IPathCommandData
21
+
22
+ beginPath(): IPathCreator
23
+
24
+ moveTo(x: number, y: number): IPathCreator
25
+ lineTo(x: number, y: number): IPathCreator
26
+ bezierCurveTo(cp1x: number, cp1y: number, cp2x: number, cp2y: number, x: number, y: number): IPathCreator
27
+ quadraticCurveTo(cpx: number, cpy: number, x: number, y: number): IPathCreator
28
+ closePath(): IPathCreator
29
+
30
+ arc(x: number, y: number, radius: number, startAngle: number, endAngle: number, anticlockwise?: boolean): IPathCreator
31
+ arcTo(x1: number, y1: number, x2: number, y2: number, radius: number): IPathCreator
32
+ ellipse(x: number, y: number, radiusX: number, radiusY: number, rotation: number, startAngle: number, endAngle: number, anticlockwise?: boolean): IPathCreator
33
+
34
+ rect(x: number, y: number, width: number, height: number): IPathCreator
35
+ roundRect(x: number, y: number, width: number, height: number, radius?: number | number[]): IPathCreator
16
36
  }
@@ -1,7 +1,15 @@
1
1
  import { IFunction } from '../function/IFunction'
2
2
  import { ILeaferCanvas } from '../canvas/ILeaferCanvas'
3
+ import { ILeaf } from '../display/ILeaf'
3
4
 
4
5
  export interface IPlatform {
5
6
  requestRender?(render: IFunction): void
6
7
  canvas?: ILeaferCanvas
8
+ isWorker?: boolean
9
+ devicePixelRatio?: number
10
+ intWheelDeltaY?: boolean // firxfox need
11
+ conicGradientSupport?: boolean
12
+ conicGradientRotate90?: boolean // fixfox need rotate
13
+ fullImageShadow?: boolean // safari need
14
+ layout(target: ILeaf): void
7
15
  }
@@ -2,7 +2,7 @@ import { ILeaferCanvas } from '../canvas/ILeaferCanvas'
2
2
  import { ILeaf } from '../display/ILeaf'
3
3
  import { IBounds, IMatrix } from '../math/IMath'
4
4
  import { IFunction } from '../function/IFunction'
5
- import { ILayoutBlockData } from '../layouter/ILayouter'
5
+ import { IControl } from '../control/IControl'
6
6
 
7
7
  export interface IRenderOptions {
8
8
  bounds?: IBounds,
@@ -12,26 +12,42 @@ export interface IRenderOptions {
12
12
  }
13
13
 
14
14
  export interface IRendererConfig {
15
+ usePartRender?: boolean
15
16
  maxFPS?: number
17
+ fill?: string
16
18
  }
17
19
 
18
- export interface IRenderer {
19
- canvas: ILeaferCanvas
20
+ export interface IRenderer extends IControl {
20
21
  target: ILeaf
21
- layoutedBlocks: ILayoutBlockData[]
22
- running: boolean
22
+ canvas: ILeaferCanvas
23
+ updateBlocks: IBounds[]
24
+
25
+ FPS: number
23
26
  totalTimes: number
24
27
  times: number
25
- config: IRendererConfig
26
28
 
27
- FPS: number
29
+ running: boolean
30
+ rendering: boolean
31
+
32
+ waitAgain: boolean
33
+ changed: boolean
34
+
35
+ config: IRendererConfig
28
36
 
29
- start(): void
30
- stop(): void
37
+ update(): void
31
38
 
32
39
  requestLayout(): void
40
+
33
41
  render(callback?: IFunction): void
42
+ renderAgain(): void
43
+ renderOnce(callback?: IFunction): void
44
+ partRender(): void
34
45
  clipRender(bounds: IBounds): void
35
- fullRender(bounds?: IBounds): void
36
- destroy(): void
46
+ fullRender(): void
47
+
48
+ renderHitView(options: IRenderOptions): void
49
+ renderBoundsView(options: IRenderOptions): void
50
+
51
+ addBlock(block: IBounds): void
52
+ mergeBlocks(): void
37
53
  }
@@ -9,15 +9,22 @@ export interface ISelectPathResult {
9
9
  }
10
10
 
11
11
  export interface ISelectPathOptions {
12
+ name?: string
12
13
  through?: boolean
13
14
  exclude?: ILeafList
15
+ ignoreHittable?: boolean
16
+ }
17
+
18
+ export interface ISelectorConfig {
19
+
14
20
  }
15
21
 
16
22
  export interface ISelector {
17
23
  target: ILeaf
18
24
 
19
- defaultPath: ILeafList
20
- getHitPointPath(hitPoint: IPointData, hitRadius: number, options?: ISelectPathOptions): ISelectPathResult
25
+ config: ISelectorConfig
26
+
27
+ getByPoint(hitPoint: IPointData, hitRadius: number, options?: ISelectPathOptions): ISelectPathResult
21
28
 
22
29
  find(name: number | string, branch?: ILeaf): ILeaf | ILeaf[]
23
30
  getByInnerId(name: number, branch?: ILeaf): ILeaf
@@ -1,5 +1,6 @@
1
1
  import { ILeaf } from '../display/ILeaf'
2
2
  import { ILeafList } from '../data/IList'
3
+ import { IControl } from '../control/IControl'
3
4
 
4
5
  export interface IWatchEventData {
5
6
  updatedList: ILeafList
@@ -9,17 +10,19 @@ export interface IWatcherConfig {
9
10
 
10
11
  }
11
12
 
12
- export interface IWatcher {
13
+ export interface IWatcher extends IControl {
13
14
  target: ILeaf
14
15
  updatedList: ILeafList
16
+
15
17
  totalTimes: number
16
- config: IWatcherConfig
18
+
19
+ disabled: boolean
17
20
  running: boolean
18
21
  changed: boolean
19
22
 
20
- start(): void
21
- stop(): void
23
+ config: IWatcherConfig
24
+
25
+ disable(): void
22
26
 
23
27
  update(): void
24
- destroy(): void
25
28
  }
@@ -1,5 +0,0 @@
1
- import { ILeafer } from './ILeafer'
2
-
3
- export interface ISupperLeafer extends ILeafer {
4
- children: ILeafer[]
5
- }