Skip to content

Commit

Permalink
Optionally load and save sh coefficients (#22)
Browse files Browse the repository at this point in the history
* optionally load and save sh coefficients

* v0.10.1
  • Loading branch information
slimbuck authored Nov 9, 2023
1 parent e03876c commit 74b3c0f
Show file tree
Hide file tree
Showing 7 changed files with 58 additions and 7 deletions.
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "super-splat",
"version": "0.10.0",
"version": "0.10.1",
"author": "PlayCanvas<[email protected]>",
"homepage": "https://playcanvas.com",
"description": "All the splat things",
Expand Down
17 changes: 15 additions & 2 deletions src/asset-loader.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { Asset, AssetRegistry, StandardMaterial, TEXTURETYPE_RGBP } from 'playcanvas';
import { getDefaultPlyElements } from 'playcanvas-extras';
import { Model } from './model';
import { Splat } from './splat';
import { Env } from './env';
Expand All @@ -17,10 +18,18 @@ interface EnvLoadRequest {
filename?: string;
}

function* shDataElementsGen(max: number) {
let val = 0;
while (val < max) {
yield `f_rest_${val++}`;
}
};

// handles loading gltf container assets
class AssetLoader {
registry: AssetRegistry;
defaultAnisotropy: number;
loadSHData = false;

constructor(registry: AssetRegistry, defaultAnisotropy?: number) {
this.registry = registry;
Expand All @@ -35,6 +44,8 @@ class AssetLoader {
return new Promise<Model|Splat>((resolve, reject) => {
const gemMaterials = new Set<StandardMaterial>();

const isPly = loadRequest.filename?.endsWith('.ply');

const containerAsset = new Asset(
loadRequest.filename || loadRequest.url,
'container',
Expand All @@ -43,7 +54,9 @@ class AssetLoader {
filename: loadRequest.filename,
contents: loadRequest.contents
},
null,
isPly ? {
elements: this.loadSHData ? getDefaultPlyElements().concat([...shDataElementsGen(45)]) : null
} : null,
{
image: {
postprocess: (gltfImage: any, textureAsset: Asset) => {
Expand All @@ -61,7 +74,7 @@ class AssetLoader {
} as any
);
containerAsset.on('load', () => {
if (loadRequest.filename.endsWith('.ply')) {
if (isPly) {
resolve(new Splat(containerAsset));
} else {
resolve(new Model(containerAsset, gemMaterials));
Expand Down
6 changes: 5 additions & 1 deletion src/editor-ops.ts
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ const convertPly = (splatData: SplatData, modelMat: Mat4) => {
numSplats += opacity[i] !== deletedOpacity ? 1 : 0;
}

const props = ['x', 'y', 'z', 'f_dc_0', 'f_dc_1', 'f_dc_2', 'opacity', 'scale_0', 'scale_1', 'scale_2', 'rot_0', 'rot_1', 'rot_2', 'rot_3'];
const props = splatData.vertexElement.properties.filter(p => p.storage).map(p => p.name);
const header = (new TextEncoder()).encode(`ply\nformat binary_little_endian 1.0\nelement vertex ${numSplats}\n` + props.map(p => `property float ${p}`).join('\n') + `\nend_header\n`);
const result = new Uint8Array(header.byteLength + numSplats * props.length * 4);

Expand Down Expand Up @@ -719,6 +719,10 @@ const registerEvents = (scene: Scene, editorUI: EditorUI) => {
updateColorData();
});

events.on('shData', (value: boolean) => {
scene.assetLoader.loadSHData = value;
});

const removeExtension = (filename: string) => {
return filename.substring(0, filename.length - path.getExtension(filename).length);
};
Expand Down
4 changes: 4 additions & 0 deletions src/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,10 @@ body {
flex-grow: 1;
}

.control-element.pcui-boolean-input {
margin-top: 10px;
}

.active {
color: white;
background-color: #f60 !important;
Expand Down
30 changes: 30 additions & 0 deletions src/ui/control-panel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -621,6 +621,31 @@ class ControlPanel extends Container {
scenePanel.append(position);
scenePanel.append(rotation);

// import
const importPanel = new Panel({
class: 'control-panel',
headerText: 'Import'
});

const shData = new Container({
class: 'control-parent'
});

const shDataLabel = new Label({
class: 'control-label',
text: 'SH data'
});

const shDataToggle = new BooleanInput({
class: 'control-element',
value: false
});

shData.append(shDataLabel);
shData.append(shDataToggle);

importPanel.append(shData);

// export
const exportPanel = new Panel({
class: 'control-panel',
Expand Down Expand Up @@ -674,6 +699,7 @@ class ControlPanel extends Container {
this.append(selectionPanel);
this.append(modifyPanel);
this.append(scenePanel);
this.append(importPanel);
this.append(exportPanel);
this.append(keyboardPanel);

Expand Down Expand Up @@ -828,6 +854,10 @@ class ControlPanel extends Container {
this.events.fire('reset');
});

shDataToggle.on('change', (enabled: boolean) => {
this.events.fire('shData', enabled);
});

exportPlyButton.on('click', () => {
this.events.fire('export', 'ply');
});
Expand Down

0 comments on commit 74b3c0f

Please sign in to comment.