@lumiscaphe/ng-viewer 15.0.0 → 16.0.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.
@@ -0,0 +1,172 @@
1
+ import { Component, EventEmitter, Input, ViewChild, Output, HostListener } from '@angular/core';
2
+ import { Viewer } from '@lumiscaphe/viewer';
3
+ import Viewport from './viewport';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ class NgViewerComponent {
7
+ constructor() {
8
+ this.hotspots = [];
9
+ this.hotspotTemplateRef = null;
10
+ this.onLoadStart = new EventEmitter();
11
+ this.onLoadProgress = new EventEmitter();
12
+ this.onLoadEnd = new EventEmitter();
13
+ this.onLoadError = new EventEmitter();
14
+ this.onInteraction = new EventEmitter();
15
+ this.onVrcubeInteraction = new EventEmitter();
16
+ this.onVrobjectInteraction = new EventEmitter();
17
+ this.fitPosition = { width: 1, height: 1, top: 1, left: 1 };
18
+ this.scaleX = 1;
19
+ this.scaleY = 1;
20
+ }
21
+ ngAfterViewInit() {
22
+ this.viewer = new Viewer(this.container.nativeElement, {
23
+ server: this.server,
24
+ api: this.api || 'v1',
25
+ fit: this.fit || 'cover',
26
+ events: {
27
+ onLoadStart: (...args) => { this.onLoadStart.emit(...args); },
28
+ onLoadProgress: (...args) => { this.onLoadProgress.emit(...args); },
29
+ onLoadEnd: (...args) => { this.onLoadEnd.emit(...args); },
30
+ onLoadError: (...args) => { this.onLoadError.emit(...args); },
31
+ onInteraction: (...args) => { this.onInteraction.emit(...args); },
32
+ onVrcubeInteraction: (...args) => { this.onVrcubeInteraction.emit(...args); },
33
+ onVrobjectInteraction: (...args) => { this.onVrobjectInteraction.emit(...args); },
34
+ onHotspotsChange: this.onHotspotsChange.bind(this)
35
+ },
36
+ });
37
+ if (this['scene']) {
38
+ this.viewer.load(this.scene).catch(() => { });
39
+ }
40
+ if (this['encoder']) {
41
+ this.viewer.setEncoder(this.encoder).catch(() => { });
42
+ }
43
+ if (this.parameters) {
44
+ this.viewer.setParameters(this.parameters).catch(() => { });
45
+ }
46
+ if (this.view) {
47
+ this.viewer.setView(this.view).catch(() => { });
48
+ }
49
+ if (this.vrcube) {
50
+ this.viewer.setVrcube(this.vrcube);
51
+ }
52
+ if (this.vrobject) {
53
+ this.viewer.setVrobject(this.vrobject);
54
+ }
55
+ if (this.tags) {
56
+ this.viewer.setTags(this.tags);
57
+ }
58
+ this.onResize();
59
+ }
60
+ ngOnDestroy() {
61
+ this.viewer?.destroy();
62
+ }
63
+ ngOnChanges(changes) {
64
+ if (!this.viewer) {
65
+ return;
66
+ }
67
+ if (changes['scene'] && changes['scene'].currentValue) {
68
+ this.viewer.load(changes['scene'].currentValue).catch(() => { });
69
+ }
70
+ if (changes['encoder'] && changes['encoder'].currentValue) {
71
+ this.viewer.setEncoder(changes['encoder'].currentValue).catch(() => { });
72
+ }
73
+ if (changes['parameters'] && changes['parameters'].currentValue) {
74
+ this.viewer.setParameters(changes['parameters'].currentValue).catch(() => { });
75
+ }
76
+ if (changes['tags'] && changes['tags'].currentValue) {
77
+ this.viewer.setTags(changes['tags'].currentValue);
78
+ }
79
+ if (changes['view'] && changes['view'].currentValue) {
80
+ this.viewer.setView(changes['view'].currentValue).catch(() => { });
81
+ }
82
+ if (changes['vrcube'] && changes['vrcube'].currentValue) {
83
+ this.viewer.setVrcube(changes['vrcube'].currentValue);
84
+ }
85
+ if (changes['vrobject'] && changes['vrobject'].currentValue) {
86
+ this.viewer.setVrobject(changes['vrobject'].currentValue);
87
+ }
88
+ }
89
+ onHotspotsChange(hotspots) {
90
+ this.hotspots = hotspots;
91
+ if (this.hotspotsFilter !== undefined) {
92
+ this.hotspots = this.hotspotsFilter(this.hotspots);
93
+ }
94
+ }
95
+ snapshot(type, quality) {
96
+ return this.viewer?.snapshot(type, quality);
97
+ }
98
+ onResize() {
99
+ this.resolution = Viewport.getStandardResolution(window.innerWidth, window.innerHeight);
100
+ this.fitPosition = Viewport.fit(this.resolution, window.innerWidth, window.innerHeight, 'cover');
101
+ this.scaleX = this.fitPosition.width / this.resolution.width;
102
+ this.scaleY = this.fitPosition.height / this.resolution.height;
103
+ }
104
+ hotspotStyle(hotspot) {
105
+ if (this.view?.mode === 'vrcube') {
106
+ return {
107
+ position: 'absolute',
108
+ top: hotspot.position2D.y + 'px',
109
+ left: hotspot.position2D.x + 'px'
110
+ };
111
+ }
112
+ else {
113
+ return {
114
+ position: 'absolute',
115
+ top: (hotspot.position2D.y * this.scaleY + this.fitPosition.top) + 'px',
116
+ left: (hotspot.position2D.x * this.scaleX + this.fitPosition.left) + 'px'
117
+ };
118
+ }
119
+ }
120
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NgViewerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
121
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.5", type: NgViewerComponent, selector: "NgViewer", inputs: { server: "server", api: "api", fit: "fit", scene: "scene", encoder: "encoder", parameters: "parameters", view: "view", vrcube: "vrcube", vrobject: "vrobject", tags: "tags", hotspotTemplateRef: "hotspotTemplateRef", hotspotsFilter: "hotspotsFilter" }, outputs: { onLoadStart: "onLoadStart", onLoadProgress: "onLoadProgress", onLoadEnd: "onLoadEnd", onLoadError: "onLoadError", onInteraction: "onInteraction", onVrcubeInteraction: "onVrcubeInteraction", onVrobjectInteraction: "onVrobjectInteraction" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #container></div>\n\n<div class=\"position-absolute w-100 h-100\" style=\"pointer-events: none;\" *ngIf=\"hotspots.length\">\n <div [ngStyle]=\"hotspotStyle(hotspot)\" *ngFor=\"let hotspot of hotspots\">\n <ng-container *ngTemplateOutlet=\"hotspotTemplateRef; context:{hotspot: hotspot}\"></ng-container>\n </div>\n</div>", styles: [":host{display:flex;flex:1 0 auto}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
122
+ }
123
+ export { NgViewerComponent };
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NgViewerComponent, decorators: [{
125
+ type: Component,
126
+ args: [{ selector: 'NgViewer', template: "<div #container></div>\n\n<div class=\"position-absolute w-100 h-100\" style=\"pointer-events: none;\" *ngIf=\"hotspots.length\">\n <div [ngStyle]=\"hotspotStyle(hotspot)\" *ngFor=\"let hotspot of hotspots\">\n <ng-container *ngTemplateOutlet=\"hotspotTemplateRef; context:{hotspot: hotspot}\"></ng-container>\n </div>\n</div>", styles: [":host{display:flex;flex:1 0 auto}\n"] }]
127
+ }], propDecorators: { server: [{
128
+ type: Input
129
+ }], api: [{
130
+ type: Input
131
+ }], fit: [{
132
+ type: Input
133
+ }], scene: [{
134
+ type: Input
135
+ }], encoder: [{
136
+ type: Input
137
+ }], parameters: [{
138
+ type: Input
139
+ }], view: [{
140
+ type: Input
141
+ }], vrcube: [{
142
+ type: Input
143
+ }], vrobject: [{
144
+ type: Input
145
+ }], tags: [{
146
+ type: Input
147
+ }], hotspotTemplateRef: [{
148
+ type: Input
149
+ }], hotspotsFilter: [{
150
+ type: Input
151
+ }], onLoadStart: [{
152
+ type: Output
153
+ }], onLoadProgress: [{
154
+ type: Output
155
+ }], onLoadEnd: [{
156
+ type: Output
157
+ }], onLoadError: [{
158
+ type: Output
159
+ }], onInteraction: [{
160
+ type: Output
161
+ }], onVrcubeInteraction: [{
162
+ type: Output
163
+ }], onVrobjectInteraction: [{
164
+ type: Output
165
+ }], container: [{
166
+ type: ViewChild,
167
+ args: ['container']
168
+ }], onResize: [{
169
+ type: HostListener,
170
+ args: ['window:resize', ['$event']]
171
+ }] } });
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-viewer.component.js","sourceRoot":"","sources":["../../../../projects/ng-viewer/src/lib/ng-viewer.component.ts","../../../../projects/ng-viewer/src/lib/ng-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, SimpleChanges, ViewChild, Output, TemplateRef, HostListener } from '@angular/core';\n\nimport { Encoder, Hotspot, Parameters, Scene, View, Viewer, WidgetVRCube, WidgetVRObject } from '@lumiscaphe/viewer';\nimport Viewport from './viewport';\n\n@Component({\n  selector: 'NgViewer',\n  templateUrl: './ng-viewer.component.html',\n  styleUrls: ['./ng-viewer.component.scss']\n})\n\nexport class NgViewerComponent implements AfterViewInit, OnChanges, OnDestroy {\n\n  public viewer: Viewer | undefined;\n\n  public hotspots: Hotspot[] = [];\n\n  @Input() server: string | undefined;\n  @Input() api: string | undefined;\n  @Input() fit: 'contain' | 'cover' | 'fill' | undefined;\n  @Input() scene: Scene | undefined;\n  @Input() encoder: Encoder | undefined;\n  @Input() parameters: Parameters | undefined;\n  @Input() view: View | undefined;\n  @Input() vrcube: Partial<WidgetVRCube> | undefined;\n  @Input() vrobject: Partial<WidgetVRObject> | undefined;\n  @Input() tags: string[] | undefined;\n  @Input() hotspotTemplateRef: TemplateRef<any> | null = null;\n  @Input() hotspotsFilter: ((hotspots: Hotspot[]) => Hotspot[]) | undefined;\n\n  @Output() onLoadStart = new EventEmitter();\n  @Output() onLoadProgress = new EventEmitter();\n  @Output() onLoadEnd = new EventEmitter();\n  @Output() onLoadError = new EventEmitter();\n  @Output() onInteraction = new EventEmitter();\n  @Output() onVrcubeInteraction = new EventEmitter();\n  @Output() onVrobjectInteraction = new EventEmitter();\n\n  @ViewChild('container') container!: ElementRef;\n\n  ngAfterViewInit() {\n    this.viewer = new Viewer(this.container.nativeElement, {\n      server: this.server,\n      api: this.api || 'v1',\n      fit: this.fit || 'cover',\n      events: {\n        onLoadStart: (...args: any[]) => { this.onLoadStart.emit(...args); },\n        onLoadProgress: (...args: any[]) => { this.onLoadProgress.emit(...args); },\n        onLoadEnd: (...args: any[]) => { this.onLoadEnd.emit(...args); },\n        onLoadError: (...args: any[]) => { this.onLoadError.emit(...args); },\n        onInteraction: (...args: any[]) => { this.onInteraction.emit(...args); },\n        onVrcubeInteraction: (...args: any[]) => { this.onVrcubeInteraction.emit(...args); },\n        onVrobjectInteraction: (...args: any[]) => { this.onVrobjectInteraction.emit(...args); },\n        onHotspotsChange: this.onHotspotsChange.bind(this)\n      },\n    });\n\n    if (this['scene']) {\n      this.viewer.load(this.scene).catch(() => { });\n    }\n\n    if (this['encoder']) {\n      this.viewer.setEncoder(this.encoder).catch(() => { });\n    }\n\n    if (this.parameters) {\n      this.viewer.setParameters(this.parameters).catch(() => { });\n    }\n\n    if (this.view) {\n      this.viewer.setView(this.view).catch(() => { });\n    }\n\n    if (this.vrcube) {\n      this.viewer.setVrcube(this.vrcube);\n    }\n\n    if (this.vrobject) {\n      this.viewer.setVrobject(this.vrobject);\n    }\n\n    if (this.tags) {\n      this.viewer.setTags(this.tags);\n    }\n\n    this.onResize();\n  }\n\n  ngOnDestroy(): void {\n    this.viewer?.destroy();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!this.viewer) {\n      return;\n    }\n\n    if (changes['scene'] && changes['scene'].currentValue) {\n      this.viewer.load(changes['scene'].currentValue).catch(() => { });\n    }\n\n    if (changes['encoder'] && changes['encoder'].currentValue) {\n      this.viewer.setEncoder(changes['encoder'].currentValue).catch(() => { });\n    }\n\n    if (changes['parameters'] && changes['parameters'].currentValue) {\n      this.viewer.setParameters(changes['parameters'].currentValue).catch(() => { });\n    }\n\n    if (changes['tags'] && changes['tags'].currentValue) {\n      this.viewer.setTags(changes['tags'].currentValue);\n    }\n\n    if (changes['view'] && changes['view'].currentValue) {\n      this.viewer.setView(changes['view'].currentValue).catch(() => { });\n    }\n\n    if (changes['vrcube'] && changes['vrcube'].currentValue) {\n      this.viewer.setVrcube(changes['vrcube'].currentValue);\n    }\n\n    if (changes['vrobject'] && changes['vrobject'].currentValue) {\n      this.viewer.setVrobject(changes['vrobject'].currentValue);\n    }\n  }\n\n  onHotspotsChange(hotspots: Hotspot[]): void {\n    this.hotspots = hotspots;\n\n    if (this.hotspotsFilter !== undefined) {\n      this.hotspots = this.hotspotsFilter(this.hotspots);\n    }\n  }\n\n  snapshot(type: string, quality: number): string | undefined {\n    return this.viewer?.snapshot(type, quality);\n  }\n\n  public fitPosition: { width: number, height: number, top: number, left: number } = { width: 1, height: 1, top: 1, left: 1 };\n  public resolution: { width: number, height: number } | undefined;\n  public scaleX: number = 1;\n  public scaleY: number = 1;\n\n  @HostListener('window:resize', ['$event'])\n  public onResize(): void {\n    this.resolution = Viewport.getStandardResolution(window.innerWidth, window.innerHeight);\n    this.fitPosition = Viewport.fit(this.resolution, window.innerWidth, window.innerHeight, 'cover');\n    this.scaleX = this.fitPosition.width / this.resolution.width;\n    this.scaleY = this.fitPosition.height / this.resolution.height;\n  }\n\n  public hotspotStyle(hotspot: Hotspot): { left: string, top: string, position: string } {\n    if (this.view?.mode === 'vrcube') {\n      return {\n        position: 'absolute',\n        top: hotspot.position2D.y + 'px',\n        left: hotspot.position2D.x + 'px'\n      };\n    } else {\n      return {\n        position: 'absolute',\n        top: (hotspot.position2D.y * this.scaleY + this.fitPosition.top) + 'px',\n        left: (hotspot.position2D.x * this.scaleX + this.fitPosition.left) + 'px'\n      };\n    }\n  }\n}\n","<div #container></div>\n\n<div class=\"position-absolute w-100 h-100\" style=\"pointer-events: none;\" *ngIf=\"hotspots.length\">\n  <div [ngStyle]=\"hotspotStyle(hotspot)\" *ngFor=\"let hotspot of hotspots\">\n    <ng-container *ngTemplateOutlet=\"hotspotTemplateRef; context:{hotspot: hotspot}\"></ng-container>\n  </div>\n</div>"]}
@@ -0,0 +1,25 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { NgViewerComponent } from './ng-viewer.component';
4
+ import * as i0 from "@angular/core";
5
+ class NgViewerModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NgViewerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.5", ngImport: i0, type: NgViewerModule, declarations: [NgViewerComponent], imports: [CommonModule], exports: [NgViewerComponent] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NgViewerModule, imports: [CommonModule] }); }
9
+ }
10
+ export { NgViewerModule };
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImport: i0, type: NgViewerModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [
15
+ NgViewerComponent
16
+ ],
17
+ imports: [
18
+ CommonModule
19
+ ],
20
+ exports: [
21
+ NgViewerComponent
22
+ ]
23
+ }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctdmlld2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXZpZXdlci9zcmMvbGliL25nLXZpZXdlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBRTFELE1BWWEsY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsaUJBVnZCLGlCQUFpQixhQUdqQixZQUFZLGFBR1osaUJBQWlCOytHQUlSLGNBQWMsWUFQdkIsWUFBWTs7U0FPSCxjQUFjOzJGQUFkLGNBQWM7a0JBWjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGlCQUFpQjtxQkFDbEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGlCQUFpQjtxQkFDbEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9uZy12aWV3ZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTmdWaWV3ZXJDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgTmdWaWV3ZXJDb21wb25lbnRcbiAgXVxufSlcblxuZXhwb3J0IGNsYXNzIE5nVmlld2VyTW9kdWxlIHsgfVxuIl19
@@ -1,72 +1,72 @@
1
- export class Viewport {
2
- static fit(resolution, viewportWidth, viewportHeight, fit) {
3
- const aspectRatio = resolution.width / resolution.height;
4
- const viewportRatio = viewportWidth / viewportHeight;
5
- let width = 0;
6
- let height = 0;
7
- switch (fit) {
8
- case 'contain':
9
- width = viewportRatio < aspectRatio ? viewportWidth : viewportHeight * aspectRatio;
10
- height = viewportRatio < aspectRatio ? viewportWidth / aspectRatio : viewportHeight;
11
- break;
12
- case 'cover':
13
- default:
14
- width = viewportRatio < aspectRatio ? viewportHeight * aspectRatio : viewportWidth;
15
- height = viewportRatio < aspectRatio ? viewportHeight : viewportWidth / aspectRatio;
16
- break;
17
- case 'fill':
18
- width = viewportWidth;
19
- height = viewportHeight;
20
- break;
21
- }
22
- return {
23
- width: Math.round(width),
24
- height: Math.round(height),
25
- top: Math.round((viewportHeight - height) / 2),
26
- left: Math.round((viewportWidth - width) / 2),
27
- };
28
- }
29
- static getStandardAspectRatio(width, height) {
30
- if (width === 0 || height === 0) {
31
- return 0;
32
- }
33
- const aspectRatio = width / height;
34
- if (width < height) {
35
- const distanceTo34 = Math.abs(3 / 4 - aspectRatio);
36
- const distanceTo916 = Math.abs(9 / 16 - aspectRatio);
37
- return distanceTo34 < distanceTo916 ? 3 / 4 : 9 / 16;
38
- }
39
- const distanceTo43 = Math.abs(4 / 3 - aspectRatio);
40
- const distanceTo169 = Math.abs(16 / 9 - aspectRatio);
41
- return distanceTo43 < distanceTo169 ? 4 / 3 : 16 / 9;
42
- }
43
- static getStandardQuality(height) {
44
- if (height <= 240) {
45
- return 240;
46
- }
47
- if (height <= 360) {
48
- return 360;
49
- }
50
- if (height <= 480) {
51
- return 480;
52
- }
53
- if (height <= 720) {
54
- return 720;
55
- }
56
- return 1080;
57
- }
58
- static getStandardResolution(width, height) {
59
- if (width === 0 || height === 0) {
60
- return { width: 0, height: 0 };
61
- }
62
- const aspectRatio = Viewport.getStandardAspectRatio(width, height);
63
- if (width < height) {
64
- const quality = Viewport.getStandardQuality(height * aspectRatio);
65
- return { width: Math.round(quality), height: Math.round(quality / aspectRatio) };
66
- }
67
- const quality = Viewport.getStandardQuality(width / aspectRatio);
68
- return { width: Math.round(quality * aspectRatio), height: Math.round(quality) };
69
- }
70
- }
71
- export default Viewport;
1
+ export class Viewport {
2
+ static fit(resolution, viewportWidth, viewportHeight, fit) {
3
+ const aspectRatio = resolution.width / resolution.height;
4
+ const viewportRatio = viewportWidth / viewportHeight;
5
+ let width = 0;
6
+ let height = 0;
7
+ switch (fit) {
8
+ case 'contain':
9
+ width = viewportRatio < aspectRatio ? viewportWidth : viewportHeight * aspectRatio;
10
+ height = viewportRatio < aspectRatio ? viewportWidth / aspectRatio : viewportHeight;
11
+ break;
12
+ case 'cover':
13
+ default:
14
+ width = viewportRatio < aspectRatio ? viewportHeight * aspectRatio : viewportWidth;
15
+ height = viewportRatio < aspectRatio ? viewportHeight : viewportWidth / aspectRatio;
16
+ break;
17
+ case 'fill':
18
+ width = viewportWidth;
19
+ height = viewportHeight;
20
+ break;
21
+ }
22
+ return {
23
+ width: Math.round(width),
24
+ height: Math.round(height),
25
+ top: Math.round((viewportHeight - height) / 2),
26
+ left: Math.round((viewportWidth - width) / 2),
27
+ };
28
+ }
29
+ static getStandardAspectRatio(width, height) {
30
+ if (width === 0 || height === 0) {
31
+ return 0;
32
+ }
33
+ const aspectRatio = width / height;
34
+ if (width < height) {
35
+ const distanceTo34 = Math.abs(3 / 4 - aspectRatio);
36
+ const distanceTo916 = Math.abs(9 / 16 - aspectRatio);
37
+ return distanceTo34 < distanceTo916 ? 3 / 4 : 9 / 16;
38
+ }
39
+ const distanceTo43 = Math.abs(4 / 3 - aspectRatio);
40
+ const distanceTo169 = Math.abs(16 / 9 - aspectRatio);
41
+ return distanceTo43 < distanceTo169 ? 4 / 3 : 16 / 9;
42
+ }
43
+ static getStandardQuality(height) {
44
+ if (height <= 240) {
45
+ return 240;
46
+ }
47
+ if (height <= 360) {
48
+ return 360;
49
+ }
50
+ if (height <= 480) {
51
+ return 480;
52
+ }
53
+ if (height <= 720) {
54
+ return 720;
55
+ }
56
+ return 1080;
57
+ }
58
+ static getStandardResolution(width, height) {
59
+ if (width === 0 || height === 0) {
60
+ return { width: 0, height: 0 };
61
+ }
62
+ const aspectRatio = Viewport.getStandardAspectRatio(width, height);
63
+ if (width < height) {
64
+ const quality = Viewport.getStandardQuality(height * aspectRatio);
65
+ return { width: Math.round(quality), height: Math.round(quality / aspectRatio) };
66
+ }
67
+ const quality = Viewport.getStandardQuality(width / aspectRatio);
68
+ return { width: Math.round(quality * aspectRatio), height: Math.round(quality) };
69
+ }
70
+ }
71
+ export default Viewport;
72
72
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aWV3ZXIvc3JjL2xpYi92aWV3cG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sUUFBUTtJQUNaLE1BQU0sQ0FBQyxHQUFHLENBQUMsVUFBZSxFQUFFLGFBQWtCLEVBQUUsY0FBbUIsRUFBRSxHQUFRO1FBQ2xGLE1BQU0sV0FBVyxHQUFHLFVBQVUsQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztRQUN6RCxNQUFNLGFBQWEsR0FBRyxhQUFhLEdBQUcsY0FBYyxDQUFDO1FBRXJELElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNkLElBQUksTUFBTSxHQUFHLENBQUMsQ0FBQztRQUVmLFFBQVEsR0FBRyxFQUFFO1lBQ1gsS0FBSyxTQUFTO2dCQUNaLEtBQUssR0FBRyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLGNBQWMsR0FBRyxXQUFXLENBQUM7Z0JBQ25GLE1BQU0sR0FBRyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUM7Z0JBQ3BGLE1BQU07WUFDUixLQUFLLE9BQU8sQ0FBQztZQUNiO2dCQUNFLEtBQUssR0FBRyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxjQUFjLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUM7Z0JBQ25GLE1BQU0sR0FBRyxhQUFhLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWEsR0FBRyxXQUFXLENBQUM7Z0JBQ3BGLE1BQU07WUFDUixLQUFLLE1BQU07Z0JBQ1QsS0FBSyxHQUFHLGFBQWEsQ0FBQztnQkFDdEIsTUFBTSxHQUFHLGNBQWMsQ0FBQztnQkFDeEIsTUFBTTtTQUNUO1FB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SSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsV0FBVyxDQUFDLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztJQUNuRixDQUFDO0NBQ0Y7QUFFRCxlQUFlLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBWaWV3cG9ydCB7XG4gIHB1YmxpYyBzdGF0aWMgZml0KHJlc29sdXRpb246IGFueSwgdmlld3BvcnRXaWR0aDogYW55LCB2aWV3cG9ydEhlaWdodDogYW55LCBmaXQ6IGFueSk6IHsgd2lkdGg6IG51bWJlciwgaGVpZ2h0OiBudW1iZXIsIHRvcDogbnVtYmVyLCBsZWZ0OiBudW1iZXIgfSB7XG4gICAgY29uc3QgYXNwZWN0UmF0aW8gPSByZXNvbHV0aW9uLndpZHRoIC8gcmVzb2x1dGlvbi5oZWlnaHQ7XG4gICAgY29uc3Qgdmlld3BvcnRSYXRpbyA9IHZpZXdwb3J0V2lkdGggLyB2aWV3cG9ydEhlaWdodDtcblxuICAgIGxldCB3aWR0aCA9IDA7XG4gICAgbGV0IGhlaWdodCA9IDA7XG5cbiAgICBzd2l0Y2ggKGZpdCkge1xuICAgICAgY2FzZSAnY29udGFpbic6XG4gICAgICAgIHdpZHRoID0gdmlld3BvcnRSYXRpbyA8IGFzcGVjdFJhdGlvID8gdmlld3BvcnRXaWR0aCA6IHZpZXdwb3J0SGVpZ2h0ICogYXNwZWN0UmF0aW87XG4gICAgICAgIGhlaWdodCA9IHZpZXdwb3J0UmF0aW8gPCBhc3BlY3RSYXRpbyA/IHZpZXdwb3J0V2lkdGggLyBhc3BlY3RSYXRpbyA6IHZpZXdwb3J0SGVpZ2h0O1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ2NvdmVyJzpcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHdpZHRoID0gdmlld3BvcnRSYXRpbyA8IGFzcGVjdFJhdGlvID8gdmlld3BvcnRIZWlnaHQgKiBhc3BlY3RSYXRpbyA6IHZpZXdwb3J0V2lkdGg7XG4gICAgICAgIGhlaWdodCA9IHZpZXdwb3J0UmF0aW8gPCBhc3BlY3RSYXRpbyA/IHZpZXdwb3J0SGVpZ2h0IDogdmlld3BvcnRXaWR0aCAvIGFzcGVjdFJhdGlvO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ2ZpbGwnOlxuICAgICAgICB3aWR0aCA9IHZpZXdwb3J0V2lkdGg7XG4gICAgICAgIGhlaWdodCA9IHZpZXdwb3J0SGVpZ2h0O1xuICAgICAgICBicmVhaztcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgd2lkdGg6IE1hdGgucm91bmQod2lkdGgpLFxuICAgICAgaGVpZ2h0OiBNYXRoLnJvdW5kKGhlaWdodCksXG4gICAgICB0b3A6IE1hdGgucm91bmQoKHZpZXdwb3J0SGVpZ2h0IC0gaGVpZ2h0KSAvIDIpLFxuICAgICAgbGVmdDogTWF0aC5yb3VuZCgodmlld3BvcnRXaWR0aCAtIHdpZHRoKSAvIDIpLFxuICAgIH07XG4gIH1cblxuICBzdGF0aWMgZ2V0U3RhbmRhcmRBc3BlY3RSYXRpbyh3aWR0aDogbnVtYmVyLCBoZWlnaHQ6IG51bWJlcik6IG51bWJlciB7XG4gICAgaWYgKHdpZHRoID09PSAwIHx8IGhlaWdodCA9PT0gMCkge1xuICAgICAgcmV0dXJuIDA7XG4gICAgfVxuXG4gICAgY29uc3QgYXNwZWN0UmF0aW8gPSB3aWR0aCAvIGhlaWdodDtcblxuICAgIGlmICh3aWR0aCA8IGhlaWdodCkge1xuICAgICAgY29uc3QgZGlzdGFuY2VUbzM0ID0gTWF0aC5hYnMoMyAvIDQgLSBhc3BlY3RSYXRpbyk7XG4gICAgICBjb25zdCBkaXN0YW5jZVRvOTE2ID0gTWF0aC5hYnMoOSAvIDE2IC0gYXNwZWN0UmF0aW8pO1xuICAgICAgcmV0dXJuIGRpc3RhbmNlVG8zNCA8IGRpc3RhbmNlVG85MTYgPyAzIC8gNCA6IDkgLyAxNjtcbiAgICB9XG5cbiAgICBjb25zdCBkaXN0YW5jZVRvNDMgPSBNYXRoLmFicyg0IC8gMyAtIGFzcGVjdFJhdGlvKTtcbiAgICBjb25zdCBkaXN0YW5jZVRvMTY5ID0gTWF0aC5hYnMoMTYgLyA5IC0gYXNwZWN0UmF0aW8pO1xuXG4gICAgcmV0dXJuIGRpc3RhbmNlVG80MyA8IGRpc3RhbmNlVG8xNjkgPyA0IC8gMyA6IDE2IC8gOTtcbiAgfVxuXG4gIHN0YXRpYyBnZXRTdGFuZGFyZFF1YWxpdHkoaGVpZ2h0OiBudW1iZXIpOiBudW1iZXIge1xuICAgIGlmIChoZWlnaHQgPD0gMjQwKSB7XG4gICAgICByZXR1cm4gMjQwO1xuICAgIH1cblxuICAgIGlmIChoZWlnaHQgPD0gMzYwKSB7XG4gICAgICByZXR1cm4gMzYwO1xuICAgIH1cblxuICAgIGlmIChoZWlnaHQgPD0gNDgwKSB7XG4gICAgICByZXR1cm4gNDgwO1xuICAgIH1cblxuICAgIGlmIChoZWlnaHQgPD0gNzIwKSB7XG4gICAgICByZXR1cm4gNzIwO1xuICAgIH1cblxuICAgIHJldHVybiAxMDgwO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBnZXRTdGFuZGFyZFJlc29sdXRpb24od2lkdGg6IG51bWJlciwgaGVpZ2h0OiBudW1iZXIpOiB7IHdpZHRoOiBudW1iZXIsIGhlaWdodDogbnVtYmVyIH0ge1xuICAgIGlmICh3aWR0aCA9PT0gMCB8fCBoZWlnaHQgPT09IDApIHtcbiAgICAgIHJldHVybiB7IHdpZHRoOiAwLCBoZWlnaHQ6IDAgfTtcbiAgICB9XG5cbiAgICBjb25zdCBhc3BlY3RSYXRpbyA9IFZpZXdwb3J0LmdldFN0YW5kYXJkQXNwZWN0UmF0aW8od2lkdGgsIGhlaWdodCk7XG5cbiAgICBpZiAod2lkdGggPCBoZWlnaHQpIHtcbiAgICAgIGNvbnN0IHF1YWxpdHkgPSBWaWV3cG9ydC5nZXRTdGFuZGFyZFF1YWxpdHkoaGVpZ2h0ICogYXNwZWN0UmF0aW8pO1xuICAgICAgcmV0dXJuIHsgd2lkdGg6IE1hdGgucm91bmQocXVhbGl0eSksIGhlaWdodDogTWF0aC5yb3VuZChxdWFsaXR5IC8gYXNwZWN0UmF0aW8pIH07XG4gICAgfVxuXG4gICAgY29uc3QgcXVhbGl0eSA9IFZpZXdwb3J0LmdldFN0YW5kYXJkUXVhbGl0eSh3aWR0aCAvIGFzcGVjdFJhdGlvKTtcbiAgICByZXR1cm4geyB3aWR0aDogTWF0aC5yb3VuZChxdWFsaXR5ICogYXNwZWN0UmF0aW8pLCBoZWlnaHQ6IE1hdGgucm91bmQocXVhbGl0eSkgfTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBWaWV3cG9ydDtcbiJdfQ==
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibHVtaXNjYXBoZS1uZy12aWV3ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9uZy12aWV3ZXIvc3JjL2x1bWlzY2FwaGUtbmctdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
@@ -1,6 +1,6 @@
1
- /*
2
- * Public API Surface of ng-viewer
3
- */
4
- export * from './lib/ng-viewer.component';
5
- export * from './lib/ng-viewer.module';
1
+ /*
2
+ * Public API Surface of ng-viewer
3
+ */
4
+ export * from './lib/ng-viewer.component';
5
+ export * from './lib/ng-viewer.module';
6
6
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXZpZXdlci9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygbmctdmlld2VyXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmctdmlld2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZy12aWV3ZXIubW9kdWxlJztcbiJdfQ==