diff --git a/packages/model-viewer/src/features/ar.ts b/packages/model-viewer/src/features/ar.ts index 312d006306..96ee08a0f1 100644 --- a/packages/model-viewer/src/features/ar.ts +++ b/packages/model-viewer/src/features/ar.ts @@ -64,6 +64,7 @@ const $onARStatus = Symbol('onARStatus'); const $onARTracking = Symbol('onARTracking'); const $onARTap = Symbol('onARTap'); const $selectARMode = Symbol('selectARMode'); +const $triggerLoad = Symbol('triggerLoad'); export declare interface ARInterface { ar: boolean; @@ -260,12 +261,7 @@ configuration or device capabilities'); protected async[$enterARWithWebXR]() { console.log('Attempting to present in AR with WebXR...'); - if (!this.loaded) { - this[$preload] = true; - this[$updateSource](); - await waitForEvent(this, 'load'); - this[$preload] = false; - } + await this[$triggerLoad](); try { this[$arButtonContainer].removeEventListener( @@ -286,6 +282,15 @@ configuration or device capabilities'); } } + async[$triggerLoad]() { + if (!this.loaded) { + this[$preload] = true; + this[$updateSource](); + await waitForEvent(this, 'load'); + this[$preload] = false; + } + } + [$shouldAttemptPreload](): boolean { return super[$shouldAttemptPreload]() || this[$preload]; } @@ -392,6 +397,8 @@ configuration or device capabilities'); async prepareUSDZ(): Promise { const updateSourceProgress = this[$progressTracker].beginActivity(); + await this[$triggerLoad](); + const scene = this[$scene]; const shadow = scene.shadow; diff --git a/packages/modelviewer.dev/index.html b/packages/modelviewer.dev/index.html index cd7a983307..cfa644b87e 100644 --- a/packages/modelviewer.dev/index.html +++ b/packages/modelviewer.dev/index.html @@ -56,7 +56,7 @@

Quick Start

- + diff --git a/packages/modelviewer.dev/styles/examples.css b/packages/modelviewer.dev/styles/examples.css index 4ef796a8a6..4931f221aa 100644 --- a/packages/modelviewer.dev/styles/examples.css +++ b/packages/modelviewer.dev/styles/examples.css @@ -371,7 +371,7 @@ model-viewer:focus { box-sizing: border-box; } -.examples-container > .sample > .demo { +.sample > .demo { height: 100vh; } @@ -754,7 +754,7 @@ paper-button { padding-top: 0px; } - .examples-container > .sample > .demo { + .sample > .demo { top: 0; height: 150vw; }