dylanebert HF staff commited on
Commit
4e1da8c
·
1 Parent(s): c087f79

add skeleton library

Browse files
viewer/src/lib/{dataLoader.ts → data/dataLoader.ts} RENAMED
File without changes
viewer/src/lib/splat.js/cameras/PerspectiveCamera.ts ADDED
@@ -0,0 +1,32 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import { Camera } from '../core/Camera';
2
+ import { Matrix4 } from '../math/Matrix4';
3
+
4
+ export class PerspectiveCamera extends Camera {
5
+ fx: number;
6
+ fy: number;
7
+
8
+ near: number;
9
+ far: number;
10
+
11
+ projectionMatrix: Matrix4;
12
+
13
+ constructor(fx: number = 1132, fy: number = 1132, near: number = 0.1, far: number = 100) {
14
+ super();
15
+
16
+ this.fx = fx;
17
+ this.fy = fy;
18
+ this.near = near;
19
+ this.far = far;
20
+
21
+ this.projectionMatrix = new Matrix4();
22
+ }
23
+
24
+ updateProjectionMatrix(width: number, height: number) : void {
25
+ this.projectionMatrix.set(
26
+ 2 * this.fx / width, 0, 0, 0,
27
+ 0, -2 * this.fy / height, 0, 0,
28
+ 0, 0, this.far / (this.far - this.near), 1,
29
+ 0, 0, -this.near * this.far / (this.far - this.near), 0
30
+ );
31
+ }
32
+ }
viewer/src/lib/splat.js/core/Camera.ts ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ import { Object3D } from './Object3D';
2
+ import { Matrix4 } from '../math/Matrix4';
3
+
4
+ export class Camera extends Object3D {
5
+ constructor() {
6
+ super();
7
+ }
8
+ }
viewer/src/lib/splat.js/core/Object3D.ts ADDED
@@ -0,0 +1,12 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import { Vector3 } from '../math/Vector3';
2
+ import { Quaternion } from '../math/Quaternion';
3
+
4
+ export class Object3D {
5
+ position: Vector3;
6
+ rotation: Quaternion;
7
+
8
+ constructor() {
9
+ this.position = new Vector3();
10
+ this.rotation = new Quaternion();
11
+ }
12
+ }
viewer/src/lib/splat.js/core/Renderer.ts ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ import type { Scene } from './Scene';
2
+ import type { Camera } from './Camera';
3
+
4
+ export interface Renderer {
5
+ render(scene: Scene, camera: Camera): void;
6
+ }
viewer/src/lib/splat.js/core/Scene.ts ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ export class Scene {
2
+
3
+ }
viewer/src/lib/splat.js/index.ts ADDED
@@ -0,0 +1,8 @@
 
 
 
 
 
 
 
 
 
