Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Editing splat created from lumalabs app #9

Open
ericrius1 opened this issue Dec 18, 2023 · 5 comments
Open

Editing splat created from lumalabs app #9

ericrius1 opened this issue Dec 18, 2023 · 5 comments

Comments

@ericrius1
Copy link

I've been experimenting with integrating splats from the lumalabs app into a threejs experience, and it's amazing! I found a splat editor online and would love to use this to edit my splats. It looks like I need to upload a file, and just provide a link to the capture as in the webgl library. I was wondering if there's a way to get the file from the luma app downloaded so I can edit it before importing it to my threejs app?

Thanks!

@Xurxowski
Copy link

I'm going to try to export an .ply file from Luma.ai and import it into Unreal Engine, saw some nice results.

@koktavy
Copy link

koktavy commented Jan 11, 2024

@ericrius1 you've probably figured this out by now, but for anyone else wondering:
Go to https://lumalabs.ai/dashboard/captures and hover over a capture, then click the download arrow. Download the Gaussian Splat under the Unreal Engine section, then unzip the PLY. Don't be fooled, this is a special PLY for the splat and not just a point cloud.

You can edit the splat in various programs from there, though I believe you can only use the semantic mask to "edit" the splats received from the Luma three.js importer:
splats.semanticsMask = LumaSplatsSemantics.FOREGROUND;

@koktavy
Copy link

koktavy commented Jan 25, 2024

@haxiomic @lovelovetrb Is there any way aside from a Luma link to load in other PLY or SPLAT files?

@KZeni
Copy link

KZeni commented Feb 27, 2024

While splats.semanticsMask = LumaSplatsSemantics.FOREGROUND; (per https://github.com/lumalabs/luma-web-examples?tab=readme-ov-file#background-removal) is great, I wish there was a quick way to effectively apply what that masking does directly to the splat itself so it's removed from the splat entirely (as my use case is just an object scan anyway.)

As it is now, it seems like it's still downloading all of the additional background data/assets/etc. while then just hiding it from the render output when the masking is set (causing the splat to take much longer to show than it otherwise would as it still downloads & processes all of that data that's then just not being output.)

Also, the splat still technically has that data available if anyone were to check out the splat data without that masking parameter set when one might want to not have that additional scanned background be accessible to anyone. Hiding via the masking method works okay, but actually removing the background from the splat itself would be best.

Is there anything out there that would make this possible?

Edit: I imported the Gaussian Splat from Luma into Spline.Design (curious if there are other, potentially better, tools out there for this) and then used the "Crop Areas" tool it offers for splats where it seemingly turned my ~260MB splat export from Luma into something that's ~2MB and is much friendlier to be embedded within a webpage (also allowing for a viewer to be more readily customized). It would be great if Luma enriched its offerings with some of these aspects, but it's still my go-to for actually generating the splat to then use as needed.

@jakerator
Copy link

Any way to load externaly edited Splat files?
E.g. I crop unnecessary points in https://playcanvas.com/supersplat/editor and want to import edited splat back to Lumalabs Js library?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants