bilca commited on
Commit
bae1b70
·
verified ·
1 Parent(s): aed8983

Update js_scripts/index.js

Browse files
Files changed (1) hide show
  1. js_scripts/index.js +43 -3
js_scripts/index.js CHANGED
@@ -60,6 +60,7 @@ const currentScriptTag = document.currentScript;
60
  let modelEntity = null;
61
  let viewerInitialized = false;
62
  let wheelHandlers = [];
 
63
 
64
  // Generate a unique identifier for this widget instance.
65
  const instanceId = Math.random().toString(36).substr(2, 8);
@@ -211,6 +212,8 @@ const currentScriptTag = document.currentScript;
211
  // and hide the "close" button since there's no preview to return to.
212
  if (gifUrl) {
213
  previewImage.src = gifUrl;
 
 
214
  } else {
215
  gifPreview.style.display = 'none';
216
  viewerContainer.style.display = 'block';
@@ -236,6 +239,12 @@ const currentScriptTag = document.currentScript;
236
  }
237
  wheelHandlers = [];
238
 
 
 
 
 
 
 
239
  // Destroy PlayCanvas app if it exists
240
  if (app) {
241
  app.destroy();
@@ -246,6 +255,19 @@ const currentScriptTag = document.currentScript;
246
  cameraEntity = null;
247
  modelEntity = null;
248
  viewerInitialized = false;
 
 
 
 
 
 
 
 
 
 
 
 
 
249
  }
250
 
251
  closeBtn.addEventListener('click', function() {
@@ -455,8 +477,12 @@ const currentScriptTag = document.currentScript;
455
  // --- Initialize the 3D PLY Viewer using PlayCanvas ---
456
  async function initializeViewer() {
457
  // Skip initialization if already initialized
458
- if (viewerInitialized) return;
 
 
 
459
 
 
460
  progressDialog.style.display = 'block';
461
 
462
  // Initialize PlayCanvas
@@ -509,8 +535,14 @@ const currentScriptTag = document.currentScript;
509
  app.resizeCanvas(canvas.clientWidth, canvas.clientHeight);
510
  }
511
  };
512
- window.addEventListener('resize', resize);
513
- app.on('destroy', () => window.removeEventListener('resize', resize));
 
 
 
 
 
 
514
 
515
  // Load required assets
516
  const assets = {
@@ -548,6 +580,11 @@ const currentScriptTag = document.currentScript;
548
 
549
  const progressChecker = setInterval(checkProgress, 100);
550
 
 
 
 
 
 
551
  // Load assets and set up scene
552
  assetListLoader.load(() => {
553
  app.start();
@@ -648,11 +685,14 @@ const currentScriptTag = document.currentScript;
648
 
649
  // Mark viewer as initialized
650
  viewerInitialized = true;
 
 
651
  });
652
 
653
  } catch (error) {
654
  console.error("Error initializing PlayCanvas viewer:", error);
655
  progressDialog.innerHTML = `<p style="color: red">Error loading viewer: ${error.message}</p>`;
 
656
  }
657
  }
658
  })();
 
60
  let modelEntity = null;
61
  let viewerInitialized = false;
62
  let wheelHandlers = [];
63
+ let resizeHandler = null;
64
 
65
  // Generate a unique identifier for this widget instance.
66
  const instanceId = Math.random().toString(36).substr(2, 8);
 
212
  // and hide the "close" button since there's no preview to return to.
213
  if (gifUrl) {
214
  previewImage.src = gifUrl;
215
+ viewerContainer.style.display = 'none';
216
+ gifPreview.style.display = 'block';
217
  } else {
218
  gifPreview.style.display = 'none';
219
  viewerContainer.style.display = 'block';
 
239
  }
240
  wheelHandlers = [];
241
 
242
+ // Remove resize handler if it exists
243
+ if (resizeHandler) {
244
+ window.removeEventListener('resize', resizeHandler);
245
+ resizeHandler = null;
246
+ }
247
+
248
  // Destroy PlayCanvas app if it exists
249
  if (app) {
250
  app.destroy();
 
255
  cameraEntity = null;
256
  modelEntity = null;
257
  viewerInitialized = false;
258
+
259
+ // Reset the canvas
260
+ if (canvas) {
261
+ const ctx = canvas.getContext('webgl2') || canvas.getContext('webgl');
262
+ if (ctx) {
263
+ ctx.getExtension('WEBGL_lose_context')?.loseContext();
264
+ }
265
+ }
266
+
267
+ // Mark the viewer as not initialized
268
+ viewerInitialized = false;
269
+
270
+ console.log("Viewer cleanup complete");
271
  }
272
 
273
  closeBtn.addEventListener('click', function() {
 
477
  // --- Initialize the 3D PLY Viewer using PlayCanvas ---
478
  async function initializeViewer() {
479
  // Skip initialization if already initialized
480
+ if (viewerInitialized) {
481
+ console.log("Viewer already initialized, skipping");
482
+ return;
483
+ }
484
 
485
+ console.log("Initializing PLY viewer...");
486
  progressDialog.style.display = 'block';
487
 
488
  // Initialize PlayCanvas
 
535
  app.resizeCanvas(canvas.clientWidth, canvas.clientHeight);
536
  }
537
  };
538
+
539
+ // Store resize handler for cleanup
540
+ resizeHandler = resize;
541
+ window.addEventListener('resize', resizeHandler);
542
+ app.on('destroy', () => {
543
+ window.removeEventListener('resize', resizeHandler);
544
+ resizeHandler = null;
545
+ });
546
 
547
  // Load required assets
548
  const assets = {
 
580
 
581
  const progressChecker = setInterval(checkProgress, 100);
582
 
583
+ // Store the interval for cleanup
584
+ app.once('destroy', () => {
585
+ clearInterval(progressChecker);
586
+ });
587
+
588
  // Load assets and set up scene
589
  assetListLoader.load(() => {
590
  app.start();
 
685
 
686
  // Mark viewer as initialized
687
  viewerInitialized = true;
688
+
689
+ console.log("PLY viewer initialization complete");
690
  });
691
 
692
  } catch (error) {
693
  console.error("Error initializing PlayCanvas viewer:", error);
694
  progressDialog.innerHTML = `<p style="color: red">Error loading viewer: ${error.message}</p>`;
695
+ viewerInitialized = false;
696
  }
697
  }
698
  })();