1
+ export * from './core/Camera';
2
+ export * from './core/Renderer';
3
+ export * from './core/Scene';
4
+
5
+ export * from './renderers/WebGLRenderer';
6
+
7
+ export * from './math/Quaternion';
8
+ export * from './math/Vector3';
viewer/src/lib/splat.js/math/Matrix4.ts ADDED
@@ -0,0 +1,31 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ export class Matrix4 {
2
+ elements: number[];
3
+
4
+ constructor(n11: number = 1, n12: number = 0, n13: number = 0, n14: number = 0,
5
+ n21: number = 0, n22: number = 1, n23: number = 0, n24: number = 0,
6
+ n31: number = 0, n32: number = 0, n33: number = 1, n34: number = 0,
7
+ n41: number = 0, n42: number = 0, n43: number = 0, n44: number = 1) {
8
+ this.elements = new Array(16);
9
+
10
+ this.set(
11
+ n11, n12, n13, n14,
12
+ n21, n22, n23, n24,
13
+ n31, n32, n33, n34,
14
+ n41, n42, n43, n44
15
+ );
16
+ }
17
+
18
+ set(n11: number, n12: number, n13: number, n14: number,
19
+ n21: number, n22: number, n23: number, n24: number,
20
+ n31: number, n32: number, n33: number, n34: number,
21
+ n41: number, n42: number, n43: number, n44: number) : Matrix4 {
22
+ const e = this.elements;
23
+
24
+ e[0] = n11; e[4] = n12; e[8] = n13; e[12] = n14;
25
+ e[1] = n21; e[5] = n22; e[9] = n23; e[13] = n24;
26
+ e[2] = n31; e[6] = n32; e[10] = n33; e[14] = n34;
27
+ e[3] = n41; e[7] = n42; e[11] = n43; e[15] = n44;
28
+
29
+ return this;
30
+ }
31
+ }
viewer/src/lib/splat.js/math/Quaternion.ts ADDED
@@ -0,0 +1,22 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ export class Quaternion {
2
+ x: number;
3
+ y: number;
4
+ z: number;
5
+ w: number;
6
+
7
+ constructor(x: number = 0, y: number = 0, z: number = 0, w: number = 1) {
8
+ this.x = x;
9
+ this.y = y;
10
+ this.z = z;
11
+ this.w = w;
12
+ }
13
+
14
+ set(x: number, y: number, z: number, w: number) : Quaternion {
15
+ this.x = x;
16
+ this.y = y;
17
+ this.z = z;
18
+ this.w = w;
19
+
20
+ return this;
21
+ }
22
+ }
viewer/src/lib/splat.js/math/Vector3.ts ADDED
@@ -0,0 +1,19 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ export class Vector3 {
2
+ x: number;
3
+ y: number;
4
+ z: number;
5
+
6
+ constructor(x: number = 0, y: number = 0, z: number = 0) {
7
+ this.x = x;
8
+ this.y = y;
9
+ this.z = z;
10
+ }
11
+
12
+ set(x: number, y: number, z: number) : Vector3 {
13
+ this.x = x;
14
+ this.y = y;
15
+ this.z = z;
16
+
17
+ return this;
18
+ }
19
+ }
viewer/src/lib/splat.js/renderers/WebGLRenderer.ts ADDED
@@ -0,0 +1,9 @@
 
 
 
 
 
 
 
 
 
 
1
+ import type { Scene } from '../core/Scene';
2
+ import type { Camera } from '../core/Camera';
3
+ import type { Renderer } from '../core/Renderer';
4
+
5
+ export class WebGLRenderer implements Renderer {
6
+ render(scene: Scene, camera: Camera): void {
7
+
8
+ }
9
+ }
viewer/src/routes/components/ModelsView.svelte CHANGED
@@ -1,6 +1,6 @@
1
  <script lang="ts">
2
  import { onMount } from "svelte";
3
- import { getModels, getScenes } from "$lib/dataLoader";
4
  import placeholderImage from "$lib/placeholder.png";
5
 
6
  let models: any[] = [];
 
1
  <script lang="ts">
2
  import { onMount } from "svelte";
3
+ import { getModels, getScenes } from "$lib/data/dataLoader";
4
  import placeholderImage from "$lib/placeholder.png";
5
 
6
  let models: any[] = [];
viewer/src/routes/components/ScenesView.svelte CHANGED
@@ -1,6 +1,6 @@
1
  <script lang="ts">
2
  import { onMount } from "svelte";
3
- import { getScenes } from "$lib/dataLoader";
4
  import placeholderImage from "$lib/placeholder.png";
5
 
6
  let scenes: any[] = [];
 
1
  <script lang="ts">
2
  import { onMount } from "svelte";
3
+ import { getScenes } from "$lib/data/dataLoader";
4
  import placeholderImage from "$lib/placeholder.png";
5
 
6
  let scenes: any[] = [];
viewer/src/routes/models/[slug]/+page.server.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { getModels, getScenes } from "$lib/dataLoader";
2
 
