forked from nativescript-community/nativescript-drawingpad
-
Notifications
You must be signed in to change notification settings - Fork 0
/
drawingpad.android.ts
107 lines (93 loc) · 2.57 KB
/
drawingpad.android.ts
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
import { Color } from "color";
import {
DrawingPadBase,
penColorProperty,
penWidthProperty
} from "./drawingpad-common";
declare var com: any;
const SignaturePad: any = com.github.gcacace.signaturepad.views.SignaturePad;
export * from "./drawingpad-common";
export class DrawingPad extends DrawingPadBase {
get android() {
return this.nativeView;
}
public createNativeView() {
const signaturePad = new SignaturePad(this._context, null);
if (this.penColor) {
signaturePad.setPenColor(this.penColor.android);
}
if (this.penWidth) {
signaturePad.setMinWidth(this.penWidth);
}
return signaturePad;
}
[penWidthProperty.getDefault](): number {
return this.nativeView.minWidth;
}
[penWidthProperty.setNative](value: number) {
this.nativeView.setMinWidth(value);
}
[penColorProperty.getDefault](): number {
return this.nativeView.penColor;
}
[penColorProperty.setNative](value: Color | number) {
const color = value instanceof Color ? value.android : value;
this.nativeView.setPenColor(color);
}
public getDrawing(): Promise<any> {
return new Promise((resolve, reject) => {
try {
if (!this.nativeView.isEmpty()) {
let data = this.nativeView.getSignatureBitmap();
resolve(data);
} else {
reject("DrawingPad is empty.");
}
} catch (err) {
reject(err);
}
});
}
public getTransparentDrawing(): Promise<any> {
return new Promise((resolve, reject) => {
try {
if (!this.nativeView.isEmpty()) {
let data = this.nativeView.getTransparentSignatureBitmap();
resolve(data);
} else {
reject("DrawingPad is empty.");
}
} catch (err) {
reject(err);
}
});
}
public getDrawingSvg(): Promise<string> {
return new Promise((resolve, reject) => {
try {
if (!this.nativeView.isEmpty()) {
let data: string = this.nativeView.getSignatureSvg();
// Append viewbox to the svg for correct scaling
const svgHeaderRegEx = /<svg (.*) height="(\d+)" width="(\d+)"(.*)>/i;
resolve(
data.replace(
svgHeaderRegEx,
`<svg $1 viewBox="0, 0, $3, $2" height="$2" width="$3"$4>`
)
);
} else {
reject("DrawingPad is empty.");
}
} catch (err) {
reject(err);
}
});
}
public clearDrawing(): void {
try {
this.nativeView.clear();
} catch (err) {
console.log("Error in clearDrawing: " + err);
}
}
}