ngx-scandoc 1.2.4 → 1.3.0

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.
Files changed (54) hide show
  1. package/core/components/components.module.d.ts +10 -7
  2. package/core/components/manual-scan/manual-scan.component.d.ts +61 -0
  3. package/core/components/scan/scan.component.d.ts +21 -24
  4. package/core/components/scan-results/scan-results.component.d.ts +11 -4
  5. package/core/components/webcam/util/webcam.util.d.ts +1 -1
  6. package/core/components/webcam/webcam/webcam.component.d.ts +26 -180
  7. package/core/components/webcam/webcam.module.d.ts +2 -0
  8. package/core/interfaces/config.d.ts +4 -0
  9. package/dialogs/components/prompt-manual/prompt-manual.component.d.ts +12 -0
  10. package/dialogs/components/scan-profile/scan-profile.component.d.ts +6 -1
  11. package/dialogs/components/scan-selfie/scan-selfie.component.d.ts +15 -61
  12. package/dialogs/dialogs.core.provider.d.ts +1 -0
  13. package/dialogs/dialogs.module.d.ts +12 -9
  14. package/esm2020/core/components/camera-switch/camera-switch.component.mjs +6 -4
  15. package/esm2020/core/components/components.module.mjs +32 -10
  16. package/esm2020/core/components/manual-scan/manual-scan.component.mjs +290 -0
  17. package/esm2020/core/components/scan/scan.component.mjs +290 -181
  18. package/esm2020/core/components/scan-results/scan-results.component.mjs +38 -12
  19. package/esm2020/core/components/webcam/util/webcam.util.mjs +7 -5
  20. package/esm2020/core/components/webcam/webcam/webcam.component.mjs +296 -772
  21. package/esm2020/core/components/webcam/webcam.module.mjs +8 -1
  22. package/esm2020/core/interfaces/config.mjs +1 -1
  23. package/esm2020/dialogs/components/confirm/confirm.component.mjs +3 -3
  24. package/esm2020/dialogs/components/prompt-manual/prompt-manual.component.mjs +30 -0
  25. package/esm2020/dialogs/components/scan-profile/scan-profile.component.mjs +36 -17
  26. package/esm2020/dialogs/components/scan-selfie/scan-selfie.component.mjs +41 -336
  27. package/esm2020/dialogs/dialogs.core.provider.mjs +12 -1
  28. package/esm2020/dialogs/dialogs.module.mjs +24 -11
  29. package/esm2020/forms/types/avatar.type.mjs +26 -21
  30. package/esm2020/forms/types/profile.image.type.mjs +51 -41
  31. package/esm2020/forms/types/title.type.mjs +7 -35
  32. package/esm2020/lib/ngx-scandoc.module.mjs +8 -6
  33. package/esm2020/providers/auth.provider.mjs +15 -2
  34. package/esm2020/providers/camera.provider.mjs +37 -4
  35. package/esm2020/providers/interceptor.provider.mjs +2 -2
  36. package/esm2020/providers/layout.provider.mjs +7 -5
  37. package/esm2020/providers/scan.form.mjs +173 -215
  38. package/esm2020/providers/scan.provider.mjs +264 -7
  39. package/esm2020/providers/translation.provider.mjs +18 -23
  40. package/esm2020/public-api.mjs +3 -1
  41. package/fesm2015/ngx-scandoc.mjs +1722 -1988
  42. package/fesm2015/ngx-scandoc.mjs.map +1 -1
  43. package/fesm2020/ngx-scandoc.mjs +1719 -1982
  44. package/fesm2020/ngx-scandoc.mjs.map +1 -1
  45. package/forms/types/avatar.type.d.ts +1 -0
  46. package/forms/types/profile.image.type.d.ts +6 -1
  47. package/lib/ngx-scandoc.module.d.ts +2 -3
  48. package/package.json +1 -1
  49. package/providers/camera.provider.d.ts +17 -1
  50. package/providers/layout.provider.d.ts +3 -1
  51. package/providers/scan.form.d.ts +2 -0
  52. package/providers/scan.provider.d.ts +6 -1
  53. package/public-api.d.ts +2 -0
  54. package/src/assets/i18n/en.json +14 -3