3
  export async function load({ params }) {
4
  const models = await getModels();
 
1
+ import { getModels, getScenes } from "$lib/data/dataLoader";
2
 
3
  export async function load({ params }) {
4
  const models = await getModels();
viewer/src/routes/store.js CHANGED
@@ -1,3 +1,3 @@
1
  import { writable } from 'svelte/store';
2
 
3
- export const activeTab = writable('Models');
 
1
  import { writable } from 'svelte/store';
2
 
3
+ export const activeTab = writable('Models');
viewer/src/routes/viewer/[slug]/+page.server.ts CHANGED
@@ -1,5 +1,5 @@
1
  import { error } from "@sveltejs/kit";
2
- import { getModels, getScenes } from "$lib/dataLoader";
3
 
4
  export async function load({ params }) {
5
  const models = await getModels();
 
1
  import { error } from "@sveltejs/kit";
2
+ import { getModels, getScenes } from "$lib/data/dataLoader";
3
 
4
  export async function load({ params }) {
5
  const models = await getModels();
viewer/src/routes/viewer/[slug]/+page.svelte CHANGED
@@ -41,7 +41,7 @@
41
  console.error(`Unsupported scene type: ${data.scene.type}`);
42
  }
43
  handleMobileView();
44
- await loadModel(data.scene.url);
45
  window.addEventListener("resize", () => {
46
  updateCanvasSize();
47
  });
@@ -87,9 +87,9 @@
87
  babylonViewer.setRenderMode(mode);
88
  }
89
 
90
- async function loadModel(url: string) {
91
  overlay.style.display = "flex";
92
- await viewer.loadModel(url, (progress) => {
93
  loadingBarFill.style.width = `${progress * 100}%`;
94
  });
95
  updateCanvasSize();
 
41
  console.error(`Unsupported scene type: ${data.scene.type}`);
42
  }
43
  handleMobileView();
44
+ await loadScene(data.scene.url);
45
  window.addEventListener("resize", () => {
46
  updateCanvasSize();
47
  });
 
87
  babylonViewer.setRenderMode(mode);
88
  }
89
 
90
+ async function loadScene(url: string) {
91
  overlay.style.display = "flex";
92
+ await viewer.loadScene(url, (progress) => {
93
  loadingBarFill.style.width = `${progress * 100}%`;
94
  });
95
  updateCanvasSize();
viewer/src/routes/viewer/[slug]/BabylonViewer.ts CHANGED
@@ -41,7 +41,7 @@ export class BabylonViewer implements IViewer {
41
  this.engine.resize();
42
  }
43
 
44
- async loadModel(url: string, loadingBarCallback?: (progress: number) => void) {
45
  // Load scene
46
  await BABYLON.SceneLoader.AppendAsync("", url, this.scene, (event) => {
47
  const progress = event.loaded / event.total;
 
41
  this.engine.resize();
42
  }
43
 
44
+ async loadScene(url: string, loadingBarCallback?: (progress: number) => void) {
45
  // Load scene
46
  await BABYLON.SceneLoader.AppendAsync("", url, this.scene, (event) => {
47
  const progress = event.loaded / event.total;
viewer/src/routes/viewer/[slug]/IViewer.ts CHANGED
@@ -1,6 +1,10 @@
1
  export interface IViewer {
2
- loadModel(url: string, loadingBarCallback?: (progress: number) => void): Promise<void>;
3
  dispose(): void;
4
  capture(): Promise<string | null>;
5
  getStats(): { name: string, value: any }[];
 
 
 
 
6
  }
 
1
  export interface IViewer {
2
+ loadScene(url: string, loadingBarCallback?: (progress: number) => void): Promise<void>;
3
  dispose(): void;
4
  capture(): Promise<string | null>;
5
  getStats(): { name: string, value: any }[];
6
+ }
7
+
8
+ export interface ISplatRenderer {
9
+ init(): void;
10
  }
viewer/src/routes/viewer/[slug]/SplatViewer.ts CHANGED
@@ -1,4 +1,5 @@
1
  import type { IViewer } from "./IViewer";
 
2
 
3
  class OrbitCamera {
4
  position: number[];
@@ -789,7 +790,7 @@ export class SplatViewer implements IViewer {
789
  return gl as WebGLRenderingContext;
790
  }
791
 
792
- async loadModel(url: string, loadingBarCallback?: (progress: number) => void) {
793
  const req = await fetch(url, {
794
  mode: "cors",
795
  credentials: "omit",
 
1
  import type { IViewer } from "./IViewer";
2
+ import * as SPLAT from "$lib/splat.js";
3
 
4
  class OrbitCamera {
5
  position: number[];
 
790
  return gl as WebGLRenderingContext;
791
  }
792
 
793
+ async loadScene(url: string, loadingBarCallback?: (progress: number) => void) {
794
  const req = await fetch(url, {
795
  mode: "cors",
796
  credentials: "omit",
viewer/tsconfig.json CHANGED
@@ -1,6 +1,7 @@
1
  {
2
  "extends": "./.svelte-kit/tsconfig.json",
3
  "compilerOptions": {
 
4
  "allowJs": true,
5
  "checkJs": true,
6
  "esModuleInterop": true,
 
1
  {
2
  "extends": "./.svelte-kit/tsconfig.json",
3
  "compilerOptions": {
4
+ "outDir": "build",
5
  "allowJs": true,
6
  "checkJs": true,
7
  "esModuleInterop": true,