This repository was archived by the owner on Dec 4, 2017. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 862
Expand file tree
/
Copy pathcanvas.component.ts
More file actions
58 lines (50 loc) · 1.38 KB
/
canvas.component.ts
File metadata and controls
58 lines (50 loc) · 1.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// #docplaster
// #docregion
import { Component, ElementRef, Renderer, ViewChild } from '@angular/core';
import { FullSizeBaseComponent } from './full-size-base.component';
// #docregion di
@Component({
selector: 'my-canvas',
template: '<canvas #canvas></canvas>',
styles: [`canvas { border: 1px solid black; }`]
})
// #docregion viewchild
// #docregion afterviewinit
// #docregion hostlistener
export class CanvasComponent extends FullSizeBaseComponent {
// #enddocregion afterviewinit
// #enddocregion hostlistener
// #enddocregion di
@ViewChild('canvas')
child: ElementRef;
// #enddocregion viewchild
// #docregion di
constructor(renderer: Renderer, private elementRef: ElementRef) {
super(renderer);
}
// #enddocregion di
// #docregion afterviewinit
ngAfterViewInit() {
super.ngAfterViewInit(); // Must call super!
this.draw();
}
// #enddocregion afterviewinit
// #docregion hostlistener
onResize(event: any) {
super.onResize(event);
this.draw();
}
// #enddocregion hostlistener
private draw() {
const ctx: CanvasRenderingContext2D = this.child.nativeElement.getContext('2d');
ctx.fillRect(10, 10, 100, 100);
}
// #docregion viewchild
// #docregion afterviewinit
// #docregion hostlistener
// #docregion di
}
// #enddocregion viewchild
// #enddocregion afterviewinit
// #enddocregion hostlistener
// #enddocregion di