threepipe
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

index.html 2.1KB

1 år sedan
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Threepipe Vue/HTML Sample</title>
  6. <style>
  7. html, body{
  8. width: 100%;
  9. height: 100%;
  10. margin: 0;
  11. overflow: hidden;
  12. }
  13. </style>
  14. <script type="module" src="../examples-utils/global-loading.mjs"></script>
  15. <script type="module" src="../examples-utils/simple-code-preview.mjs"></script>
  16. </head>
  17. <body>
  18. <div id="app">
  19. <canvas id="three-canvas" style="width: 800px; height: 600px" ref="canvasRef"></canvas>
  20. </div>
  21. <script id="example-script" type="module" data-scripts="./index.html">
  22. // import { ThreeViewer, LoadingScreenPlugin } from 'https://unpkg.com/threepipe@latest/dist/index.mjs'
  23. import { ThreeViewer, LoadingScreenPlugin, _testStart, _testFinish } from './../../dist/index.mjs'
  24. import { createApp, ref, onMounted, onBeforeUnmount } from "https://unpkg.com/vue@3/dist/vue.esm-browser.prod.js";
  25. _testStart()
  26. const ThreeViewerComponent = {
  27. setup() {
  28. const canvasRef = ref(null);
  29. onMounted(() => {
  30. const viewer = new ThreeViewer({
  31. canvas: canvasRef.value,
  32. plugins: [LoadingScreenPlugin],
  33. });
  34. // Load an environment map
  35. const envPromise = viewer.setEnvironmentMap('https://threejs.org/examples/textures/equirectangular/venice_sunset_1k.hdr');
  36. const modelPromise = viewer.load('https://threejs.org/examples/models/gltf/DamagedHelmet/glTF/DamagedHelmet.gltf', {
  37. autoCenter: true,
  38. autoScale: true,
  39. });
  40. Promise.all([envPromise, modelPromise]).then(([env, model]) => {
  41. console.log('Loaded', model, env, viewer);
  42. _testFinish()
  43. });
  44. onBeforeUnmount(() => {
  45. viewer.dispose();
  46. });
  47. });
  48. return { canvasRef };
  49. },
  50. };
  51. const app = createApp(ThreeViewerComponent);
  52. app.mount('#app');
  53. </script>
  54. </body>
  55. </html>