@@ -1,10 +1,6 @@
1
- import { Component, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { WebcamImage } from '../domain/webcam-image';
3
- import { from, Observable, of } from 'rxjs';
4
- import { WebcamUtil } from '../util/webcam.util';
5
- import { Breakpoints, } from '@angular/cdk/layout';
6
- import { switchMap } from 'rxjs/operators';
7
- import { workertext } from '../../../app.worker';
3
+ import { from } from 'rxjs';
8
4
  import { BaseComponent } from '../../base.component';
9
5
  import * as i0 from "@angular/core";
10
6
  import * as i1 from "@angular/cdk/layout";
@@ -19,313 +15,183 @@ export class WebcamComponent extends BaseComponent {
19
15
  this.cd = cd;
20
16
  this.zone = zone;
21
17
  this.cameraProvider = cameraProvider;
22
- /** Defines the max width of the webcam area in px */
23
- this.width = 640;
24
- /** Defines the max height of the webcam area in px */
25
- this.height = 480;
26
- /** Defines base constraints to apply when requesting video track from UserMedia */
27
- this.videoOptions = WebcamComponent.DEFAULT_VIDEO_OPTIONS;
28
- /** Flag to enable/disable camera switch. If enabled, a switch icon will be displayed if multiple cameras were found */
29
- this.allowCameraSwitch = true;
30
- /** Flag to control whether an ImageData object is stored into the WebcamImage object. */
31
- this.captureImageData = false;
32
- /** The image type to use when capturing snapshots */
33
- this.imageType = WebcamComponent.DEFAULT_IMAGE_TYPE;
34
- /** The image quality to use when capturing snapshots (number between 0 and 1) */
35
- this.imageQuality = WebcamComponent.DEFAULT_IMAGE_QUALITY;
36
- /** EventEmitter which fires when an image has been captured */
37
- this.imageCapture = new EventEmitter();
38
- /** Emits a mediaError if webcam cannot be initialized (e.g. missing user permissions) */
39
- this.initError = new EventEmitter();
40
- /** Emits when the webcam video was clicked */
41
- this.imageClick = new EventEmitter();
42
- /** Emits the active deviceId after the active video device was switched */
18
+ this.canvasSize = { width: 0, height: 0 };
19
+ this.showVideo = false;
20
+ this.canvasData = {
21
+ ctx: null,
22
+ ctxO: null,
23
+ };
24
+ this.chunks = [];
43
25
  this.cameraSwitched = new EventEmitter();
44
26
  this.videoReady = new EventEmitter();
45
- this.showVideo = false;
46
- this.destroyed = new EventEmitter();
47
- /** available video devices */
48
- this.availableVideoInputs = [];
49
- /** Indicates whether the video device is ready to be switched */
50
- this.videoInitialized = false;
51
- this.canvasEl = document.createElement('canvas');
52
- /** Index of active video in availableVideoInputs */
53
- this.activeVideoInputIndex = -1;
54
- /** MediaStream object in use for streaming UserMedia data */
55
- this.mediaStream = null;
56
- this.shutdown = false;
57
- this.canStart = true;
58
- this.videoSize = { width: 1920, height: 1080 };
59
- this.canvasSize = { width: 1280, height: 720 };
60
- this.landscape = true;
61
- // if (typeof Worker !== 'undefined') {
62
- // // Create a new
63
- // this.worker = new Worker(
64
- // new URL('./../../../../app/app.worker', import.meta.url)
65
- // );
66
- // this.worker.onmessage = ({ data }) => {
67
- // console.log(`page got message: ${data}`);
68
- // };
69
- // console.log('POST');
70
- // this.worker.postMessage('hello');
71
- // } else {
72
- // // Web workers are not supported in this environment.
73
- // // You should add a fallback so that your program still executes correctly.
74
- // }
75
- }
76
- /**
77
- * If the given Observable emits, an image will be captured and emitted through 'imageCapture' EventEmitter
78
- */
79
- set trigger(trigger) {
80
- if (this.triggerSubscription) {
81
- this.triggerSubscription.unsubscribe();
82
- }
83
- // Subscribe to events from this Observable to take snapshots
84
- this.triggerSubscription = trigger.subscribe((time) => {
85
- this.takeSnapshot(time);
86
- });
27
+ this.imageCapture = new EventEmitter();
28
+ this.initError = new EventEmitter();
87
29
  }
88
30
  onResize() {
31
+ this.cameraProvider.rectPosition.t = 0;
89
32
  // this.videoReady.next(false);
90
- this.resizeStage();
91
- }
92
- /**
93
- * Get MediaTrackConstraints to request streaming the given device
94
- * @param deviceId
95
- * @param baseMediaTrackConstraints base constraints to merge deviceId-constraint into
96
- * @returns
97
- */
98
- static getMediaConstraintsForDevice(deviceId, baseMediaTrackConstraints) {
99
- const result = baseMediaTrackConstraints
100
- ? baseMediaTrackConstraints
101
- : this.DEFAULT_VIDEO_OPTIONS;
102
- if (deviceId) {
103
- result.deviceId = { exact: deviceId };
33
+ if (this.resizeTimeout) {
34
+ clearTimeout(this.resizeTimeout);
104
35
  }
105
- return result;
36
+ this.resizeTimeout = setTimeout(() => {
37
+ this.drawRectangle();
38
+ }, 50);
106
39
  }
107
- /**
108
- * Tries to harvest the deviceId from the given mediaStreamTrack object.
109
- * Browsers populate this object differently; this method tries some different approaches
110
- * to read the id.
111
- * @param mediaStreamTrack
112
- * @returns deviceId if found in the mediaStreamTrack
113
- */
114
- static getDeviceIdFromMediaStreamTrack(mediaStreamTrack) {
115
- if (mediaStreamTrack.getSettings &&
116
- mediaStreamTrack.getSettings() &&
117
- mediaStreamTrack.getSettings().deviceId) {
118
- return mediaStreamTrack.getSettings().deviceId;
119
- }
120
- else if (mediaStreamTrack.getConstraints &&
121
- mediaStreamTrack.getConstraints() &&
122
- mediaStreamTrack.getConstraints().deviceId) {
123
- const deviceIdObj = mediaStreamTrack.getConstraints().deviceId;
124
- return WebcamComponent.getValueFromConstrainDOMString(deviceIdObj);
125
- }
40
+ ngAfterViewInit() {
41
+ console.warn('[video] start');
42
+ // initial load
43
+ this.__subs(this.cameraProvider.getDevices()).subscribe((resp) => {
44
+ this.init();
45
+ });
46
+ // camera switch
47
+ this.__subs(this.cameraProvider.webcamObservable).subscribe((device) => {
48
+ const videoTrackConstraints = this.setConstraints();
49
+ this.stopAllTracks();
50
+ this.showVideo = false;
51
+ this.cd.detectChanges();
52
+ videoTrackConstraints.deviceId = device;
53
+ this.setup(videoTrackConstraints);
54
+ });
55
+ this.__subs(this.trigger).subscribe((time) => this.takeSnapshot(time));
126
56
  }
127
- /**
128
- * Tries to harvest the facingMode from the given mediaStreamTrack object.
129
- * Browsers populate this object differently; this method tries some different approaches
130
- * to read the value.
131
- * @param mediaStreamTrack
132
- * @returns facingMode if found in the mediaStreamTrack
133
- */
134
- static getFacingModeFromMediaStreamTrack(mediaStreamTrack) {
135
- if (mediaStreamTrack) {
136
- if (mediaStreamTrack.getSettings &&
137
- mediaStreamTrack.getSettings() &&
138
- mediaStreamTrack.getSettings().facingMode) {
139
- return mediaStreamTrack.getSettings().facingMode;
140
- }
141
- else if (mediaStreamTrack.getConstraints &&
142
- mediaStreamTrack.getConstraints() &&
143
- mediaStreamTrack.getConstraints().facingMode) {
144
- const facingModeConstraint = mediaStreamTrack.getConstraints().facingMode;
145
- return WebcamComponent.getValueFromConstrainDOMString(facingModeConstraint);
146
- }
147
- }
57
+ get video() {
58
+ return this.videoRef.nativeElement;
148
59
  }
149
- /**
150
- * Determines whether the given mediaStreamTrack claims itself as user facing
151
- * @param mediaStreamTrack
152
- */
153
- static isUserFacing(mediaStreamTrack) {
154
- const facingMode = WebcamComponent.getFacingModeFromMediaStreamTrack(mediaStreamTrack);
155
- return facingMode ? 'user' === facingMode.toLowerCase() : false;
60
+ get isMobile() {
61
+ return this.platform.ANDROID || this.platform.IOS;
156
62
  }
157
- /**
158
- * Extracts the value from the given ConstrainDOMString
159
- * @param constrainDOMString
160
- */
161
- static getValueFromConstrainDOMString(constrainDOMString) {
162
- if (constrainDOMString) {
163
- if (constrainDOMString instanceof String) {
164
- return String(constrainDOMString);
165
- }
166
- else if (Array.isArray(constrainDOMString) &&
167
- Array(constrainDOMString).length > 0) {
168
- return String(constrainDOMString[0]);
169
- }
170
- else if (typeof constrainDOMString === 'object') {
171
- if (constrainDOMString['exact']) {
172
- return String(constrainDOMString['exact']);
63
+ setConstraints() {
64
+ const out = {};
65
+ switch (this.type) {
66
+ default:
67
+ if (this.isMobile) {
68
+ out.video = { height: { ideal: 1600 }, width: { ideal: 1600 } };
173
69
  }
174
- else if (constrainDOMString['ideal']) {
175
- return String(constrainDOMString['ideal']);
70
+ else {
71
+ out.video = { height: { ideal: 1080 }, width: { ideal: 1920 } };
176
72
  }
177
- }
73
+ out.video.facingMode = 'environment';
74
+ break;
75
+ case 'selfie':
76
+ if (this.isMobile) {
77
+ out.video = { height: { ideal: 1600 }, width: { ideal: 1600 } };
78
+ }
79
+ else {
80
+ out.video = { height: { ideal: 1080 }, width: { ideal: 1920 } };
81
+ }
82
+ out.video.facingMode = 'user';
83
+ break;
178
84
  }
179
- return null;
85
+ return out.video;
180
86
  }
181
- resizeStage() {
182
- setTimeout(() => {
183
- this.updateSize();
184
- this.updatecanvasSize();
185
- this.drawRectangle();
186
- this.cd.detectChanges();
187
- this.videoReady.next(true);
188
- }, 10);
189
- }
190
- get canvasHeight() {
191
- const landscape = this.width > this.height;
192
- const aspect = this.videoSize.width / this.videoSize.height;
193
- if (!landscape) {
194
- return this.width * aspect;
195
- }
196
- return this.height;
87
+ get activeTrackSettings() {
88
+ return this.mediaStream.getVideoTracks()[0].getSettings();
197
89
  }
198
- updatecanvasSize() {
199
- // console.log(this.width, this.height);
200
- const landscape = this.width > this.height;
201
- const aspect = this.videoSize.width / this.videoSize.height;
202
- let width = this.width;
203
- let height = this.height;
204
- if (landscape) {
205
- height = width / aspect;
206
- }
207
- else {
208
- height = width / aspect;
209
- }
210
- if (height > this.height) {
211
- height = this.height;
212
- width = this.height * aspect;
90
+ get activeTrackCapabilities() {
91
+ try {
92
+ return this.mediaStream.getVideoTracks()[0].getCapabilities();
213
93
  }
214
- this.canvasSize = { width: Math.round(width), height: Math.round(height) };
215
- console.log(this.canvasSize, this.videoSize);
216
- if (this.isMobile) {
217
- this.video.nativeElement.setAttribute('height', this.canvasSize.height);
218
- this.video.nativeElement.setAttribute('width', this.canvasSize.width);
94
+ catch (e) {
95
+ return {};
219
96
  }
220
- else {
221
- if (this.videoSize.width > this.videoSize.hight) {
222
- this.video.nativeElement.setAttribute('height', this.canvasSize.height);
223
- }
224
- else {
225
- this.video.nativeElement.setAttribute('width', this.canvasSize.width);
226
- }
227
- }
228
- this.drawRectangle();
229
- this.cd.detectChanges();
230
97
  }
231
- setupWorker() {
232
- if (typeof Worker !== 'undefined') {
233
- // Create a new
234
- if (this.type !== 'selfie') {
235
- this.zone.runOutsideAngular(() => {
236
- var blob = new Blob([workertext], { type: 'text/javascript' });
237
- var url = URL.createObjectURL(blob);
238
- this.worker = new Worker(url);
239
- this.worker.onmessage = ({ data }) => {
240
- if (data.base64) {
241
- data.type == 'data';
242
- this.imageHandler.next(data);
243
- }
244
- };
245
- });
246
- }
247
- }
98
+ init() {
99
+ const videoTrackConstraints = this.setConstraints();
100
+ this.setup(videoTrackConstraints);
248
101
  }
249
- ngAfterViewInit() {
250
- this.setupWorker();
251
- if (this.imageHandler) {
252
- this.__subs(this.imageHandler).subscribe((resp) => {
253
- if (resp.type === 'stop') {
254
- this.worker?.postMessage({ type: 'stop' });
255
- }
256
- });
257
- }
258
- this.__subs(this.breakpointObserver
259
- .observe([Breakpoints.HandsetPortrait, Breakpoints.HandsetLandscape]))
260
- .subscribe((state) => {
261
- if (this.platform.IOS || this.platform.ANDROID) {
262
- // this.landscape = state.breakpoints[Breakpoints.HandsetLandscape];
263
- }
264
- const mobile = this.platform.IOS;
265
- if (state.matches && mobile) {
266
- this.updateSize();
267
- this.updatecanvasSize();
268
- this.drawRectangle();
269
- }
270
- });
271
- if (this.switchCamera) {
272
- if (this.switchCameraSubscription) {
273
- this.switchCameraSubscription.unsubscribe();
274
- }
275
- // Subscribe to events from this Observable to switch video device
276
- this.switchCameraSubscription = this.switchCamera.subscribe((value) => {
277
- this.switchToVideoInput(value);
278
- });
279
- }
280
- this.detectAvailableDevices()
281
- .then(() => {
282
- // start video
283
- if (this.canStart) {
284
- this.switchToVideoInput('');
285
- }
286
- })
287
- .catch((err) => {
288
- this.initError.next({ message: err });
289
- // fallback: still try to load webcam, even if device enumeration failed
290
- if (this.canStart) {
291
- this.switchToVideoInput('');
292
- }
102
+ setup(videoTrackConstraints) {
103
+ this.__subs(from(navigator.mediaDevices.getUserMedia({
104
+ video: videoTrackConstraints,
105
+ }))).subscribe((stream) => {
106
+ this.mediaStream = stream;
107
+ this.cameraProvider.deviceId = this.activeTrackSettings.deviceId;
108
+ this.startVideo();
293
109
  });
294
110
  }
295
- ngOnDestroy() {
296
- this.canStart = false;
297
- this.nativeVideoElement.pause();
298
- this.destroyed.emit(true);
299
- this.stopMediaTracks();
300
- this.unsubscribeFromSubscriptions();
301
- this.shutdown = true;
302
- // shut down worker
303
- if (this.imageHandler) {
304
- this.imageHandler.next({ type: 'stop' });
111
+ startVideo() {
112
+ console.log('START VIDEO');
113
+ this.video.srcObject = this.mediaStream;
114
+ this.video.onloadedmetadata = (data) => {
115
+ // console.log(data);
116
+ this.video.play();
117
+ this.showVideo = true;
118
+ this.cd.detectChanges();
119
+ console.log('VIDEO PLAY');
120
+ };
121
+ this.video.onplay = () => {
122
+ this.videoReady.next(true);
123
+ console.log(this.video.videoWidth, this.video.videoHeight);
124
+ this.drawRectangle();
125
+ };
126
+ }
127
+ setCanvas() {
128
+ let _canvas = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;
129
+ const { videoWidth, videoHeight } = this.video;
130
+ const aspect = videoWidth / videoHeight;
131
+ const canvasSmalSize = 384;
132
+ const smallSize = {
133
+ w: 0,
134
+ h: 0,
135
+ };
136
+ if (videoWidth >= videoHeight) {
137
+ smallSize.w = canvasSmalSize;
138
+ smallSize.h = canvasSmalSize / aspect;
305
139
  }
306
- if (this.nativeVideoElement.srcObject) {
307
- this.nativeVideoElement.srcObject
308
- .getTracks()
309
- .forEach((track) => {
310
- track.stop();
311
- });
312
- this.nativeVideoElement.srcObject = null;
140
+ else {
141
+ smallSize.h = canvasSmalSize;
142
+ smallSize.h = canvasSmalSize * aspect;
313
143
  }
314
- this.__destroy();
315
- // this.nativeVideoElement.src = null;
316
- // this.nativeVideoElement.srcObject = null;
144
+ console.log('SZ', smallSize);
145
+ _canvas.width = videoWidth;
146
+ _canvas.height = videoHeight;
147
+ const ctx = _canvas.getContext('2d', {
148
+ alpha: false,
149
+ powerPreference: 'high-performance',
150
+ antialias: false,
151
+ depth: false,
152
+ desynchronized: true,
153
+ });
154
+ const canvas = document.createElement('canvas'); // needs an initial size
155
+ canvas.height = smallSize.h;
156
+ canvas.width = smallSize.w;
157
+ const ctxO = canvas.getContext('2d', {
158
+ alpha: false,
159
+ powerPreference: 'high-performance',
160
+ antialias: false,
161
+ depth: false,
162
+ desynchronized: true,
163
+ });
164
+ this.canvasData.ctx = ctx;
165
+ this.canvasData.ctxO = ctxO;
166
+ this.canvasData.canvas = canvas;
167
+ this.canvasData._canvas = _canvas;
168
+ this.canvasData.size = smallSize;
169
+ // const stream = this.video.captureStream(5);
170
+ // const mediaRecorder = new MediaRecorder(stream);
171
+ // mediaRecorder.start();
172
+ // mediaRecorder.ondataavailable = (e:any) => {
173
+ // console.log(e)
174
+ // this.chunks.push(e.data);
175
+ // var url = window.URL.createObjectURL(e.data);
176
+ // var anchor = document.createElement('a');
177
+ // anchor.download = 'myfile.webm';
178
+ // anchor.href = url;
179
+ // anchor.click();
180
+ // };
317
181
  }
318
182
  takeSelfie() {
319
- const _video = this.nativeVideoElement;
320
- const mimeType = this.imageType
321
- ? this.imageType
322
- : WebcamComponent.DEFAULT_IMAGE_TYPE;
183
+ const mimeType = 'image/jpeg';
184
+ const { videoWidth, offsetWidth, videoHeight } = this.video;
323
185
  let _canvas = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;
324
- const { width, height } = this.videoSize;
325
- // console.log(width, height);
326
- const { padding, top, rWidth, rHeight } = this.snapRectangle;
327
- _canvas.width = rWidth;
328
- _canvas.height = rHeight;
186
+ const { w, h } = this.cameraProvider.rectPosition;
187
+ const aspect = videoWidth / offsetWidth;
188
+ // console.log(videoWidth, offsetWidth, l, t, w, h);
189
+ _canvas.width = w * aspect;
190
+ _canvas.height = h * aspect;
191
+ const dx = videoWidth - w * aspect;
192
+ const dy = videoHeight - h * aspect;
193
+ const x = dx / 2;
194
+ const y = dy / 2;
329
195
  const ctx = _canvas.getContext('2d', {
330
196
  alpha: false,
331
197
  powerPreference: 'high-performance',
@@ -334,58 +200,69 @@ export class WebcamComponent extends BaseComponent {
334
200
  desynchronized: true,
335
201
  });
336
202
  if (ctx) {
337
- ctx.drawImage(_video, padding, top, rWidth, rHeight, 0, 0, rWidth, rHeight);
203
+ ctx.drawImage(this.video, x, y, w * aspect, h * aspect, 0, 0, w * aspect, h * aspect);
338
204
  const imgAsUrl = _canvas.toDataURL(mimeType, 1);
339
205
  this.imageCapture.emit(new WebcamImage(imgAsUrl, mimeType, new ImageData(1, 1), null));
340
206
  }
341
207
  }
342
- /**
343
- * Takes a snapshot of the current webcam's view and emits the image as an event
344
- */
345
208
  takeSnapshot(time) {
346
- if (this.type === 'selfie') {
209
+ if (this.type !== 'document') {
347
210
  this.takeSelfie();
348
211
  return;
349
212
  }
350
- if (this.trackProcessor) {
213
+ console.warn('SNAP', time);
214
+ if (!this.showVideo) {
351
215
  return;
352
216
  }
353
217
  this.zone.runOutsideAngular(() => {
354
218
  const canvasSmalSize = 384;
355
- const _video = this.nativeVideoElement;
356
- const mimeType = this.imageType
357
- ? this.imageType
358
- : WebcamComponent.DEFAULT_IMAGE_TYPE;
359
- let _canvas = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;
360
- const { width, height } = this.videoSize;
361
- _canvas.width = width;
362
- _canvas.height = height;
363
- const ctx = _canvas.getContext('2d', {
364
- alpha: false,
365
- powerPreference: 'high-performance',
366
- antialias: false,
367
- depth: false,
368
- desynchronized: true,
369
- });
370
- const canvas = document.createElement('canvas'); // needs an initial size
371
- canvas.height = canvasSmalSize;
372
- canvas.width = canvasSmalSize;
373
- const ctxO = canvas.getContext('2d', {
374
- alpha: false,
375
- powerPreference: 'high-performance',
376
- antialias: false,
377
- depth: false,
378
- desynchronized: true,
379
- });
219
+ const mimeType = 'image/jpeg';
220
+ // let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;
221
+ const { videoWidth, videoHeight } = this.video;
222
+ // _canvas.width = videoWidth;
223
+ // _canvas.height = videoHeight;
224
+ // console.log(videoWidth, videoHeight);
225
+ // const ctx: any = _canvas.getContext('2d', {
226
+ // alpha: false,
227
+ // powerPreference: 'high-performance',
228
+ // antialias: false,
229
+ // depth: false,
230
+ // desynchronized: true,
231
+ // });
232
+ // const canvas = document.createElement('canvas'); // needs an initial size
233
+ // canvas.height = canvasSmalSize;
234
+ // canvas.width = canvasSmalSize;
235
+ // const ctxO: any = canvas.getContext('2d', {
236
+ // alpha: false,
237
+ // powerPreference: 'high-performance',
238
+ // antialias: false,
239
+ // depth: false,
240
+ // desynchronized: true,
241
+ // });
242
+ const { ctx, ctxO, canvas, _canvas, size } = this.canvasData;
380
243
  if (ctx && ctxO) {
381
244
  ctx.imageSmoothingEnabled = false;
382
- ctx.drawImage(_video, 0, 0);
383
- ctxO.drawImage(_video, 0, 0, canvasSmalSize, canvasSmalSize);
384
- const imData = ctx.getImageData(0, 0, this.videoSize.width, this.videoSize.height);
245
+ const drawStart = Date.now();
246
+ ctx.clearRect(0, 0, videoWidth, videoHeight);
247
+ ctxO.clearRect(0, 0, size.w, size.h);
248
+ ctx.drawImage(this.video, 0, 0);
249
+ console.time('drawVideo');
250
+ ctxO.drawImage(_canvas, 0, 0, size.w, size.h);
251
+ console.timeEnd('drawVideo');
252
+ console.time('DRAW');
253
+ const imData = ctx.getImageData(0, 0, videoWidth, videoHeight);
254
+ console.timeEnd('DRAW');
255
+ console.time('CTX');
385
256
  const resize = canvas.toDataURL(mimeType, 1);
257
+ console.timeEnd('CTX');
386
258
  const currentTime = new Date().getTime();
387
259
  const diff = currentTime - time;
388
- const delay = diff > 100 ? 0 : 100 - diff;
260
+ // total time for pack one image
261
+ const drawTime = Date.now() - drawStart;
262
+ console.warn('DRAW TIME', drawTime);
263
+ const delayMax = drawTime < 60 ? 100 : 200;
264
+ const delay = diff > delayMax ? 0 : delayMax - diff;
265
+ console.warn(this.chunks);
389
266
  const timeout = setTimeout(() => {
390
267
  this.imageCapture.emit(new WebcamImage('', mimeType, imData, resize));
391
268
  clearTimeout(timeout);
@@ -393,481 +270,128 @@ export class WebcamComponent extends BaseComponent {
393
270
  }
394
271
  });
395
272
  }
396
- update() { }
397
- resizeImage(base64data) {
398
- return new Observable((observer) => {
399
- let canvas = document.createElement('canvas');
400
- const ctx = canvas.getContext('2d');
401
- const max_size = 384;
402
- let image = new Image();
403
- image.src = base64data;
404
- image.onload = () => {
405
- let width = image.width;
406
- let height = image.height;
407
- if (width < height) {
408
- height *= max_size / width;
409
- width = max_size;
410
- }
411
- else {
412
- width *= max_size / height;
413
- height = max_size;
414
- }
415
- canvas.width = width;
416
- canvas.height = height;
417
- // console.log(width, height);
418
- if (ctx) {
419
- // ctx.rotate((90 * Math.PI) / 180);
420
- // ctx.translate(0, -canvas.width);
421
- ctx.drawImage(image, 0, 0, 384, 384);
422
- observer.next(canvas.toDataURL());
423
- ctx.clearRect(0, 0, 1, 1);
424
- }
425
- else {
426
- observer.error({ type: 'generic error' });
427
- }
428
- image = null;
429
- canvas = null;
430
- };
431
- image.onerror = (e) => {
432
- observer.error(e);
433
- };
434
- });
435
- }
436
- /**
437
- * Switches to the next/previous video device
438
- * @param forward
439
- */
440
- rotateVideoInput(forward) {
441
- if (this.availableVideoInputs && this.availableVideoInputs.length > 1) {
442
- const increment = forward
443
- ? 1
444
- : this.availableVideoInputs.length - 1;
445
- const nextInputIndex = (this.activeVideoInputIndex + increment) %
446
- this.availableVideoInputs.length;
447
- this.switchToVideoInput(this.availableVideoInputs[nextInputIndex].deviceId);
448
- }
449
- }
450
- /**
451
- * Switches the camera-view to the specified video device
452
- */
453
- switchToVideoInput(deviceId) {
454
- // if(deviceId){
455
- this.videoInitialized = false;
456
- this.stopMediaTracks();
457
- this.initWebcam(deviceId, this.videoOptions);
458
- // }
459
- }
460
- /**
461
- * Event-handler for video resize event.
462
- * Triggers Angular change detection so that new video dimensions get applied
463
- */
464
- videoResize() {
465
- // here to trigger Angular change detection
466
- }
467
- get videoWidth() {
468
- const videoRatio = this.getVideoAspectRatio();
469
- return Math.min(this.width, this.height * videoRatio);
470
- }
471
- get videoHeight() {
472
- const videoRatio = this.getVideoAspectRatio();
473
- return Math.min(this.height, this.width / videoRatio);
474
- }
475
- get videoStyleClasses() {
476
- let classes = '';
477
- if (this.isMirrorImage()) {
478
- classes += 'mirrored ';
479
- }
480
- return classes.trim();
481
- }
482
- get nativeVideoElement() {
483
- return this.video.nativeElement;
484
- }
485
- // public get smallVideoElement() {
486
- // return this.videoSmall;
487
- // }
488
- /**
489
- * Returns the video aspect ratio of the active video stream
490
- */
491
- getVideoAspectRatio() {
492
- // calculate ratio from video element dimensions if present
493
- const videoElement = this.nativeVideoElement;
494
- if (videoElement.videoWidth &&
495
- videoElement.videoWidth > 0 &&
496
- videoElement.videoHeight &&
497
- videoElement.videoHeight > 0) {
498
- return videoElement.videoWidth / videoElement.videoHeight;
499
- }
500
- // nothing present - calculate ratio based on width/height params
501
- return this.width / this.height;
502
- }
503
- updateSize() {
504
- const track = this.mediaStream?.getTracks()[0];
505
- if (track) {
506
- let desired = {
507
- width: {
508
- ideal: 0,
509
- },
510
- height: {
511
- ideal: 0,
512
- },
513
- // facingMode:'user',
514
- frameRate: { min: 20, ideal: 24, max: 24 },
515
- };
516
- if (typeof track.getCapabilities === 'function') {
517
- const { width, height } = track.getCapabilities();
518
- desired = {
519
- width: {
520
- ideal: this.landscape && this.isMobile ? height?.max : width?.max,
521
- },
522
- height: {
523
- ideal: this.landscape && this.isMobile ? width?.max : height?.max,
524
- },
525
- // facingMode:'user',
526
- frameRate: { min: 20, ideal: 24, max: 24 },
527
- };
528
- }
529
- else {
530
- desired = {
531
- width: {
532
- ideal: 1920,
533
- },
534
- height: {
535
- ideal: 1080,
536
- },
537
- // facingMode:'user',
538
- frameRate: { min: 20, ideal: 30, max: 31 },
539
- };
540
- }
541
- // desired.height.ideal = 1000;
542
- // desired.width.ideal = 1000;
543
- if (desired.height.ideal && desired.height.ideal >= 1600) {
544
- desired.height.ideal = 1600;
545
- desired.width.ideal = 1600;
546
- }
547
- if (this.platform.ANDROID) {
548
- //desired.width.ideal = 2160;
549
- //desired.height.ideal = 2160;
550
- // if (!this.landscape) {
551
- // } else {
552
- // desired.width.ideal = width?.max;
553
- // desired.height.ideal = height?.max;
554
- // }
555
- }
556
- track.applyConstraints(desired);
557
- //track.getSettings().facingMode!=='user';
558
- this.videoSize = {
559
- height: this.landscape
560
- ? track.getSettings().height
561
- : track.getSettings().width,
562
- width: this.landscape
563
- ? track.getSettings().width
564
- : track.getSettings().height,
565
- };
566
- this.cd.detectChanges();
273
+ stopAllTracks() {
274
+ this.showVideo = false;
275
+ if (this.mediaStream && this.mediaStream.getTracks) {
276
+ // getTracks() returns all media tracks (video+audio)
277
+ this.mediaStream.getTracks().forEach((track) => {
278
+ track.stop();
279
+ this.video.srcObject.removeTrack(track);
280
+ this.mediaStream.removeTrack(track);
281
+ });
282
+ this.video.srcObject = null;
283
+ this.video.load();
567
284
  }
568
285
  }
569
- getStreamTrack(stream) {
570
- return stream.getVideoTracks()[0];
571
- }
572
- getTrackSettings() { }
573
- accesVideoTrack(videoTrackConstraints) {
574
- return from(navigator.mediaDevices.getUserMedia(videoTrackConstraints)).pipe(switchMap((stream) => {
575
- // default resolution 1280x720, check max resolution
576
- const track = this.getStreamTrack(stream);
577
- const capabilities = track.getCapabilities();
578
- const { facingMode, height, width } = capabilities;
579
- const desired = {
580
- width: {
581
- min: this.landscape && this.isMobile ? height?.max : width?.max,
582
- },
583
- // height: {
584
- // exact: this.landscape && this.isMobile ? width?.max : height?.max,
585
- // },
586
- // facingMode:'en',
587
- // frameRate: { min: 25, ideal: 30, max: 31 },
588
- };
589
- // get max width
590
- const { width: sWidth, height: sHeight } = track.getSettings();
591
- if (desired.width.min != sWidth) {
592
- return this.accesVideoTrack({ video: desired });
593
- }
594
- //return this.accesVideoTrack({video:desired});
595
- return of(stream);
596
- }));
597
- }
598
286
  drawRectangle() {
599
- const _canvas = this.canvas.nativeElement;
600
- const ctx = _canvas.getContext('2d');
601
- ctx.clearRect(0, 0, _canvas.width, _canvas.height);
602
- // ctx.drawImage(_video, 0, 0, _canvas.width, _canvas.height);
603
- const { padding, top, rWidth, rHeight } = this.cardRectangle;
604
- ctx.strokeStyle = 'red';
605
- ctx.strokeRect(padding, top, rWidth, rHeight);
606
- }
607
- getMaxAvailableResolution() { }
608
- /**
609
- * Init webcam live view
610
- */
611
- initWebcam(deviceId, userVideoTrackConstraints) {
612
- console.log('INIT WEBCAM');
613
- const _video = this.nativeVideoElement;
614
- // const videoStreamer = this.videoStreamer.nativeElement;
615
- // const videoSmall = document.createElement('video');
616
- if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {
617
- // merge deviceId -> userVideoTrackConstraints
618
- const videoTrackConstraints = WebcamComponent.getMediaConstraintsForDevice(deviceId, userVideoTrackConstraints);
619
- // // if (deviceId) {
620
- // this.accesVideoTrack({ video: videoTrackConstraints }).subscribe(
621
- // (stream: MediaStream) => {
622
- // console.log(
623
- // 'VALID SETTINGS',
624
- // stream.getVideoTracks()[0].getSettings()
625
- // );
626
- // }
627
- // );
628
- // }
629
- if (this.platform.ANDROID) {
630
- videoTrackConstraints.width = 1600;
631
- videoTrackConstraints.height = 1600;
287
+ this.zone.run(() => {
288
+ const _canvas = this.canvas.nativeElement;
289
+ let padding = 10;
290
+ if (!this.isMobile && _canvas.width !== _canvas.height) {
291
+ padding = 40;
632
292
  }
633
- const constraints = {
634
- exact: deviceId,
635
- width: { min: 480, ideal: 1280 },
636
- height: { min: 480, ideal: 720 },
637
- // aspectRatio: 3 / 2,
638
- frameRate: { min: 20 },
639
- };
640
- navigator.mediaDevices
641
- .getUserMedia({ video: videoTrackConstraints })
642
- .then((stream) => {
643
- this.mediaStream = stream;
644
- _video.srcObject = stream;
645
- this.updateSize();
646
- this.updatecanvasSize();
647
- _video.play();
648
- _video.onplay = () => {
649
- this.setActiveCamera(stream);
650
- this.drawRectangle();
651
- };
652
- })
653
- .catch((err) => {
654
- console.log(err);
655
- this.initError.next({
656
- message: err.message,
657
- mediaStreamError: err,
658
- });
659
- });
660
- }
661
- else {
662
- this.initError.next({
663
- message: 'Cannot read UserMedia from MediaDevices.',
664
- });
665
- }
666
- }
667
- get isMobile() {
668
- return this.platform.ANDROID || this.platform.IOS;
669
- }
670
- get cardRectangle() {
671
- const _canvas = this.canvas.nativeElement;
672
- const docSize = this.type === 'selfie' ? 1 : 86 / 55;
673
- // console.log(_canvas.width, _canvas.height);
674
- let padding = 10;
675
- let rWidth = _canvas.width - 2 * padding;
676
- let rHeight = rWidth / docSize;
677
- let top = (_canvas.height - rHeight) / 2;
678
- if ((!this.isMobile && _canvas.width !== _canvas.height)) {
679
- padding = 40;
680
- rHeight = _canvas.height - 2 * padding;
681
- rWidth = rHeight * docSize;
682
- top = (_canvas.height - rHeight) / 2;
683
- padding = (_canvas.width - rWidth) / 2;
684
- }
685
- // console.log(padding, top, rWidth, rHeight);
686
- return { padding, top, rWidth, rHeight };
687
- }
688
- get snapRectangle() {
689
- const _canvas = this.canvas.nativeElement;
690
- const ar = this.videoSize.width / _canvas.width;
691
- let { padding, top, rWidth, rHeight } = this.cardRectangle;
692
- padding = padding * ar;
693
- top = top * ar;
694
- rWidth = rWidth * ar;
695
- rHeight = rHeight * ar;
696
- return { padding, top, rWidth, rHeight };
697
- }
698
- setActiveCamera(stream) {
699
- this.videoReady.next(false);
700
- this.showVideo = false;
701
- this.activeVideoSettings = stream.getVideoTracks()[0].getSettings();
702
- const activeDeviceId = WebcamComponent.getDeviceIdFromMediaStreamTrack(stream.getVideoTracks()[0]);
703
- const videoTrack = stream.getTracks()[0];
704
- this.trackSettings = videoTrack.getSettings();
705
- this.cameraProvider.cameraWasSwitched(activeDeviceId);
706
- this.cameraSwitched.next(activeDeviceId);
707
- setTimeout(() => {
708
- this.zone.run(() => {
709
- this.resizeStage();
710
- this.showVideo = true;
711
- this.videoReady.next(true);
712
- if (MediaStreamTrackProcessor) {
713
- this.trackProcessor = new MediaStreamTrackProcessor(videoTrack);
714
- let frameStream = this.trackProcessor.readable;
715
- if (!this.shutdown) {
716
- this.worker?.postMessage({
717
- type: 'start',
718
- frameStream: frameStream,
719
- trackSettings: this.trackSettings,
720
- }, [frameStream]);
721
- }
293
+ const ctx = _canvas.getContext('2d');
294
+ console.log(ctx);
295
+ ctx.clearRect(0, 0, _canvas.width, _canvas.height);
296
+ const { width, height } = _canvas;
297
+ console.log(width, height);
298
+ const { videoWidth, videoHeight } = this.video;
299
+ const docSize = this.type === 'selfie' ? 1 : 86 / 55;
300
+ const aspect = videoWidth / videoHeight;
301
+ let _height;
302
+ let _width;
303
+ if (videoWidth >= videoHeight) {
304
+ _width = width;
305
+ _height = _width / aspect;
306
+ if (_height > height) {
307
+ _height = height;
308
+ _width = aspect * _height;
722
309
  }
723
- });
724
- }, 500);
725
- }
726
- getActiveVideoTrack() {
727
- return this.mediaStream ? this.mediaStream.getVideoTracks()[0] : null;
728
- }
729
- isMirrorImage() {
730
- if (!this.getActiveVideoTrack()) {
731
- return false;
732
- }
733
- // check for explicit mirror override parameter
734
- {
735
- let mirror = 'auto';
736
- if (this.mirrorImage) {
737
- if (typeof this.mirrorImage === 'string') {
738
- mirror = String(this.mirrorImage).toLowerCase();
739
- }
740
- else {
741
- // WebcamMirrorProperties
742
- if (this.mirrorImage.x) {
743
- mirror = this.mirrorImage.x.toLowerCase();
744
- }
310
+ }
311
+ else {
312
+ _height = height;
313
+ _width = aspect * _height;
314
+ if (_width > width) {
315
+ _width = width;
316
+ _height = _width / aspect;
745
317
  }
746
318
  }
747
- switch (mirror) {
748
- case 'always':
749
- return true;
750
- case 'never':
751
- return false;
319
+ let w, h;
320
+ if (_width <= _height) {
321
+ w = _width - 2 * padding;
322
+ h = w / docSize;
752
323
  }
753
- }
754
- // default: enable mirroring if webcam is user facing
755
- return WebcamComponent.isUserFacing(this.getActiveVideoTrack());
756
- }
757
- /**
758
- * Stops all active media tracks.
759
- * This prevents the webcam from being indicated as active,
760
- * even if it is no longer used by this component.
761
- */
762
- stopMediaTracks() {
763
- // this.video.nativeElement.pause();
764
- if (this.video.nativeElement.srcObject) {
765
- this.video.nativeElement.srcObject
766
- .getTracks()
767
- .forEach((track) => {
768
- track.stop();
769
- });
770
- this.video.nativeElement.srcObject = null;
771
- this.video.nativeElement.src = '';
772
- }
773
- if (this.mediaStream && this.mediaStream.getTracks) {
774
- // getTracks() returns all media tracks (video+audio)
775
- this.mediaStream
776
- .getTracks()
777
- .forEach((track) => track.stop());
778
- }
324
+ else {
325
+ h = _height - 2 * padding;
326
+ w = docSize * h;
327
+ }
328
+ h = Math.floor(h);
329
+ w = Math.floor(w);
330
+ console.log(_width, _height);
331
+ const left = Math.floor((width - w) / 2);
332
+ const top = Math.floor((height - h) / 2);
333
+ ctx.strokeStyle = 'red';
334
+ // ctx.strokeRect(left, top, _width, _height);
335
+ ctx.shadowColor = 'red';
336
+ ctx.shadowBlur = 15;
337
+ ctx.beginPath();
338
+ // Draw using 5px for border radius on all sides
339
+ // stroke it but no fill
340
+ ctx.roundRect(left, top, w, h, 5);
341
+ ctx.stroke();
342
+ this.cameraProvider.rectPosition = {
343
+ l: left,
344
+ t: top,
345
+ w,
346
+ h,
347
+ _w: _width,
348
+ _h: _height,
349
+ };
350
+ this.setCanvas();
351
+ // ctx.stroke();
352
+ });
779
353
  }
780
- /**
781
- * Unsubscribe from all open subscriptions
782
- */
783
- unsubscribeFromSubscriptions() {
354
+ ngOnDestroy() {
355
+ this.video.pause();
356
+ // this.video.getTracks().forEach((track: any) => {
357
+ // track.stop();
358
+ // this.video.srcObject.removeTrack(track);
359
+ // });
360
+ this.stopAllTracks();
784
361
  if (this.triggerSubscription) {
785
362
  this.triggerSubscription.unsubscribe();
786
363
  }
787
- if (this.switchCameraSubscription) {
788
- this.switchCameraSubscription.unsubscribe();
789
- }
790
- }
791
- /**
792
- * Reads available input devices
793
- */
794
- detectAvailableDevices() {
795
- return new Promise((resolve, reject) => {
796
- WebcamUtil.getAvailableVideoInputs().subscribe((devices) => {
797
- this.availableVideoInputs = devices;
798
- resolve(devices);
799
- }, (err) => {
800
- this.availableVideoInputs = [];
801
- reject(err);
802
- });
803
- });
364
+ this.__destroy();
365
+ console.warn('[VIDEO] destroyed');
804
366
  }
805
367
  }
806
- WebcamComponent.DEFAULT_VIDEO_OPTIONS = {
807
- facingMode: 'environment',
808
- };
809
- WebcamComponent.DEFAULT_IMAGE_TYPE = 'image/jpeg';
810
- WebcamComponent.DEFAULT_IMAGE_QUALITY = 1;
811
368
  WebcamComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WebcamComponent, deps: [{ token: i1.BreakpointObserver }, { token: i2.Platform }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i3.NgxScandocCameraProvider }], target: i0.ɵɵFactoryTarget.Component });
812
- WebcamComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WebcamComponent, selector: "ngx-scandoc-webcam", inputs: { imageHandler: "imageHandler", id: "id", type: "type", width: "width", height: "height", videoOptions: "videoOptions", allowCameraSwitch: "allowCameraSwitch", mirrorImage: "mirrorImage", captureImageData: "captureImageData", imageType: "imageType", imageQuality: "imageQuality", trigger: "trigger", switchCamera: "switchCamera" }, outputs: { imageCapture: "imageCapture", initError: "initError", imageClick: "imageClick", cameraSwitched: "cameraSwitched", videoReady: "videoReady", destroyed: "destroyed" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "video", first: true, predicate: ["video"], descendants: true, static: true }, { propertyName: "videoStreamer", first: true, predicate: ["videoStreamer"], descendants: true, static: true }, { propertyName: "canvas", first: true, predicate: ["canvas"], descendants: true, static: true }, { propertyName: "canvasSnapshot", first: true, predicate: ["canvasSnapshot"], descendants: true, static: true }, { propertyName: "canvasResize", first: true, predicate: ["canvasResize"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"webcam-wrapper\">\n <div>\n <video\n #video\n autoplay\n muted\n style=\"display: block\"\n playsinline\n\n ></video>\n\n <div class=\"rectangle\">\n\n <canvas\n #canvas\n [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n [width]=\"canvasSize.width\"\n [height]=\"canvasSize.height\"\n ></canvas>\n </div>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex:1;transform:transale3d(0,0,0);background-color:#000}.webcam-wrapper{display:flex;flex-direction:row;align-items:center;flex:1;justify-content:center;position:relative}.webcam-wrapper canvas{transform:transale3d(0,0,0);display:block;position:relative;z-index:20;left:0;top:0}.webcam-wrapper .rectangle{position:absolute;left:0;top:0;display:flex;flex-direction:row;align-items:center;justify-content:center;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
369
+ WebcamComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: WebcamComponent, selector: "ngx-scandoc-webcam", inputs: { imageHandler: "imageHandler", type: "type", trigger: "trigger" }, outputs: { cameraSwitched: "cameraSwitched", videoReady: "videoReady", imageCapture: "imageCapture", initError: "initError" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "canvas", first: true, predicate: ["canvas"], descendants: true, static: true }, { propertyName: "videoRef", first: true, predicate: ["video"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"webcam-wrapper\">\n <video #video autoplay muted style=\"display: block\" playsinline></video>\n\n <div class=\"rectangle\">\n <canvas\n #canvas\n [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n [width]=\"video.offsetWidth\"\n [height]=\"video.offsetHeight\"\n ></canvas>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex:1;transform:transale3d(0,0,0);background-color:#000;overflow:hidden}.webcam-wrapper{display:flex;overflow:hidden;flex-direction:row;flex:1;position:relative}.webcam-wrapper video{overflow:hidden;flex:1;object-fit:contain}.webcam-wrapper canvas{transform:translateZ(0);display:block;position:absolute;z-index:20;left:0;top:0}.webcam-wrapper .rectangle{position:absolute;left:0;top:0;display:flex;flex-direction:row;align-items:center;justify-content:center;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
813
370
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WebcamComponent, decorators: [{
814
371
  type: Component,
815
- args: [{ selector: 'ngx-scandoc-webcam', template: "<div class=\"webcam-wrapper\">\n <div>\n <video\n #video\n autoplay\n muted\n style=\"display: block\"\n playsinline\n\n ></video>\n\n <div class=\"rectangle\">\n\n <canvas\n #canvas\n [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n [width]=\"canvasSize.width\"\n [height]=\"canvasSize.height\"\n ></canvas>\n </div>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex:1;transform:transale3d(0,0,0);background-color:#000}.webcam-wrapper{display:flex;flex-direction:row;align-items:center;flex:1;justify-content:center;position:relative}.webcam-wrapper canvas{transform:transale3d(0,0,0);display:block;position:relative;z-index:20;left:0;top:0}.webcam-wrapper .rectangle{position:absolute;left:0;top:0;display:flex;flex-direction:row;align-items:center;justify-content:center;width:100%;height:100%}\n"] }]
372
+ args: [{ selector: 'ngx-scandoc-webcam', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"webcam-wrapper\">\n <video #video autoplay muted style=\"display: block\" playsinline></video>\n\n <div class=\"rectangle\">\n <canvas\n #canvas\n [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n [width]=\"video.offsetWidth\"\n [height]=\"video.offsetHeight\"\n ></canvas>\n </div>\n</div>\n", styles: [":host{display:flex;flex-direction:row;flex:1;transform:transale3d(0,0,0);background-color:#000;overflow:hidden}.webcam-wrapper{display:flex;overflow:hidden;flex-direction:row;flex:1;position:relative}.webcam-wrapper video{overflow:hidden;flex:1;object-fit:contain}.webcam-wrapper canvas{transform:translateZ(0);display:block;position:absolute;z-index:20;left:0;top:0}.webcam-wrapper .rectangle{position:absolute;left:0;top:0;display:flex;flex-direction:row;align-items:center;justify-content:center;width:100%;height:100%}\n"] }]
816
373
  }], ctorParameters: function () { return [{ type: i1.BreakpointObserver }, { type: i2.Platform }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i3.NgxScandocCameraProvider }]; }, propDecorators: { imageHandler: [{
817
374
  type: Input
818
- }], id: [{
819
- type: Input
820
375
  }], type: [{
821
376
  type: Input
822
- }], width: [{
823
- type: Input
824
- }], height: [{
825
- type: Input
826
- }], videoOptions: [{
827
- type: Input
828
- }], allowCameraSwitch: [{
829
- type: Input
830
- }], mirrorImage: [{
831
- type: Input
832
- }], captureImageData: [{
833
- type: Input
834
- }], imageType: [{
835
- type: Input
836
- }], imageQuality: [{
377
+ }], trigger: [{
837
378
  type: Input
838
- }], imageCapture: [{
839
- type: Output
840
- }], initError: [{
841
- type: Output
842
- }], imageClick: [{
843
- type: Output
379
+ }], onResize: [{
380
+ type: HostListener,
381
+ args: ['window:resize', ['$event']]
382
+ }], canvas: [{
383
+ type: ViewChild,
384
+ args: ['canvas', { static: true }]
385
+ }], videoRef: [{
386
+ type: ViewChild,
387
+ args: ['video', { static: true }]
844
388
  }], cameraSwitched: [{
845
389
  type: Output
846
390
  }], videoReady: [{
847
391
  type: Output
848
- }], destroyed: [{
392
+ }], imageCapture: [{
393
+ type: Output
394
+ }], initError: [{
849
395
  type: Output
850
- }], video: [{
851
- type: ViewChild,
852
- args: ['video', { static: true }]
853
- }], videoStreamer: [{
854
- type: ViewChild,
855
- args: ['videoStreamer', { static: true }]
856
- }], canvas: [{
857
- type: ViewChild,
858
- args: ['canvas', { static: true }]
859
- }], canvasSnapshot: [{
860
- type: ViewChild,
861
- args: ['canvasSnapshot', { static: true }]
862
- }], canvasResize: [{
863
- type: ViewChild,
864
- args: ['canvasResize', { static: true }]
865
- }], trigger: [{
866
- type: Input
867
- }], switchCamera: [{
868
- type: Input
869
- }], onResize: [{
870
- type: HostListener,
871
- args: ['window:resize', ['$event']]
872
396
  }] } });
873
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webcam.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-scandoc/src/core/components/webcam/webcam/webcam.component.ts","../../../../../../../projects/ngx-scandoc/src/core/components/webcam/webcam/webcam.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { WebcamInitError } from '../domain/webcam-init-error';\nimport { WebcamImage } from '../domain/webcam-image';\nimport { from, Observable, of, Subject, Subscription } from 'rxjs';\nimport { WebcamUtil } from '../util/webcam.util';\nimport { WebcamMirrorProperties } from '../domain/webcam-mirror-properties';\nimport {\n  BreakpointObserver,\n  Breakpoints,\n  BreakpointState,\n} from '@angular/cdk/layout';\nimport { Platform } from '@angular/cdk/platform';\nimport { switchMap } from 'rxjs/operators';\nimport { workertext } from '../../../app.worker';\nimport { NgxScandocCameraProvider } from '../../../../providers/camera.provider';\nimport { BaseComponent } from '../../base.component';\n\ndeclare var MediaStreamTrackProcessor: any;\n\n@Component({\n  selector: 'ngx-scandoc-webcam',\n  templateUrl: './webcam.component.html',\n  styleUrls: ['./webcam.component.scss'],\n})\nexport class WebcamComponent\n  extends BaseComponent\n  implements AfterViewInit, OnDestroy\n{\n  trackProcessor: any;\n  trackSettings: any;\n\n  @Input() imageHandler!: Subject<any>;\n\n  private static DEFAULT_VIDEO_OPTIONS: MediaTrackConstraints = {\n    facingMode: 'environment',\n  };\n  private static DEFAULT_IMAGE_TYPE: string = 'image/jpeg';\n  private static DEFAULT_IMAGE_QUALITY: number = 1;\n\n  @Input() public id?: any;\n  @Input() public type?: 'document' | 'selfie';\n  /** Defines the max width of the webcam area in px */\n  @Input() public width: number = 640;\n  /** Defines the max height of the webcam area in px */\n  @Input() public height: number = 480;\n  /** Defines base constraints to apply when requesting video track from UserMedia */\n  @Input() public videoOptions: MediaTrackConstraints =\n    WebcamComponent.DEFAULT_VIDEO_OPTIONS;\n  /** Flag to enable/disable camera switch. If enabled, a switch icon will be displayed if multiple cameras were found */\n  @Input() public allowCameraSwitch: boolean = true;\n  /** Parameter to control image mirroring (i.e. for user-facing camera). [\"auto\", \"always\", \"never\"] */\n  @Input() public mirrorImage?: string | WebcamMirrorProperties;\n  /** Flag to control whether an ImageData object is stored into the WebcamImage object. */\n  @Input() public captureImageData: boolean = false;\n  /** The image type to use when capturing snapshots */\n  @Input() public imageType: string = WebcamComponent.DEFAULT_IMAGE_TYPE;\n  /** The image quality to use when capturing snapshots (number between 0 and 1) */\n  @Input() public imageQuality: number = WebcamComponent.DEFAULT_IMAGE_QUALITY;\n\n  /** EventEmitter which fires when an image has been captured */\n  @Output() public imageCapture: EventEmitter<WebcamImage> =\n    new EventEmitter<WebcamImage>();\n  /** Emits a mediaError if webcam cannot be initialized (e.g. missing user permissions) */\n  @Output() public initError: EventEmitter<WebcamInitError> =\n    new EventEmitter<WebcamInitError>();\n  /** Emits when the webcam video was clicked */\n  @Output() public imageClick: EventEmitter<void> = new EventEmitter<void>();\n  /** Emits the active deviceId after the active video device was switched */\n  @Output() public cameraSwitched: EventEmitter<string> =\n    new EventEmitter<string>();\n\n  @Output() public videoReady: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  showVideo = false;\n  @Output() destroyed = new EventEmitter();\n\n  /** available video devices */\n  public availableVideoInputs: MediaDeviceInfo[] = [];\n\n  /** Indicates whether the video device is ready to be switched */\n  public videoInitialized: boolean = false;\n\n  canvasEl = document.createElement('canvas');\n\n  /** If the Observable represented by this subscription emits, an image will be captured and emitted through\n   * the 'imageCapture' EventEmitter */\n  private triggerSubscription?: Subscription;\n  /** Index of active video in availableVideoInputs */\n  private activeVideoInputIndex: number = -1;\n  /** Subscription to switchCamera events */\n  private switchCameraSubscription?: Subscription;\n  /** MediaStream object in use for streaming UserMedia data */\n  private mediaStream: MediaStream | null = null;\n  // Original video\n  @ViewChild('video', { static: true }) private video: any;\n  // Adjusted for UI\n  @ViewChild('videoStreamer', { static: true }) private videoStreamer: any;\n\n  //@ViewChild('videoSmall', { static: true }) private videoSmall: any;\n  //videoSmall: HTMLVideoElement = document.createElement('video');\n  /** Canvas for Video Snapshots */\n  @ViewChild('canvas', { static: true }) private canvas: any;\n\n  /** Canvas for Video Snapshots */\n  @ViewChild('canvasSnapshot', { static: true }) private canvasSnapshot: any;\n\n  @ViewChild('canvasResize', { static: true }) private canvasResize: any;\n  /** width and height of the active video stream */\n  activeVideoSettings: any;\n\n  shutdown = false;\n  private canStart = true;\n  videoSize: any = { width: 1920, height: 1080 };\n  canvasSize: any = { width: 1280, height: 720 };\n\n  worker?: Worker;\n  /**\n   * If the given Observable emits, an image will be captured and emitted through 'imageCapture' EventEmitter\n   */\n  @Input()\n  public set trigger(trigger: Observable<number>) {\n    if (this.triggerSubscription) {\n      this.triggerSubscription.unsubscribe();\n    }\n\n    // Subscribe to events from this Observable to take snapshots\n    this.triggerSubscription = trigger.subscribe((time) => {\n      this.takeSnapshot(time);\n    });\n  }\n\n  /**\n   * If the given Observable emits, the active webcam will be switched to the one indicated by the emitted value.\n   * @param switchCamera Indicates which webcam to switch to\n   *   true: cycle forwards through available webcams\n   *   false: cycle backwards through available webcams\n   *   string: activate the webcam with the given id\n   */\n  @Input() switchCamera: any;\n\n  @HostListener('window:resize', ['$event'])\n  onResize() {\n   // this.videoReady.next(false);\n    this.resizeStage();\n  }\n  constructor(\n    public breakpointObserver: BreakpointObserver,\n    public platform: Platform,\n    private cd: ChangeDetectorRef,\n    private zone: NgZone,\n\n    private cameraProvider: NgxScandocCameraProvider\n  ) {\n    super();\n    // if (typeof Worker !== 'undefined') {\n    //   // Create a new\n    //   this.worker = new Worker(\n    //     new URL('./../../../../app/app.worker', import.meta.url)\n    //   );\n    //   this.worker.onmessage = ({ data }) => {\n    //     console.log(`page got message: ${data}`);\n    //   };\n    //   console.log('POST');\n    //   this.worker.postMessage('hello');\n    // } else {\n    //   // Web workers are not supported in this environment.\n    //   // You should add a fallback so that your program still executes correctly.\n    // }\n  }\n\n  /**\n   * Get MediaTrackConstraints to request streaming the given device\n   * @param deviceId\n   * @param baseMediaTrackConstraints base constraints to merge deviceId-constraint into\n   * @returns\n   */\n  private static getMediaConstraintsForDevice(\n    deviceId: string,\n    baseMediaTrackConstraints: MediaTrackConstraints\n  ): MediaTrackConstraints {\n    const result: MediaTrackConstraints = baseMediaTrackConstraints\n      ? baseMediaTrackConstraints\n      : this.DEFAULT_VIDEO_OPTIONS;\n    if (deviceId) {\n      result.deviceId = { exact: deviceId };\n    }\n\n    return result;\n  }\n\n  /**\n   * Tries to harvest the deviceId from the given mediaStreamTrack object.\n   * Browsers populate this object differently; this method tries some different approaches\n   * to read the id.\n   * @param mediaStreamTrack\n   * @returns deviceId if found in the mediaStreamTrack\n   */\n  private static getDeviceIdFromMediaStreamTrack(\n    mediaStreamTrack: MediaStreamTrack\n  ): any {\n    if (\n      mediaStreamTrack.getSettings &&\n      mediaStreamTrack.getSettings() &&\n      mediaStreamTrack.getSettings().deviceId\n    ) {\n      return mediaStreamTrack.getSettings().deviceId;\n    } else if (\n      mediaStreamTrack.getConstraints &&\n      mediaStreamTrack.getConstraints() &&\n      mediaStreamTrack.getConstraints().deviceId\n    ) {\n      const deviceIdObj: any = mediaStreamTrack.getConstraints().deviceId;\n\n      return WebcamComponent.getValueFromConstrainDOMString(deviceIdObj);\n    }\n  }\n\n  /**\n   * Tries to harvest the facingMode from the given mediaStreamTrack object.\n   * Browsers populate this object differently; this method tries some different approaches\n   * to read the value.\n   * @param mediaStreamTrack\n   * @returns facingMode if found in the mediaStreamTrack\n   */\n  private static getFacingModeFromMediaStreamTrack(\n    mediaStreamTrack: MediaStreamTrack\n  ): any {\n    if (mediaStreamTrack) {\n      if (\n        mediaStreamTrack.getSettings &&\n        mediaStreamTrack.getSettings() &&\n        mediaStreamTrack.getSettings().facingMode\n      ) {\n        return mediaStreamTrack.getSettings().facingMode;\n      } else if (\n        mediaStreamTrack.getConstraints &&\n        mediaStreamTrack.getConstraints() &&\n        mediaStreamTrack.getConstraints().facingMode\n      ) {\n        const facingModeConstraint: any =\n          mediaStreamTrack.getConstraints().facingMode;\n        return WebcamComponent.getValueFromConstrainDOMString(\n          facingModeConstraint\n        );\n      }\n    }\n  }\n\n  /**\n   * Determines whether the given mediaStreamTrack claims itself as user facing\n   * @param mediaStreamTrack\n   */\n  private static isUserFacing(mediaStreamTrack: MediaStreamTrack): boolean {\n    const facingMode: string =\n      WebcamComponent.getFacingModeFromMediaStreamTrack(mediaStreamTrack);\n    return facingMode ? 'user' === facingMode.toLowerCase() : false;\n  }\n  landscape = true;\n  /**\n   * Extracts the value from the given ConstrainDOMString\n   * @param constrainDOMString\n   */\n  private static getValueFromConstrainDOMString(constrainDOMString: any): any {\n    if (constrainDOMString) {\n      if (constrainDOMString instanceof String) {\n        return String(constrainDOMString);\n      } else if (\n        Array.isArray(constrainDOMString) &&\n        Array(constrainDOMString).length > 0\n      ) {\n        return String(constrainDOMString[0]);\n      } else if (typeof constrainDOMString === 'object') {\n        if (constrainDOMString['exact']) {\n          return String(constrainDOMString['exact']);\n        } else if (constrainDOMString['ideal']) {\n          return String(constrainDOMString['ideal']);\n        }\n      }\n    }\n\n    return null;\n  }\n\n  resizeStage() {\n    setTimeout(() => {\n      this.updateSize();\n      this.updatecanvasSize();\n      this.drawRectangle();\n      this.cd.detectChanges();\n      this.videoReady.next(true);\n    }, 10);\n  }\n\n  get canvasHeight() {\n    const landscape = this.width > this.height;\n    const aspect = this.videoSize.width / this.videoSize.height;\n    if (!landscape) {\n      return this.width * aspect;\n    }\n    return this.height;\n  }\n  updatecanvasSize() {\n   // console.log(this.width, this.height);\n    const landscape = this.width > this.height;\n    const aspect = this.videoSize.width / this.videoSize.height;\n\n    let width = this.width;\n    let height = this.height;\n\n    if (landscape) {\n      height = width / aspect;\n    } else {\n      height = width / aspect;\n    }\n\n    if (height > this.height) {\n      height = this.height;\n      width = this.height * aspect;\n    }\n\n    this.canvasSize = { width: Math.round(width), height: Math.round(height) };\n\n    console.log(this.canvasSize, this.videoSize);\n\n    if (this.isMobile) {\n      this.video.nativeElement.setAttribute('height', this.canvasSize.height);\n      this.video.nativeElement.setAttribute('width', this.canvasSize.width);\n    } else {\n      if (this.videoSize.width > this.videoSize.hight) {\n        this.video.nativeElement.setAttribute('height', this.canvasSize.height);\n      } else {\n        this.video.nativeElement.setAttribute('width', this.canvasSize.width);\n      }\n    }\n\n    this.drawRectangle();\n\n    this.cd.detectChanges();\n  }\n\n  private setupWorker() {\n    if (typeof Worker !== 'undefined') {\n      // Create a new\n\n      if (this.type !== 'selfie') {\n        this.zone.runOutsideAngular(() => {\n          var blob = new Blob([workertext], { type: 'text/javascript' });\n\n          var url = URL.createObjectURL(blob);\n\n          this.worker = new Worker(url);\n          this.worker.onmessage = ({ data }) => {\n            if (data.base64) {\n\n              data.type == 'data';\n              this.imageHandler.next(data);\n            }\n          };\n        });\n      }\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.setupWorker();\n\n    if (this.imageHandler) {\n      this.__subs(this.imageHandler).subscribe((resp) => {\n        if (resp.type === 'stop') {\n          this.worker?.postMessage({ type: 'stop' });\n        }\n      });\n    }\n    this.__subs(this.breakpointObserver\n      .observe([Breakpoints.HandsetPortrait, Breakpoints.HandsetLandscape]))\n      .subscribe((state: BreakpointState) => {\n        if (this.platform.IOS || this.platform.ANDROID) {\n          // this.landscape = state.breakpoints[Breakpoints.HandsetLandscape];\n        }\n        const mobile = this.platform.IOS;\n        if (state.matches && mobile) {\n          this.updateSize();\n          this.updatecanvasSize();\n          this.drawRectangle();\n        }\n      });\n    if (this.switchCamera) {\n      if (this.switchCameraSubscription) {\n        this.switchCameraSubscription.unsubscribe();\n      }\n\n      // Subscribe to events from this Observable to switch video device\n      this.switchCameraSubscription = this.switchCamera.subscribe(\n        (value: string) => {\n          this.switchToVideoInput(value);\n        }\n      );\n    }\n\n    this.detectAvailableDevices()\n      .then(() => {\n        // start video\n\n        if (this.canStart) {\n          this.switchToVideoInput('');\n        }\n      })\n      .catch((err: string) => {\n        this.initError.next(<WebcamInitError>{ message: err });\n        // fallback: still try to load webcam, even if device enumeration failed\n        if (this.canStart) {\n          this.switchToVideoInput('');\n        }\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.canStart = false;\n    this.nativeVideoElement.pause();\n    this.destroyed.emit(true);\n    this.stopMediaTracks();\n    this.unsubscribeFromSubscriptions();\n    this.shutdown = true;\n\n    // shut down worker\n    if (this.imageHandler) {\n      this.imageHandler.next({ type: 'stop' });\n    }\n\n    if (this.nativeVideoElement.srcObject) {\n      ((this.nativeVideoElement as HTMLVideoElement).srcObject as MediaStream)\n        .getTracks()\n        .forEach((track) => {\n          track.stop();\n        });\n      this.nativeVideoElement.srcObject = null;\n    }\n\n    this.__destroy();\n\n    // this.nativeVideoElement.src = null;\n    // this.nativeVideoElement.srcObject = null;\n  }\n\n  private takeSelfie() {\n    const _video = this.nativeVideoElement;\n\n    const mimeType: string = this.imageType\n      ? this.imageType\n      : WebcamComponent.DEFAULT_IMAGE_TYPE;\n\n    let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;\n\n    const { width, height } = this.videoSize;\n   // console.log(width, height);\n\n    const { padding, top, rWidth, rHeight } = this.snapRectangle;\n    _canvas.width = rWidth;\n    _canvas.height = rHeight;\n\n    const ctx: any = _canvas.getContext('2d', {\n      alpha: false,\n      powerPreference: 'high-performance',\n      antialias: false,\n      depth: false,\n      desynchronized: true,\n    });\n\n    if (ctx) {\n      ctx.drawImage(\n        _video,\n        padding,\n        top,\n        rWidth,\n        rHeight,\n        0,\n        0,\n        rWidth,\n        rHeight\n      );\n\n      const imgAsUrl: any = _canvas.toDataURL(mimeType, 1);\n\n      this.imageCapture.emit(\n        new WebcamImage(imgAsUrl, mimeType, new ImageData(1, 1), null)\n      );\n    }\n  }\n\n  /**\n   * Takes a snapshot of the current webcam's view and emits the image as an event\n   */\n\n  public takeSnapshot(time: number): void {\n    if (this.type === 'selfie') {\n      this.takeSelfie();\n      return;\n    }\n\n    if (this.trackProcessor) {\n      return;\n    }\n    this.zone.runOutsideAngular(() => {\n      const canvasSmalSize = 384;\n\n      const _video = this.nativeVideoElement;\n\n      const mimeType: string = this.imageType\n        ? this.imageType\n        : WebcamComponent.DEFAULT_IMAGE_TYPE;\n\n      let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;\n\n      const { width, height } = this.videoSize;\n\n      _canvas.width = width;\n      _canvas.height = height;\n\n      const ctx: any = _canvas.getContext('2d', {\n        alpha: false,\n        powerPreference: 'high-performance',\n        antialias: false,\n        depth: false,\n        desynchronized: true,\n      });\n\n      const canvas = document.createElement('canvas'); // needs an initial size\n      canvas.height = canvasSmalSize;\n      canvas.width = canvasSmalSize;\n\n      const ctxO: any = canvas.getContext('2d', {\n        alpha: false,\n        powerPreference: 'high-performance',\n        antialias: false,\n        depth: false,\n        desynchronized: true,\n      });\n\n      if (ctx && ctxO) {\n        ctx.imageSmoothingEnabled = false;\n\n        ctx.drawImage(_video, 0, 0);\n        ctxO.drawImage(_video, 0, 0, canvasSmalSize, canvasSmalSize);\n\n        const imData: any = ctx.getImageData(\n          0,\n          0,\n          this.videoSize.width,\n          this.videoSize.height\n        );\n\n        const resize = canvas.toDataURL(mimeType, 1);\n\n        const currentTime = new Date().getTime();\n        const diff = currentTime - time;\n\n        const delay = diff > 100 ? 0 : 100 - diff;\n\n        const timeout = setTimeout(() => {\n          this.imageCapture.emit(new WebcamImage('', mimeType, imData, resize));\n          clearTimeout(timeout);\n        }, delay);\n      }\n    });\n  }\n\n  private update() {}\n\n  resizeImage(base64data: any): Observable<any> {\n    return new Observable((observer) => {\n      let canvas: any = document.createElement('canvas');\n      const ctx = canvas.getContext('2d');\n      const max_size = 384;\n      let image: any = new Image();\n\n      image.src = base64data;\n      image.onload = () => {\n        let width = image.width;\n        let height = image.height;\n\n        if (width < height) {\n          height *= max_size / width;\n          width = max_size;\n        } else {\n          width *= max_size / height;\n          height = max_size;\n        }\n        canvas.width = width;\n        canvas.height = height;\n\n        // console.log(width, height);\n\n        if (ctx) {\n          // ctx.rotate((90 * Math.PI) / 180);\n          // ctx.translate(0, -canvas.width);\n          ctx.drawImage(image, 0, 0, 384, 384);\n\n          observer.next(canvas.toDataURL());\n          ctx.clearRect(0, 0, 1, 1);\n        } else {\n          observer.error({ type: 'generic error' });\n        }\n        image = null;\n        canvas = null;\n      };\n      image.onerror = (e: any) => {\n        observer.error(e);\n      };\n    });\n  }\n\n  /**\n   * Switches to the next/previous video device\n   * @param forward\n   */\n  public rotateVideoInput(forward: boolean) {\n    if (this.availableVideoInputs && this.availableVideoInputs.length > 1) {\n      const increment: number = forward\n        ? 1\n        : this.availableVideoInputs.length - 1;\n      const nextInputIndex =\n        (this.activeVideoInputIndex + increment) %\n        this.availableVideoInputs.length;\n      this.switchToVideoInput(\n        this.availableVideoInputs[nextInputIndex].deviceId\n      );\n    }\n  }\n\n  /**\n   * Switches the camera-view to the specified video device\n   */\n  public switchToVideoInput(deviceId: string): void {\n    // if(deviceId){\n    this.videoInitialized = false;\n    this.stopMediaTracks();\n    this.initWebcam(deviceId, this.videoOptions);\n    // }\n  }\n\n  /**\n   * Event-handler for video resize event.\n   * Triggers Angular change detection so that new video dimensions get applied\n   */\n  public videoResize(): void {\n    // here to trigger Angular change detection\n  }\n\n  public get videoWidth() {\n    const videoRatio = this.getVideoAspectRatio();\n    return Math.min(this.width, this.height * videoRatio);\n  }\n\n  public get videoHeight() {\n    const videoRatio = this.getVideoAspectRatio();\n    return Math.min(this.height, this.width / videoRatio);\n  }\n\n  public get videoStyleClasses() {\n    let classes: string = '';\n\n    if (this.isMirrorImage()) {\n      classes += 'mirrored ';\n    }\n\n    return classes.trim();\n  }\n\n  public get nativeVideoElement() {\n    return this.video.nativeElement;\n  }\n  // public get smallVideoElement() {\n  //   return this.videoSmall;\n  // }\n\n  /**\n   * Returns the video aspect ratio of the active video stream\n   */\n  private getVideoAspectRatio(): number {\n    // calculate ratio from video element dimensions if present\n    const videoElement = this.nativeVideoElement;\n    if (\n      videoElement.videoWidth &&\n      videoElement.videoWidth > 0 &&\n      videoElement.videoHeight &&\n      videoElement.videoHeight > 0\n    ) {\n      return videoElement.videoWidth / videoElement.videoHeight;\n    }\n\n    // nothing present - calculate ratio based on width/height params\n    return this.width / this.height;\n  }\n\n  private updateSize() {\n    const track: MediaStreamTrack | undefined =\n      this.mediaStream?.getTracks()[0];\n\n    if (track) {\n      let desired: any = {\n        width: {\n          ideal: 0,\n        },\n        height: {\n          ideal: 0,\n        },\n\n        //  facingMode:'user',\n        frameRate: { min: 20, ideal: 24, max: 24 },\n      };\n      if (typeof track.getCapabilities === 'function') {\n        const { width, height } = track.getCapabilities();\n        desired = {\n          width: {\n            ideal: this.landscape && this.isMobile ? height?.max : width?.max,\n          },\n          height: {\n            ideal: this.landscape && this.isMobile ? width?.max : height?.max,\n          },\n\n          //  facingMode:'user',\n          frameRate: { min: 20, ideal: 24, max: 24 },\n        };\n      } else {\n        desired = {\n          width: {\n            ideal: 1920,\n          },\n          height: {\n            ideal: 1080,\n          },\n\n          //  facingMode:'user',\n          frameRate: { min: 20, ideal: 30, max: 31 },\n        };\n      }\n\n//  desired.height.ideal = 1000;\n//  desired.width.ideal = 1000;\n\n      if (desired.height.ideal && desired.height.ideal >= 1600) {\n        desired.height.ideal = 1600;\n        desired.width.ideal = 1600;\n      }\n\n      if (this.platform.ANDROID) {\n        //desired.width.ideal = 2160;\n        //desired.height.ideal = 2160;\n        // if (!this.landscape) {\n        // } else {\n        //   desired.width.ideal = width?.max;\n        //   desired.height.ideal = height?.max;\n        // }\n      }\n\n      track.applyConstraints(desired);\n\n      //track.getSettings().facingMode!=='user';\n\n      this.videoSize = {\n        height: this.landscape\n          ? track.getSettings().height\n          : track.getSettings().width,\n        width: this.landscape\n          ? track.getSettings().width\n          : track.getSettings().height,\n      };\n\n      this.cd.detectChanges();\n    }\n  }\n\n  getStreamTrack(stream: MediaStream) {\n    return stream.getVideoTracks()[0];\n  }\n\n  getTrackSettings() {}\n\n  accesVideoTrack(videoTrackConstraints: MediaStreamConstraints): any {\n    return from(\n      navigator.mediaDevices.getUserMedia(videoTrackConstraints)\n    ).pipe(\n      switchMap((stream: MediaStream) => {\n        // default resolution 1280x720, check max resolution\n\n        const track = this.getStreamTrack(stream);\n\n        const capabilities = track.getCapabilities();\n\n        const { facingMode, height, width } = capabilities;\n\n        const desired = {\n          width: {\n            min: this.landscape && this.isMobile ? height?.max : width?.max,\n          },\n          // height: {\n          //   exact: this.landscape && this.isMobile ? width?.max : height?.max,\n          // },\n          // facingMode:'en',\n          // frameRate: { min: 25, ideal: 30, max: 31 },\n        };\n        // get max width\n\n        const { width: sWidth, height: sHeight } = track.getSettings();\n\n        if (desired.width.min != sWidth) {\n          return this.accesVideoTrack({ video: desired });\n        }\n\n        //return this.accesVideoTrack({video:desired});\n\n        return of(stream);\n      })\n    );\n  }\n\n  private drawRectangle() {\n    const _canvas = this.canvas.nativeElement;\n\n    const ctx = _canvas.getContext('2d');\n    ctx.clearRect(0, 0, _canvas.width, _canvas.height);\n\n    // ctx.drawImage(_video, 0, 0, _canvas.width, _canvas.height);\n\n    const { padding, top, rWidth, rHeight } = this.cardRectangle;\n\n    ctx.strokeStyle = 'red';\n\n    ctx.strokeRect(padding, top, rWidth, rHeight);\n  }\n\n  getMaxAvailableResolution() {}\n  /**\n   * Init webcam live view\n   */\n  private initWebcam(\n    deviceId: string,\n    userVideoTrackConstraints: MediaTrackConstraints\n  ) {\n    console.log('INIT WEBCAM')\n    const _video = this.nativeVideoElement;\n    // const videoStreamer = this.videoStreamer.nativeElement;\n    // const videoSmall = document.createElement('video');\n    if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {\n      // merge deviceId -> userVideoTrackConstraints\n      const videoTrackConstraints =\n        WebcamComponent.getMediaConstraintsForDevice(\n          deviceId,\n          userVideoTrackConstraints\n        );\n\n      // // if (deviceId) {\n      // this.accesVideoTrack({ video: videoTrackConstraints }).subscribe(\n      //   (stream: MediaStream) => {\n      //     console.log(\n      //       'VALID SETTINGS',\n      //       stream.getVideoTracks()[0].getSettings()\n      //     );\n      //   }\n      // );\n      // }\n      if (this.platform.ANDROID) {\n        videoTrackConstraints.width = 1600;\n        videoTrackConstraints.height = 1600;\n      }\n\n      const constraints = {\n        exact: deviceId,\n        width: { min: 480, ideal: 1280 },\n        height: { min: 480, ideal: 720 },\n        // aspectRatio: 3 / 2,\n        frameRate: { min: 20 },\n      };\n\n      navigator.mediaDevices\n        .getUserMedia(<MediaStreamConstraints>{ video: videoTrackConstraints })\n        .then((stream: MediaStream) => {\n          this.mediaStream = stream;\n          _video.srcObject = stream;\n\n          this.updateSize();\n          this.updatecanvasSize();\n\n          _video.play();\n\n          _video.onplay = () => {\n            this.setActiveCamera(stream);\n            this.drawRectangle();\n          };\n        })\n        .catch((err: any) => {\n          console.log(err);\n          this.initError.next(<WebcamInitError>{\n            message: err.message,\n            mediaStreamError: err,\n          });\n        });\n    } else {\n      this.initError.next(<WebcamInitError>{\n        message: 'Cannot read UserMedia from MediaDevices.',\n      });\n    }\n  }\n\n  get isMobile() {\n    return this.platform.ANDROID || this.platform.IOS;\n  }\n\n  get cardRectangle() {\n    const _canvas = this.canvas.nativeElement;\n    const docSize = this.type === 'selfie' ? 1 : 86 / 55;\n\n   // console.log(_canvas.width, _canvas.height);\n    let padding = 10;\n\n    let rWidth = _canvas.width - 2 * padding;\n    let rHeight = rWidth / docSize;\n    let top = (_canvas.height - rHeight) / 2;\n\n    if ((!this.isMobile && _canvas.width!== _canvas.height)) {\n      padding = 40;\n\n      rHeight = _canvas.height - 2 * padding;\n      rWidth = rHeight * docSize;\n      top = (_canvas.height - rHeight) / 2;\n      padding = (_canvas.width - rWidth) / 2;\n    }\n\n   // console.log(padding, top, rWidth, rHeight);\n\n    return { padding, top, rWidth, rHeight };\n  }\n  get snapRectangle() {\n    const _canvas = this.canvas.nativeElement;\n\n    const ar = this.videoSize.width / _canvas.width;\n\n    let { padding, top, rWidth, rHeight } = this.cardRectangle;\n\n    padding = padding * ar;\n    top = top * ar;\n    rWidth = rWidth * ar;\n    rHeight = rHeight * ar;\n\n    return { padding, top, rWidth, rHeight };\n  }\n\n  private setActiveCamera(stream: any) {\n    this.videoReady.next(false);\n    this.showVideo = false;\n    this.activeVideoSettings = stream.getVideoTracks()[0].getSettings();\n    const activeDeviceId: string =\n      WebcamComponent.getDeviceIdFromMediaStreamTrack(\n        stream.getVideoTracks()[0]\n      );\n\n    const videoTrack = stream.getTracks()[0];\n    this.trackSettings = videoTrack.getSettings();\n\n    this.cameraProvider.cameraWasSwitched(activeDeviceId);\n\n    this.cameraSwitched.next(activeDeviceId);\n\n    setTimeout(() => {\n      this.zone.run(() => {\n        this.resizeStage();\n        this.showVideo = true;\n        this.videoReady.next(true);\n\n        if (MediaStreamTrackProcessor) {\n          this.trackProcessor = new MediaStreamTrackProcessor(videoTrack);\n          let frameStream = this.trackProcessor.readable;\n          if (!this.shutdown) {\n            this.worker?.postMessage(\n              {\n                type: 'start',\n\n                frameStream: frameStream,\n                trackSettings: this.trackSettings,\n              },\n              [frameStream]\n            );\n          }\n        }\n      });\n    }, 500);\n  }\n\n  private getActiveVideoTrack(): MediaStreamTrack | any {\n    return this.mediaStream ? this.mediaStream.getVideoTracks()[0] : null;\n  }\n\n  private isMirrorImage(): boolean {\n    if (!this.getActiveVideoTrack()) {\n      return false;\n    }\n\n    // check for explicit mirror override parameter\n    {\n      let mirror: string = 'auto';\n      if (this.mirrorImage) {\n        if (typeof this.mirrorImage === 'string') {\n          mirror = String(this.mirrorImage).toLowerCase();\n        } else {\n          // WebcamMirrorProperties\n          if (this.mirrorImage.x) {\n            mirror = this.mirrorImage.x.toLowerCase();\n          }\n        }\n      }\n\n      switch (mirror) {\n        case 'always':\n          return true;\n        case 'never':\n          return false;\n      }\n    }\n\n    // default: enable mirroring if webcam is user facing\n    return WebcamComponent.isUserFacing(this.getActiveVideoTrack());\n  }\n\n  /**\n   * Stops all active media tracks.\n   * This prevents the webcam from being indicated as active,\n   * even if it is no longer used by this component.\n   */\n  private stopMediaTracks() {\n    // this.video.nativeElement.pause();\n    if (this.video.nativeElement.srcObject) {\n      ((this.video.nativeElement as HTMLVideoElement).srcObject as MediaStream)\n        .getTracks()\n        .forEach((track) => {\n          track.stop();\n        });\n      this.video.nativeElement.srcObject = null;\n      this.video.nativeElement.src = '';\n    }\n\n    if (this.mediaStream && this.mediaStream.getTracks) {\n      // getTracks() returns all media tracks (video+audio)\n\n      this.mediaStream\n        .getTracks()\n        .forEach((track: MediaStreamTrack) => track.stop());\n    }\n  }\n\n  /**\n   * Unsubscribe from all open subscriptions\n   */\n  private unsubscribeFromSubscriptions() {\n    if (this.triggerSubscription) {\n      this.triggerSubscription.unsubscribe();\n    }\n    if (this.switchCameraSubscription) {\n      this.switchCameraSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * Reads available input devices\n   */\n  private detectAvailableDevices(): Promise<MediaDeviceInfo[]> {\n    return new Promise((resolve, reject) => {\n      WebcamUtil.getAvailableVideoInputs().subscribe(\n        (devices: MediaDeviceInfo[]) => {\n          this.availableVideoInputs = devices;\n          resolve(devices);\n        },\n        (err) => {\n          this.availableVideoInputs = [];\n          reject(err);\n        }\n      );\n    });\n  }\n}\n","<div class=\"webcam-wrapper\">\n  <div>\n    <video\n      #video\n      autoplay\n      muted\n      style=\"display: block\"\n      playsinline\n\n    ></video>\n\n    <div class=\"rectangle\">\n\n      <canvas\n        #canvas\n        [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n        [width]=\"canvasSize.width\"\n        [height]=\"canvasSize.height\"\n      ></canvas>\n    </div>\n  </div>\n</div>\n"]}
397
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webcam.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-scandoc/src/core/components/webcam/webcam/webcam.component.ts","../../../../../../../projects/ngx-scandoc/src/core/components/webcam/webcam/webcam.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { WebcamInitError } from '../domain/webcam-init-error';\nimport { WebcamImage } from '../domain/webcam-image';\nimport { from, Observable, of, Subject, Subscription } from 'rxjs';\nimport { WebcamUtil } from '../util/webcam.util';\nimport { WebcamMirrorProperties } from '../domain/webcam-mirror-properties';\nimport {\n  BreakpointObserver,\n  Breakpoints,\n  BreakpointState,\n} from '@angular/cdk/layout';\nimport { Platform } from '@angular/cdk/platform';\nimport { switchMap } from 'rxjs/operators';\nimport { workertext } from '../../../app.worker';\nimport { NgxScandocCameraProvider } from '../../../../providers/camera.provider';\nimport { BaseComponent } from '../../base.component';\n\ndeclare var MediaStreamTrackProcessor: any;\n\n@Component({\n  selector: 'ngx-scandoc-webcam',\n  templateUrl: './webcam.component.html',\n  styleUrls: ['./webcam.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class WebcamComponent\n  extends BaseComponent\n  implements AfterViewInit, OnDestroy\n{\n  private triggerSubscription?: Subscription;\n  canvasSize: any = { width: 0, height: 0 };\n  showVideo = false;\n\n  canvasData: any = {\n    ctx: null,\n    ctxO: null,\n  };\n\n  mediaStream!: MediaStream;\n  @Input() imageHandler!: Subject<any>;\n\n  @Input() public type?: 'document' | 'selfie' | 'manual';\n\n  @Input() trigger!: Observable<number>;\n  // public set trigger(trigger: Observable<number>) {\n  //   if (this.triggerSubscription) {\n  //     this.triggerSubscription.unsubscribe();\n  //   }\n\n  //   // Subscribe to events from this Observable to take snapshots\n  //   this.triggerSubscription = trigger.subscribe((time) => {\n  //     this.takeSnapshot(time);\n  //   });\n  // }\n  resizeTimeout: any;\n  @HostListener('window:resize', ['$event'])\n  onResize() {\n    this.cameraProvider.rectPosition.t = 0;\n    // this.videoReady.next(false);\n    if (this.resizeTimeout) {\n      clearTimeout(this.resizeTimeout);\n    }\n    this.resizeTimeout = setTimeout(() => {\n      this.drawRectangle();\n    }, 50);\n  }\n\n  private chunks:any = [];\n  @ViewChild('canvas', { static: true }) private canvas: any;\n\n  @ViewChild('video', { static: true }) private videoRef: any;\n\n  @Output() public cameraSwitched: EventEmitter<string> =\n    new EventEmitter<string>();\n  @Output() public videoReady: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output() public imageCapture: EventEmitter<WebcamImage> =\n    new EventEmitter<WebcamImage>();\n\n  @Output() public initError: EventEmitter<WebcamInitError> =\n    new EventEmitter<WebcamInitError>();\n  constructor(\n    public breakpointObserver: BreakpointObserver,\n    public platform: Platform,\n    private cd: ChangeDetectorRef,\n    private zone: NgZone,\n\n    private cameraProvider: NgxScandocCameraProvider\n  ) {\n    super();\n  }\n  ngAfterViewInit(): void {\n    console.warn('[video] start');\n    // initial load\n    this.__subs(this.cameraProvider.getDevices()).subscribe((resp) => {\n      this.init();\n    });\n\n    // camera switch\n    this.__subs(this.cameraProvider.webcamObservable).subscribe((device) => {\n      const videoTrackConstraints: any = this.setConstraints();\n      this.stopAllTracks();\n      this.showVideo = false;\n      this.cd.detectChanges();\n      videoTrackConstraints.deviceId = device;\n      this.setup(videoTrackConstraints);\n    });\n\n    this.__subs(this.trigger).subscribe((time) => this.takeSnapshot(time));\n  }\n\n  public get video() {\n    return this.videoRef.nativeElement;\n  }\n  get isMobile() {\n    return this.platform.ANDROID || this.platform.IOS;\n  }\n  private setConstraints() {\n    const out: MediaStreamConstraints = {};\n    switch (this.type) {\n      default:\n        if (this.isMobile) {\n          out.video = { height: { ideal: 1600 }, width: { ideal: 1600 } };\n        } else {\n          out.video = { height: { ideal: 1080 }, width: { ideal: 1920 } };\n        }\n        out.video.facingMode = 'environment';\n        break;\n\n      case 'selfie':\n        if (this.isMobile) {\n          out.video = { height: { ideal: 1600 }, width: { ideal: 1600 } };\n        } else {\n          out.video = { height: { ideal: 1080 }, width: { ideal: 1920 } };\n        }\n        out.video.facingMode = 'user';\n        break;\n    }\n\n    return out.video;\n  }\n\n  private get activeTrackSettings() {\n    return this.mediaStream.getVideoTracks()[0].getSettings();\n  }\n  private get activeTrackCapabilities() {\n    try {\n      return this.mediaStream.getVideoTracks()[0].getCapabilities();\n    } catch (e) {\n      return {};\n    }\n  }\n\n  private init() {\n    const videoTrackConstraints = this.setConstraints();\n\n    this.setup(videoTrackConstraints);\n  }\n  private setup(videoTrackConstraints: any) {\n    this.__subs(\n      from(\n        navigator.mediaDevices.getUserMedia(<MediaStreamConstraints>{\n          video: videoTrackConstraints,\n        })\n      )\n    ).subscribe((stream: MediaStream) => {\n      this.mediaStream = stream;\n      this.cameraProvider.deviceId = this.activeTrackSettings.deviceId;\n      this.startVideo();\n    });\n  }\n\n  private startVideo() {\n    console.log('START VIDEO');\n    this.video.srcObject = this.mediaStream;\n\n    this.video.onloadedmetadata = (data: any) => {\n      //  console.log(data);\n      this.video.play();\n      this.showVideo = true;\n      this.cd.detectChanges();\n      console.log('VIDEO PLAY');\n    };\n    this.video.onplay = () => {\n      this.videoReady.next(true);\n      console.log(this.video.videoWidth, this.video.videoHeight);\n      this.drawRectangle();\n    };\n  }\n  setCanvas() {\n    let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;\n\n    const { videoWidth, videoHeight } = this.video;\n\n    const aspect = videoWidth / videoHeight;\n\n    const canvasSmalSize = 384;\n    const smallSize = {\n      w: 0,\n      h: 0,\n    };\n\n    if (videoWidth >= videoHeight) {\n      smallSize.w = canvasSmalSize;\n      smallSize.h = canvasSmalSize / aspect;\n    } else {\n      smallSize.h = canvasSmalSize;\n      smallSize.h = canvasSmalSize * aspect;\n    }\n\n    console.log('SZ', smallSize);\n\n    _canvas.width = videoWidth;\n    _canvas.height = videoHeight;\n    const ctx: any = _canvas.getContext('2d', {\n      alpha: false,\n      powerPreference: 'high-performance',\n      antialias: false,\n      depth: false,\n      desynchronized: true,\n    });\n\n    const canvas = document.createElement('canvas'); // needs an initial size\n    canvas.height = smallSize.h;\n    canvas.width = smallSize.w;\n\n    const ctxO: any = canvas.getContext('2d', {\n      alpha: false,\n      powerPreference: 'high-performance',\n      antialias: false,\n      depth: false,\n      desynchronized: true,\n    });\n\n    this.canvasData.ctx = ctx;\n    this.canvasData.ctxO = ctxO;\n    this.canvasData.canvas = canvas;\n    this.canvasData._canvas = _canvas;\n    this.canvasData.size = smallSize;\n\n    // const stream = this.video.captureStream(5);\n\n\n\n    // const mediaRecorder = new MediaRecorder(stream);\n\n\n    // mediaRecorder.start();\n\n    // mediaRecorder.ondataavailable = (e:any) => {\n    //   console.log(e)\n    //   this.chunks.push(e.data);\n\n    //   var url = window.URL.createObjectURL(e.data);\n    //   var anchor = document.createElement('a');\n    //   anchor.download = 'myfile.webm';\n    //   anchor.href = url;\n    //   anchor.click();\n    // };\n  }\n\n  private takeSelfie() {\n    const mimeType: string = 'image/jpeg';\n    const { videoWidth, offsetWidth, videoHeight } = this.video;\n\n    let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;\n\n    const { w, h } = this.cameraProvider.rectPosition;\n\n    const aspect = videoWidth / offsetWidth;\n\n    // console.log(videoWidth, offsetWidth, l, t, w, h);\n\n    _canvas.width = w * aspect;\n    _canvas.height = h * aspect;\n\n    const dx = videoWidth - w * aspect;\n    const dy = videoHeight - h * aspect;\n    const x = dx / 2;\n    const y = dy / 2;\n\n    const ctx: any = _canvas.getContext('2d', {\n      alpha: false,\n      powerPreference: 'high-performance',\n      antialias: false,\n      depth: false,\n      desynchronized: true,\n    });\n\n    if (ctx) {\n      ctx.drawImage(\n        this.video,\n        x,\n        y,\n        w * aspect,\n        h * aspect,\n        0,\n        0,\n        w * aspect,\n        h * aspect\n      );\n\n      const imgAsUrl: any = _canvas.toDataURL(mimeType, 1);\n\n      this.imageCapture.emit(\n        new WebcamImage(imgAsUrl, mimeType, new ImageData(1, 1), null)\n      );\n    }\n  }\n  takeSnapshot(time: number) {\n    if (this.type !== 'document') {\n      this.takeSelfie();\n      return;\n    }\n    console.warn('SNAP', time);\n    if (!this.showVideo) {\n      return;\n    }\n    this.zone.runOutsideAngular(() => {\n      const canvasSmalSize = 384;\n\n      const mimeType: string = 'image/jpeg';\n\n      // let _canvas: HTMLCanvasElement = document.createElement('canvas'); //this.canvasSnapshot.nativeElement;\n\n      const { videoWidth, videoHeight } = this.video;\n\n      // _canvas.width = videoWidth;\n      // _canvas.height = videoHeight;\n      // console.log(videoWidth, videoHeight);\n\n      // const ctx: any = _canvas.getContext('2d', {\n      //   alpha: false,\n      //   powerPreference: 'high-performance',\n      //   antialias: false,\n      //   depth: false,\n      //   desynchronized: true,\n      // });\n\n      // const canvas = document.createElement('canvas'); // needs an initial size\n      // canvas.height = canvasSmalSize;\n      // canvas.width = canvasSmalSize;\n\n      // const ctxO: any = canvas.getContext('2d', {\n      //   alpha: false,\n      //   powerPreference: 'high-performance',\n      //   antialias: false,\n      //   depth: false,\n      //   desynchronized: true,\n      // });\n\n      const { ctx, ctxO, canvas, _canvas, size } = this.canvasData;\n\n      if (ctx && ctxO) {\n        ctx.imageSmoothingEnabled = false;\n        const drawStart = Date.now();\n        ctx.clearRect(0, 0, videoWidth, videoHeight);\n        ctxO.clearRect(0, 0, size.w, size.h);\n\n        ctx.drawImage(this.video, 0, 0);\n        console.time('drawVideo');\n        ctxO.drawImage(_canvas, 0, 0, size.w, size.h);\n        console.timeEnd('drawVideo');\n        console.time('DRAW');\n\n        const imData: any = ctx.getImageData(0, 0, videoWidth, videoHeight);\n\n        console.timeEnd('DRAW');\n\n        console.time('CTX');\n\n        const resize = canvas.toDataURL(mimeType, 1);\n        console.timeEnd('CTX');\n        const currentTime = new Date().getTime();\n        const diff = currentTime - time;\n\n        // total time for pack one image\n        const drawTime = Date.now() - drawStart;\n\n        console.warn('DRAW TIME', drawTime);\n        const delayMax = drawTime < 60 ? 100 : 200;\n\n        const delay = diff > delayMax ? 0 : delayMax - diff;\n\n        console.warn(this.chunks)\n        const timeout = setTimeout(() => {\n          this.imageCapture.emit(new WebcamImage('', mimeType, imData, resize));\n          clearTimeout(timeout);\n        }, delay);\n      }\n    });\n  }\n\n  private stopAllTracks() {\n    this.showVideo = false;\n    if (this.mediaStream && this.mediaStream.getTracks) {\n      // getTracks() returns all media tracks (video+audio)\n\n      this.mediaStream.getTracks().forEach((track: MediaStreamTrack) => {\n        track.stop();\n        this.video.srcObject.removeTrack(track);\n        this.mediaStream.removeTrack(track);\n      });\n      this.video.srcObject = null;\n\n      this.video.load();\n    }\n  }\n\n  private drawRectangle() {\n    this.zone.run(() => {\n      const _canvas = this.canvas.nativeElement;\n      let padding = 10;\n      if (!this.isMobile && _canvas.width !== _canvas.height) {\n        padding = 40;\n      }\n      const ctx = _canvas.getContext('2d');\n      console.log(ctx);\n      ctx.clearRect(0, 0, _canvas.width, _canvas.height);\n\n      const { width, height } = _canvas;\n\n      console.log(width, height);\n\n      const { videoWidth, videoHeight } = this.video;\n\n      const docSize = this.type === 'selfie' ? 1 : 86 / 55;\n\n      const aspect = videoWidth / videoHeight;\n      let _height;\n      let _width;\n\n      if (videoWidth >= videoHeight) {\n        _width = width;\n\n        _height = _width / aspect;\n\n        if (_height > height) {\n          _height = height;\n          _width = aspect * _height;\n        }\n      } else {\n        _height = height;\n        _width = aspect * _height;\n        if (_width > width) {\n          _width = width;\n          _height = _width / aspect;\n        }\n      }\n      let w, h;\n\n      if (_width <= _height) {\n        w = _width - 2 * padding;\n        h = w / docSize;\n      } else {\n        h = _height - 2 * padding;\n        w = docSize * h;\n      }\n\n      h = Math.floor(h);\n      w = Math.floor(w);\n\n      console.log(_width, _height);\n\n      const left = Math.floor((width - w) / 2);\n      const top = Math.floor((height - h) / 2);\n\n      ctx.strokeStyle = 'red';\n\n      // ctx.strokeRect(left, top, _width, _height);\n\n      ctx.shadowColor = 'red';\n      ctx.shadowBlur = 15;\n      ctx.beginPath();\n\n      // Draw using 5px for border radius on all sides\n      // stroke it but no fill\n      ctx.roundRect(left, top, w, h, 5);\n      ctx.stroke();\n\n      this.cameraProvider.rectPosition = {\n        l: left,\n        t: top,\n        w,\n        h,\n        _w: _width,\n        _h: _height,\n      };\n\n      this.setCanvas();\n      // ctx.stroke();\n    });\n  }\n  ngOnDestroy(): void {\n    this.video.pause();\n\n    // this.video.getTracks().forEach((track: any) => {\n    //   track.stop();\n    //   this.video.srcObject.removeTrack(track);\n    // });\n\n    this.stopAllTracks();\n\n    if (this.triggerSubscription) {\n      this.triggerSubscription.unsubscribe();\n    }\n    this.__destroy();\n\n    console.warn('[VIDEO] destroyed');\n  }\n}\n","<div class=\"webcam-wrapper\">\n  <video #video autoplay muted style=\"display: block\" playsinline></video>\n\n  <div class=\"rectangle\">\n    <canvas\n      #canvas\n      [ngStyle]=\"{ visibility: showVideo ? 'visible' : 'hidden' }\"\n      [width]=\"video.offsetWidth\"\n      [height]=\"video.offsetHeight\"\n    ></canvas>\n  </div>\n</div>\n"]}