viewerManager.ts 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /// <reference path="../../../dist/preview release/babylon.d.ts"/>
  2. import { Observable } from 'babylonjs';
  3. import { AbstractViewer } from './viewer';
  4. export class ViewerManager {
  5. private viewers: { [key: string]: AbstractViewer };
  6. public onViewerAdded: (viewer: AbstractViewer) => void;
  7. public onViewerAddedObservable: Observable<AbstractViewer>;
  8. constructor() {
  9. this.viewers = {};
  10. this.onViewerAddedObservable = new Observable();
  11. }
  12. public addViewer(viewer: AbstractViewer) {
  13. this.viewers[viewer.getBaseId()] = viewer;
  14. this._onViewerAdded(viewer);
  15. }
  16. public getViewerById(id: string): AbstractViewer {
  17. return this.viewers[id];
  18. }
  19. public getViewerByHTMLElement(element: HTMLElement) {
  20. for (let id in this.viewers) {
  21. if (this.viewers[id].containerElement === element) {
  22. return this.getViewerById(id);
  23. }
  24. }
  25. }
  26. public getViewerPromiseById(id: string): Promise<AbstractViewer> {
  27. return new Promise((resolve, reject) => {
  28. let localViewer = this.getViewerById(id)
  29. if (localViewer) {
  30. return resolve(localViewer);
  31. }
  32. let viewerFunction = (viewer: AbstractViewer) => {
  33. if (viewer.getBaseId() === id) {
  34. resolve(viewer);
  35. this.onViewerAddedObservable.removeCallback(viewerFunction);
  36. }
  37. }
  38. this.onViewerAddedObservable.add(viewerFunction);
  39. });
  40. }
  41. private _onViewerAdded(viewer: AbstractViewer) {
  42. this.onViewerAdded && this.onViewerAdded(viewer);
  43. this.onViewerAddedObservable.notifyObservers(viewer);
  44. }
  45. }
  46. export let viewerManager = new ViewerManager();