ngx-easy-image-drawing 0.0.1

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.
package/README.md ADDED
@@ -0,0 +1,24 @@
1
+ # NgxEasyImageDrawing
2
+
3
+ This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.1.0.
4
+
5
+ ## Code scaffolding
6
+
7
+ Run `ng generate component component-name --project ngx-easy-image-drawing` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project ngx-easy-image-drawing`.
8
+ > Note: Don't forget to add `--project ngx-easy-image-drawing` or else it will be added to the default project in your `angular.json` file.
9
+
10
+ ## Build
11
+
12
+ Run `ng build ngx-easy-image-drawing` to build the project. The build artifacts will be stored in the `dist/` directory.
13
+
14
+ ## Publishing
15
+
16
+ After building your library with `ng build ngx-easy-image-drawing`, go to the dist folder `cd dist/ngx-easy-image-drawing` and run `npm publish`.
17
+
18
+ ## Running unit tests
19
+
20
+ Run `ng test ngx-easy-image-drawing` to execute the unit tests via [Karma](https://karma-runner.github.io).
21
+
22
+ ## Further help
23
+
24
+ To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page.
@@ -0,0 +1,114 @@
1
+ import { Component, ViewChild, Input, Output, EventEmitter, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NgxEasyImageDrawingComponent {
4
+ constructor() {
5
+ this.width = 500;
6
+ this.height = 500;
7
+ this.lineWidth = 7;
8
+ this.lineColor = '#000000';
9
+ this.src = '';
10
+ this.savedImage = new EventEmitter();
11
+ this.previousPosition = { x: 0, y: 0 };
12
+ this.activePath = false;
13
+ this._mousedown = null;
14
+ this._mousemove = null;
15
+ this._mouseup = null;
16
+ }
17
+ ngAfterViewInit() {
18
+ this.canvas.nativeElement.width = this.width;
19
+ this.canvas.nativeElement.height = this.height;
20
+ this.context = this.canvas.nativeElement.getContext('2d');
21
+ this.context.lineWidth = this.lineWidth;
22
+ this.context.strokeStyle = this.lineColor;
23
+ this.context.lineCap = 'round';
24
+ // set src to image
25
+ const image = new Image();
26
+ image.src = this.src;
27
+ image.onload = () => {
28
+ this.context.drawImage(image, 0, 0, this.width, this.height);
29
+ };
30
+ this._mousedown = window.addEventListener('mousedown', (event) => {
31
+ this.activePath = true;
32
+ this.context.beginPath();
33
+ this.previousPosition = this.getMousePosition(event);
34
+ });
35
+ this._mousemove = window.addEventListener('mousemove', (event) => {
36
+ event.preventDefault();
37
+ if (this.activePath) {
38
+ this._drawLine(event);
39
+ }
40
+ });
41
+ this._mouseup = window.addEventListener('mouseup', () => {
42
+ if (this.activePath) {
43
+ this.context.closePath();
44
+ this.activePath = false;
45
+ }
46
+ });
47
+ }
48
+ save() {
49
+ const dataUrl = this.canvas.nativeElement.toDataURL('image/png');
50
+ const blob = this._dataURItoBlob(dataUrl);
51
+ this.savedImage.next(new File([blob], 'image.png'));
52
+ }
53
+ clear() {
54
+ this.context.clearRect(0, 0, this.width, this.height);
55
+ const image = new Image();
56
+ image.src = this.src;
57
+ image.onload = () => {
58
+ this.context.drawImage(image, 0, 0, this.width, this.height);
59
+ };
60
+ }
61
+ _dataURItoBlob(dataUrl) {
62
+ const byteString = atob(dataUrl.split(',')[1]);
63
+ const mimeString = dataUrl.split(',')[0].split(':')[1].split(';')[0];
64
+ const ab = new ArrayBuffer(byteString.length);
65
+ const dw = new DataView(ab);
66
+ for (let i = 0; i < byteString.length; i++) {
67
+ dw.setUint8(i, byteString.charCodeAt(i));
68
+ }
69
+ return new Blob([ab], { type: mimeString });
70
+ }
71
+ _drawLine(event) {
72
+ const currentPosition = this.getMousePosition(event);
73
+ this.context.moveTo(this.previousPosition.x, this.previousPosition.y);
74
+ this.context.lineTo(currentPosition.x, currentPosition.y);
75
+ this.previousPosition = currentPosition;
76
+ this.context.stroke();
77
+ }
78
+ getMousePosition(event) {
79
+ const rect = this.canvas.nativeElement.getBoundingClientRect();
80
+ const scaleX = this.canvas.nativeElement.width / rect.width;
81
+ const scaleY = this.canvas.nativeElement.height / rect.height;
82
+ return {
83
+ x: (event.clientX - rect.left) * scaleX,
84
+ y: (event.clientY - rect.top) * scaleY,
85
+ };
86
+ }
87
+ ngOnDestroy() {
88
+ window.removeEventListener('mousedown', this._mousedown);
89
+ window.removeEventListener('mousemove', this._mousemove);
90
+ window.removeEventListener('mouseup', this._mouseup);
91
+ }
92
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgxEasyImageDrawingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
93
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.3", type: NgxEasyImageDrawingComponent, isStandalone: true, selector: "lib-ngx-easy-image-drawing", inputs: { width: "width", height: "height", lineWidth: "lineWidth", lineColor: "lineColor", src: "src" }, outputs: { savedImage: "savedImage" }, viewQueries: [{ propertyName: "canvas", first: true, predicate: ["drawingCanvas"], descendants: true }], ngImport: i0, template: ` <p>ngx-easy-image-drawing works!</p> `, isInline: true, styles: [""] }); }
94
+ }
95
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgxEasyImageDrawingComponent, decorators: [{
96
+ type: Component,
97
+ args: [{ selector: 'lib-ngx-easy-image-drawing', standalone: true, imports: [], template: ` <p>ngx-easy-image-drawing works!</p> ` }]
98
+ }], propDecorators: { width: [{
99
+ type: Input
100
+ }], height: [{
101
+ type: Input
102
+ }], lineWidth: [{
103
+ type: Input
104
+ }], lineColor: [{
105
+ type: Input
106
+ }], src: [{
107
+ type: Input
108
+ }], savedImage: [{
109
+ type: Output
110
+ }], canvas: [{
111
+ type: ViewChild,
112
+ args: ['drawingCanvas']
113
+ }] } });
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-easy-image-drawing.component.js","sourceRoot":"","sources":["../../../../projects/ngx-easy-image-drawing/src/lib/ngx-easy-image-drawing.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  ElementRef,\r\n  AfterViewInit,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  OnDestroy,\r\n} from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'lib-ngx-easy-image-drawing',\r\n  standalone: true,\r\n  imports: [],\r\n  template: ` <p>ngx-easy-image-drawing works!</p> `,\r\n  styles: ``,\r\n})\r\nexport class NgxEasyImageDrawingComponent implements AfterViewInit, OnDestroy {\r\n  @Input() width: number = 500;\r\n  @Input() height: number = 500;\r\n  @Input() lineWidth = 7;\r\n  @Input() lineColor = '#000000';\r\n  @Input() src = '';\r\n  @Output() savedImage = new EventEmitter<File>();\r\n\r\n  // its important myCanvas matches the variable name in the template\r\n  @ViewChild('drawingCanvas') canvas!: ElementRef<HTMLCanvasElement>;\r\n\r\n  context!: CanvasRenderingContext2D;\r\n  private previousPosition: { x: number; y: number } = { x: 0, y: 0 };\r\n  private activePath = false;\r\n\r\n  private _mousedown: any = null;\r\n  private _mousemove: any = null;\r\n  private _mouseup: any = null;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.canvas.nativeElement.width = this.width;\r\n    this.canvas.nativeElement.height = this.height;\r\n\r\n    this.context = this.canvas.nativeElement.getContext('2d')!;\r\n    this.context.lineWidth = this.lineWidth;\r\n    this.context.strokeStyle = this.lineColor;\r\n    this.context.lineCap = 'round';\r\n\r\n    // set src to image\r\n    const image = new Image();\r\n    image.src = this.src;\r\n    image.onload = () => {\r\n      this.context.drawImage(image, 0, 0, this.width, this.height);\r\n    };\r\n\r\n    this._mousedown = window.addEventListener(\r\n      'mousedown',\r\n      (event: MouseEvent) => {\r\n        this.activePath = true;\r\n        this.context.beginPath();\r\n        this.previousPosition = this.getMousePosition(event);\r\n      }\r\n    );\r\n\r\n    this._mousemove = window.addEventListener('mousemove', (event) => {\r\n      event.preventDefault();\r\n      if (this.activePath) {\r\n        this._drawLine(event);\r\n      }\r\n    });\r\n\r\n    this._mouseup = window.addEventListener('mouseup', () => {\r\n      if (this.activePath) {\r\n        this.context.closePath();\r\n        this.activePath = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  public save(): void {\r\n    const dataUrl = this.canvas.nativeElement.toDataURL('image/png');\r\n    const blob = this._dataURItoBlob(dataUrl);\r\n    this.savedImage.next(new File([blob], 'image.png'));\r\n  }\r\n\r\n  public clear(): void {\r\n    this.context.clearRect(0, 0, this.width, this.height);\r\n    const image = new Image();\r\n    image.src = this.src;\r\n    image.onload = () => {\r\n      this.context.drawImage(image, 0, 0, this.width, this.height);\r\n    };\r\n  }\r\n\r\n  private _dataURItoBlob(dataUrl: string) {\r\n    const byteString = atob(dataUrl.split(',')[1]);\r\n    const mimeString = dataUrl.split(',')[0].split(':')[1].split(';')[0];\r\n    const ab = new ArrayBuffer(byteString.length);\r\n    const dw = new DataView(ab);\r\n    for (let i = 0; i < byteString.length; i++) {\r\n      dw.setUint8(i, byteString.charCodeAt(i));\r\n    }\r\n    return new Blob([ab], { type: mimeString });\r\n  }\r\n\r\n  private _drawLine(event: MouseEvent): void {\r\n    const currentPosition = this.getMousePosition(event);\r\n    this.context.moveTo(this.previousPosition.x, this.previousPosition.y);\r\n    this.context.lineTo(currentPosition.x, currentPosition.y);\r\n    this.previousPosition = currentPosition;\r\n    this.context.stroke();\r\n  }\r\n\r\n  private getMousePosition(event: MouseEvent): { x: number; y: number } {\r\n    const rect = this.canvas.nativeElement.getBoundingClientRect();\r\n    const scaleX = this.canvas.nativeElement.width / rect.width;\r\n    const scaleY = this.canvas.nativeElement.height / rect.height;\r\n    return {\r\n      x: (event.clientX - rect.left) * scaleX,\r\n      y: (event.clientY - rect.top) * scaleY,\r\n    };\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    window.removeEventListener('mousedown', this._mousedown);\r\n    window.removeEventListener('mousemove', this._mousemove);\r\n    window.removeEventListener('mouseup', this._mouseup);\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWVhc3ktaW1hZ2UtZHJhd2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1lYXN5LWltYWdlLWRyYXdpbmcvc3JjL25neC1lYXN5LWltYWdlLWRyYXdpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of ngx-easy-image-drawing
3
+ */
4
+ export * from './lib/ngx-easy-image-drawing.component';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1lYXN5LWltYWdlLWRyYXdpbmcvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHdDQUF3QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5neC1lYXN5LWltYWdlLWRyYXdpbmdcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZ3gtZWFzeS1pbWFnZS1kcmF3aW5nLmNvbXBvbmVudCc7XHJcbiJdfQ==
@@ -0,0 +1,125 @@
1
+ import * as i0 from '@angular/core';
2
+ import { EventEmitter, Component, Input, Output, ViewChild } from '@angular/core';
3
+
4
+ class NgxEasyImageDrawingComponent {
5
+ constructor() {
6
+ this.width = 500;
7
+ this.height = 500;
8
+ this.lineWidth = 7;
9
+ this.lineColor = '#000000';
10
+ this.src = '';
11
+ this.savedImage = new EventEmitter();
12
+ this.previousPosition = { x: 0, y: 0 };
13
+ this.activePath = false;
14
+ this._mousedown = null;
15
+ this._mousemove = null;
16
+ this._mouseup = null;
17
+ }
18
+ ngAfterViewInit() {
19
+ this.canvas.nativeElement.width = this.width;
20
+ this.canvas.nativeElement.height = this.height;
21
+ this.context = this.canvas.nativeElement.getContext('2d');
22
+ this.context.lineWidth = this.lineWidth;
23
+ this.context.strokeStyle = this.lineColor;
24
+ this.context.lineCap = 'round';
25
+ // set src to image
26
+ const image = new Image();
27
+ image.src = this.src;
28
+ image.onload = () => {
29
+ this.context.drawImage(image, 0, 0, this.width, this.height);
30
+ };
31
+ this._mousedown = window.addEventListener('mousedown', (event) => {
32
+ this.activePath = true;
33
+ this.context.beginPath();
34
+ this.previousPosition = this.getMousePosition(event);
35
+ });
36
+ this._mousemove = window.addEventListener('mousemove', (event) => {
37
+ event.preventDefault();
38
+ if (this.activePath) {
39
+ this._drawLine(event);
40
+ }
41
+ });
42
+ this._mouseup = window.addEventListener('mouseup', () => {
43
+ if (this.activePath) {
44
+ this.context.closePath();
45
+ this.activePath = false;
46
+ }
47
+ });
48
+ }
49
+ save() {
50
+ const dataUrl = this.canvas.nativeElement.toDataURL('image/png');
51
+ const blob = this._dataURItoBlob(dataUrl);
52
+ this.savedImage.next(new File([blob], 'image.png'));
53
+ }
54
+ clear() {
55
+ this.context.clearRect(0, 0, this.width, this.height);
56
+ const image = new Image();
57
+ image.src = this.src;
58
+ image.onload = () => {
59
+ this.context.drawImage(image, 0, 0, this.width, this.height);
60
+ };
61
+ }
62
+ _dataURItoBlob(dataUrl) {
63
+ const byteString = atob(dataUrl.split(',')[1]);
64
+ const mimeString = dataUrl.split(',')[0].split(':')[1].split(';')[0];
65
+ const ab = new ArrayBuffer(byteString.length);
66
+ const dw = new DataView(ab);
67
+ for (let i = 0; i < byteString.length; i++) {
68
+ dw.setUint8(i, byteString.charCodeAt(i));
69
+ }
70
+ return new Blob([ab], { type: mimeString });
71
+ }
72
+ _drawLine(event) {
73
+ const currentPosition = this.getMousePosition(event);
74
+ this.context.moveTo(this.previousPosition.x, this.previousPosition.y);
75
+ this.context.lineTo(currentPosition.x, currentPosition.y);
76
+ this.previousPosition = currentPosition;
77
+ this.context.stroke();
78
+ }
79
+ getMousePosition(event) {
80
+ const rect = this.canvas.nativeElement.getBoundingClientRect();
81
+ const scaleX = this.canvas.nativeElement.width / rect.width;
82
+ const scaleY = this.canvas.nativeElement.height / rect.height;
83
+ return {
84
+ x: (event.clientX - rect.left) * scaleX,
85
+ y: (event.clientY - rect.top) * scaleY,
86
+ };
87
+ }
88
+ ngOnDestroy() {
89
+ window.removeEventListener('mousedown', this._mousedown);
90
+ window.removeEventListener('mousemove', this._mousemove);
91
+ window.removeEventListener('mouseup', this._mouseup);
92
+ }
93
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgxEasyImageDrawingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
94
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.3", type: NgxEasyImageDrawingComponent, isStandalone: true, selector: "lib-ngx-easy-image-drawing", inputs: { width: "width", height: "height", lineWidth: "lineWidth", lineColor: "lineColor", src: "src" }, outputs: { savedImage: "savedImage" }, viewQueries: [{ propertyName: "canvas", first: true, predicate: ["drawingCanvas"], descendants: true }], ngImport: i0, template: ` <p>ngx-easy-image-drawing works!</p> `, isInline: true, styles: [""] }); }
95
+ }
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.3", ngImport: i0, type: NgxEasyImageDrawingComponent, decorators: [{
97
+ type: Component,
98
+ args: [{ selector: 'lib-ngx-easy-image-drawing', standalone: true, imports: [], template: ` <p>ngx-easy-image-drawing works!</p> ` }]
99
+ }], propDecorators: { width: [{
100
+ type: Input
101
+ }], height: [{
102
+ type: Input
103
+ }], lineWidth: [{
104
+ type: Input
105
+ }], lineColor: [{
106
+ type: Input
107
+ }], src: [{
108
+ type: Input
109
+ }], savedImage: [{
110
+ type: Output
111
+ }], canvas: [{
112
+ type: ViewChild,
113
+ args: ['drawingCanvas']
114
+ }] } });
115
+
116
+ /*
117
+ * Public API Surface of ngx-easy-image-drawing
118
+ */
119
+
120
+ /**
121
+ * Generated bundle index. Do not edit.
122
+ */
123
+
124
+ export { NgxEasyImageDrawingComponent };
125
+ //# sourceMappingURL=ngx-easy-image-drawing.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ngx-easy-image-drawing.mjs","sources":["../../../projects/ngx-easy-image-drawing/src/lib/ngx-easy-image-drawing.component.ts","../../../projects/ngx-easy-image-drawing/src/public-api.ts","../../../projects/ngx-easy-image-drawing/src/ngx-easy-image-drawing.ts"],"sourcesContent":["import {\r\n Component,\r\n ViewChild,\r\n ElementRef,\r\n AfterViewInit,\r\n Input,\r\n Output,\r\n EventEmitter,\r\n OnDestroy,\r\n} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'lib-ngx-easy-image-drawing',\r\n standalone: true,\r\n imports: [],\r\n template: ` <p>ngx-easy-image-drawing works!</p> `,\r\n styles: ``,\r\n})\r\nexport class NgxEasyImageDrawingComponent implements AfterViewInit, OnDestroy {\r\n @Input() width: number = 500;\r\n @Input() height: number = 500;\r\n @Input() lineWidth = 7;\r\n @Input() lineColor = '#000000';\r\n @Input() src = '';\r\n @Output() savedImage = new EventEmitter<File>();\r\n\r\n // its important myCanvas matches the variable name in the template\r\n @ViewChild('drawingCanvas') canvas!: ElementRef<HTMLCanvasElement>;\r\n\r\n context!: CanvasRenderingContext2D;\r\n private previousPosition: { x: number; y: number } = { x: 0, y: 0 };\r\n private activePath = false;\r\n\r\n private _mousedown: any = null;\r\n private _mousemove: any = null;\r\n private _mouseup: any = null;\r\n\r\n ngAfterViewInit(): void {\r\n this.canvas.nativeElement.width = this.width;\r\n this.canvas.nativeElement.height = this.height;\r\n\r\n this.context = this.canvas.nativeElement.getContext('2d')!;\r\n this.context.lineWidth = this.lineWidth;\r\n this.context.strokeStyle = this.lineColor;\r\n this.context.lineCap = 'round';\r\n\r\n // set src to image\r\n const image = new Image();\r\n image.src = this.src;\r\n image.onload = () => {\r\n this.context.drawImage(image, 0, 0, this.width, this.height);\r\n };\r\n\r\n this._mousedown = window.addEventListener(\r\n 'mousedown',\r\n (event: MouseEvent) => {\r\n this.activePath = true;\r\n this.context.beginPath();\r\n this.previousPosition = this.getMousePosition(event);\r\n }\r\n );\r\n\r\n this._mousemove = window.addEventListener('mousemove', (event) => {\r\n event.preventDefault();\r\n if (this.activePath) {\r\n this._drawLine(event);\r\n }\r\n });\r\n\r\n this._mouseup = window.addEventListener('mouseup', () => {\r\n if (this.activePath) {\r\n this.context.closePath();\r\n this.activePath = false;\r\n }\r\n });\r\n }\r\n\r\n public save(): void {\r\n const dataUrl = this.canvas.nativeElement.toDataURL('image/png');\r\n const blob = this._dataURItoBlob(dataUrl);\r\n this.savedImage.next(new File([blob], 'image.png'));\r\n }\r\n\r\n public clear(): void {\r\n this.context.clearRect(0, 0, this.width, this.height);\r\n const image = new Image();\r\n image.src = this.src;\r\n image.onload = () => {\r\n this.context.drawImage(image, 0, 0, this.width, this.height);\r\n };\r\n }\r\n\r\n private _dataURItoBlob(dataUrl: string) {\r\n const byteString = atob(dataUrl.split(',')[1]);\r\n const mimeString = dataUrl.split(',')[0].split(':')[1].split(';')[0];\r\n const ab = new ArrayBuffer(byteString.length);\r\n const dw = new DataView(ab);\r\n for (let i = 0; i < byteString.length; i++) {\r\n dw.setUint8(i, byteString.charCodeAt(i));\r\n }\r\n return new Blob([ab], { type: mimeString });\r\n }\r\n\r\n private _drawLine(event: MouseEvent): void {\r\n const currentPosition = this.getMousePosition(event);\r\n this.context.moveTo(this.previousPosition.x, this.previousPosition.y);\r\n this.context.lineTo(currentPosition.x, currentPosition.y);\r\n this.previousPosition = currentPosition;\r\n this.context.stroke();\r\n }\r\n\r\n private getMousePosition(event: MouseEvent): { x: number; y: number } {\r\n const rect = this.canvas.nativeElement.getBoundingClientRect();\r\n const scaleX = this.canvas.nativeElement.width / rect.width;\r\n const scaleY = this.canvas.nativeElement.height / rect.height;\r\n return {\r\n x: (event.clientX - rect.left) * scaleX,\r\n y: (event.clientY - rect.top) * scaleY,\r\n };\r\n }\r\n\r\n ngOnDestroy(): void {\r\n window.removeEventListener('mousedown', this._mousedown);\r\n window.removeEventListener('mousemove', this._mousemove);\r\n window.removeEventListener('mouseup', this._mouseup);\r\n }\r\n}\r\n","/*\r\n * Public API Surface of ngx-easy-image-drawing\r\n */\r\n\r\nexport * from './lib/ngx-easy-image-drawing.component';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":";;;MAkBa,4BAA4B,CAAA;AAPzC,IAAA,WAAA,GAAA;QAQW,IAAK,CAAA,KAAA,GAAW,GAAG,CAAC;QACpB,IAAM,CAAA,MAAA,GAAW,GAAG,CAAC;QACrB,IAAS,CAAA,SAAA,GAAG,CAAC,CAAC;QACd,IAAS,CAAA,SAAA,GAAG,SAAS,CAAC;QACtB,IAAG,CAAA,GAAA,GAAG,EAAE,CAAC;AACR,QAAA,IAAA,CAAA,UAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;QAMxC,IAAgB,CAAA,gBAAA,GAA6B,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;QAC5D,IAAU,CAAA,UAAA,GAAG,KAAK,CAAC;QAEnB,IAAU,CAAA,UAAA,GAAQ,IAAI,CAAC;QACvB,IAAU,CAAA,UAAA,GAAQ,IAAI,CAAC;QACvB,IAAQ,CAAA,QAAA,GAAQ,IAAI,CAAC;AA2F9B,KAAA;IAzFC,eAAe,GAAA;QACb,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QAC7C,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;AAE/C,QAAA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,CAAE,CAAC;QAC3D,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC;AAC1C,QAAA,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;;AAG/B,QAAA,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;AAC1B,QAAA,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;AACrB,QAAA,KAAK,CAAC,MAAM,GAAG,MAAK;AAClB,YAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AAC/D,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,gBAAgB,CACvC,WAAW,EACX,CAAC,KAAiB,KAAI;AACpB,YAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;AACvB,YAAA,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;YACzB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;AACvD,SAAC,CACF,CAAC;AAEF,QAAA,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,KAAK,KAAI;YAC/D,KAAK,CAAC,cAAc,EAAE,CAAC;AACvB,YAAA,IAAI,IAAI,CAAC,UAAU,EAAE;AACnB,gBAAA,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;aACvB;AACH,SAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,MAAK;AACtD,YAAA,IAAI,IAAI,CAAC,UAAU,EAAE;AACnB,gBAAA,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;AACzB,gBAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;aACzB;AACH,SAAC,CAAC,CAAC;KACJ;IAEM,IAAI,GAAA;AACT,QAAA,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACjE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;AAC1C,QAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC;KACrD;IAEM,KAAK,GAAA;AACV,QAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AACtD,QAAA,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;AAC1B,QAAA,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;AACrB,QAAA,KAAK,CAAC,MAAM,GAAG,MAAK;AAClB,YAAA,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AAC/D,SAAC,CAAC;KACH;AAEO,IAAA,cAAc,CAAC,OAAe,EAAA;AACpC,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,EAAE,GAAG,IAAI,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAC9C,QAAA,MAAM,EAAE,GAAG,IAAI,QAAQ,CAAC,EAAE,CAAC,CAAC;AAC5B,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AAC1C,YAAA,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SAC1C;AACD,QAAA,OAAO,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;KAC7C;AAEO,IAAA,SAAS,CAAC,KAAiB,EAAA;QACjC,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;AACrD,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;AACtE,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC;AAC1D,QAAA,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;AACxC,QAAA,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;KACvB;AAEO,IAAA,gBAAgB,CAAC,KAAiB,EAAA;QACxC,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;AAC/D,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;AAC5D,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC9D,OAAO;YACL,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,IAAI,MAAM;YACvC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,IAAI,MAAM;SACvC,CAAC;KACH;IAED,WAAW,GAAA;QACT,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACzD,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QACzD,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;KACtD;8GA3GU,4BAA4B,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;AAA5B,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,4BAA4B,gVAH7B,CAAwC,sCAAA,CAAA,EAAA,QAAA,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,CAAA,CAAA,EAAA;;2FAGvC,4BAA4B,EAAA,UAAA,EAAA,CAAA;kBAPxC,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,4BAA4B,EAC1B,UAAA,EAAA,IAAI,EACP,OAAA,EAAA,EAAE,YACD,CAAwC,sCAAA,CAAA,EAAA,CAAA;8BAIzC,KAAK,EAAA,CAAA;sBAAb,KAAK;gBACG,MAAM,EAAA,CAAA;sBAAd,KAAK;gBACG,SAAS,EAAA,CAAA;sBAAjB,KAAK;gBACG,SAAS,EAAA,CAAA;sBAAjB,KAAK;gBACG,GAAG,EAAA,CAAA;sBAAX,KAAK;gBACI,UAAU,EAAA,CAAA;sBAAnB,MAAM;gBAGqB,MAAM,EAAA,CAAA;sBAAjC,SAAS;uBAAC,eAAe,CAAA;;;AC3B5B;;AAEG;;ACFH;;AAEG;;;;"}
package/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="ngx-easy-image-drawing" />
5
+ export * from './public-api';
@@ -0,0 +1,26 @@
1
+ import { ElementRef, AfterViewInit, EventEmitter, OnDestroy } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class NgxEasyImageDrawingComponent implements AfterViewInit, OnDestroy {
4
+ width: number;
5
+ height: number;
6
+ lineWidth: number;
7
+ lineColor: string;
8
+ src: string;
9
+ savedImage: EventEmitter<File>;
10
+ canvas: ElementRef<HTMLCanvasElement>;
11
+ context: CanvasRenderingContext2D;
12
+ private previousPosition;
13
+ private activePath;
14
+ private _mousedown;
15
+ private _mousemove;
16
+ private _mouseup;
17
+ ngAfterViewInit(): void;
18
+ save(): void;
19
+ clear(): void;
20
+ private _dataURItoBlob;
21
+ private _drawLine;
22
+ private getMousePosition;
23
+ ngOnDestroy(): void;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<NgxEasyImageDrawingComponent, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<NgxEasyImageDrawingComponent, "lib-ngx-easy-image-drawing", never, { "width": { "alias": "width"; "required": false; }; "height": { "alias": "height"; "required": false; }; "lineWidth": { "alias": "lineWidth"; "required": false; }; "lineColor": { "alias": "lineColor"; "required": false; }; "src": { "alias": "src"; "required": false; }; }, { "savedImage": "savedImage"; }, never, never, true, never>;
26
+ }
package/package.json ADDED
@@ -0,0 +1,36 @@
1
+ {
2
+ "name": "ngx-easy-image-drawing",
3
+ "version": "0.0.1",
4
+ "peerDependencies": {
5
+ "@angular/common": "^18.1.0",
6
+ "@angular/core": "^18.1.0"
7
+ },
8
+ "description": "Angular library for easy image drawing on canvas",
9
+ "dependencies": {
10
+ "tslib": "^2.3.0"
11
+ },
12
+ "sideEffects": false,
13
+ "module": "fesm2022/ngx-easy-image-drawing.mjs",
14
+ "typings": "index.d.ts",
15
+ "exports": {
16
+ "./package.json": {
17
+ "default": "./package.json"
18
+ },
19
+ ".": {
20
+ "types": "./index.d.ts",
21
+ "esm2022": "./esm2022/ngx-easy-image-drawing.mjs",
22
+ "esm": "./esm2022/ngx-easy-image-drawing.mjs",
23
+ "default": "./fesm2022/ngx-easy-image-drawing.mjs"
24
+ }
25
+ },
26
+ "git repository": "",
27
+ "keywords": [
28
+ "image",
29
+ "drawing",
30
+ "canvas",
31
+ "angular",
32
+ "ngx"
33
+ ],
34
+ "author": "Alex Voronin <alex.varonin@gmail.com>",
35
+ "license": "ISC"
36
+ }
@@ -0,0 +1 @@
1
+ export * from './lib/ngx-easy-image-drawing.component';