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

feature: Add potree 2.0 parser #2137

Merged
merged 5 commits into from
Jun 24, 2024
Merged

Conversation

ketourneau
Copy link
Contributor

@ketourneau ketourneau commented Jul 11, 2023

Description

We add Potree2Source, Potree2Layer, Potree2Node and example (potree2_25d_map.html) for loading potree 2.0 file format in iTowns.
Pull request for sample data must be accepted before (iTowns/iTowns2-sample-data#15).

Motivation and Context

We need to load potree 2.0 file format in iTowns to meet our project requirements.

Do I need to duplicate the potree tests to run them on potree2 ?

@Desplandis
Copy link
Contributor

Hi @ketourneau and thanks for your contribution!
Is this PR still in draft or ready to review? If ready, I'll start reviewing it by the end of the week.

Do I need to duplicate the potree tests to run them on potree2 ?

I advise to add some tests (duplicates of potree 1.x parser tests and/or your own).

@ketourneau
Copy link
Contributor Author

@Desplandis thanks for your reply, I will add potree 2 tests.

Actually we got some trouble to use use itowns package with potree2 loader (web worker) in a vite project.
I try to do worker import like here unsuccessfuly.
potree-core package work's fine in vite project (it use same web worker for potree 2).

If we change in itowns .babelrc
"presets": [["@babel/preset-env", { "modules": false }]],
Worker works fine in vite project but test failed in itowns.

So if someone can help to fix the problem (I think it's a babel config problem) ?
You can find vite sample project here

@Makaronelle
Copy link

@Desplandis thanks for your reply, I will add potree 2 tests.

Actually we got some trouble to use use itowns package with potree2 loader (web worker) in a vite project. I try to do worker import like here unsuccessfuly. potree-core package work's fine in vite project (it use same web worker for potree 2).

If we change in itowns .babelrc "presets": [["@babel/preset-env", { "modules": false }]], Worker works fine in vite project but test failed in itowns.

So if someone can help to fix the problem (I think it's a babel config problem) ? You can find vite sample project here

@Desplandis FYI those very same web workers cannot work on our end without some kind of tinkering with Babel, which breaks all iTowns' tests. At least, that's what we got so far since our resources around web workers are currently busy and we cannot allocate any of their time.

What we do know: since we call those web workers from Potree2BinParser, they do get recognized by Webpack and Babel, they do get outputted, but keep their URL as it is. Since they are located in the "Worker" subfolder, they get called as "Worker/worker_name". Once we use them in our project, these files can't be resolved unless we add aliases left and right.

We could add more logic to this worker loading process (something in line with what pdf-js is doing) but we still wanted to ask any of this project's contributor if there will be some plan on the way for either outputing or if it should be done in a certain way.

Our endgoal would be to put iTowns' library as it is, without cloning or adding on top of it any building logic.

@Desplandis
Copy link
Contributor

Desplandis commented Jul 24, 2023

@ketourneau @Makaronelle If I understand your issue correctly, it seems the problem is that rollup does not bundle/alias the two workers in your vite project ?

I am not familiar with vite but looking at the web workers documentation and the output of babel on our side (after a npm run transpile), it seems that babel does not transform the absolute path to the worker to a relative path. rollup expecting a relative path, it does not bundle/alias your workers.

After setting a relative path to the workers file, it seems to fix this issue:

✓ 624 modules transformed.
dist/index.html                                            0.52 kB │ gzip:   0.31 kB
dist/assets/potree2-decoder.worker-ffeff9b8.js            10.37 kB
dist/assets/potree2-brotli-decoder.worker-7fc1bb98.js    162.99 kB
dist/assets/index-323ff7d8.css                             0.07 kB │ gzip:   0.08 kB
dist/assets/index-3d1b9e4c.js                          2,241.98 kB │ gzip: 614.49 kB

@ketourneau
Copy link
Contributor Author

ketourneau commented Jul 24, 2023

@Desplandis Thanks for your reply.

I try with relative path but we got the same error in vite (maybe we could resolve it later).
For now, we have an error when we try to execute test on Potree2BinParser.
I push potree2BinParser test (Work In Progress) :

npm run base-test-unit test/unit/potree2BinParser.js
Potree2BinParser.js:27
new URL('../Workers/potree2-brotli-decoder.worker.js', import.meta.url)
SyntaxError: Cannot use 'import.meta' outside a module

I try to add babel-plugin-transform-import-meta but I got this error when I try to execute potree2BinParser test :

Potree2BinParser
ReferenceError: Worker is not defined

Copy link
Contributor

@Desplandis Desplandis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This a nice start. =)
I left some comments that should be addressed before getting this merged.
I did not however reviewed the two workers because eslint generates two many errors, I'll do it in the following review.

.gitignore Outdated Show resolved Hide resolved
docs/config.json Show resolved Hide resolved
examples/potree2_25d_map.html Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Source/Potree2Source.js Outdated Show resolved Hide resolved
src/Utils/Potree2Utils.js Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
@Desplandis
Copy link
Contributor

@ketourneau I also see that you have added brotli decompression library as as local dependency?
I would prefer that such dependency be resolved by npm or added at runtime à la three.js GLTFLoader.

Copy link
Contributor Author

@ketourneau ketourneau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I modified code according to your comments.
I still have 2-3 remarks to deal with and I will fix and add tests on potree2.

examples/potree2_25d_map.html Outdated Show resolved Hide resolved
.gitignore Outdated Show resolved Hide resolved
docs/config.json Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Core/PointAttributes.js Outdated Show resolved Hide resolved
src/Utils/Potree2Utils.js Outdated Show resolved Hide resolved
src/Utils/Potree2Utils.js Outdated Show resolved Hide resolved
src/Workers/potree2-decoder.worker.js Outdated Show resolved Hide resolved
src/Layer/Potree2Layer.js Show resolved Hide resolved
src/Workers/potree2-decoder.worker.js Outdated Show resolved Hide resolved
Copy link
Contributor Author

@ketourneau ketourneau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I add more description about metadata.json and improve Promise in Potree2BinParser.

I'm still working on tests.

src/Parser/Potree2BinParser.js Outdated Show resolved Hide resolved
src/Source/Potree2Source.js Show resolved Hide resolved
@ketourneau
Copy link
Contributor Author

@Desplandis I've completed the tests. Is everything good except the bigint issue ?

@gauthier-th
Copy link

Hi, any update on this?

@Desplandis
Copy link
Contributor

@gauthier-th Following #2195, I expect this PR to be merged upstream by the end of February.
@ketourneau @Makaronelle Since this is open for quite some time, I will rebase your PR on the master branch as well as doing some adjustments work.
We decided to cut support of old browsers and distributing as ESM (see #2256), I will :

  • Remove the transpile BigInt to JSBI step
  • Use a common WorkerPool implementation that I intend to share with the COPC one.

@ketourneau ketourneau force-pushed the potree2 branch 3 times, most recently from 6cad6a7 to 163ce34 Compare May 3, 2024 09:14
Copy link
Contributor

@Desplandis Desplandis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, thanks for your PR. =)

@Desplandis Desplandis merged commit ee56ec7 into iTowns:master Jun 24, 2024
9 checks passed
@ketourneau ketourneau deleted the potree2 branch July 12, 2024 06:40
@Desplandis Desplandis mentioned this pull request Oct 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Development

Successfully merging this pull request may close these issues.

5 participants