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

Boolean #17

Open
rustythirsty opened this issue Aug 24, 2021 · 5 comments
Open

Boolean #17

rustythirsty opened this issue Aug 24, 2021 · 5 comments

Comments

@rustythirsty
Copy link

Any hint as to when we can expect Boolean operations to be made available in the package. I would like to know if it is possible to generate a mesh from a only a set of 3D points.

@ytanimura
Copy link
Contributor

ytanimura commented Aug 25, 2021

We will be announcing more details about the progress of the Boolean operations in this week. There are some performance issues, but so far the implementation is making steady progress.
There are no concrete plans for generating a mesh from point cloud at this time. We plan to develop the API for web applications once STEP I/O and set operations are in place.

@ytanimura
Copy link
Contributor

ytanimura commented Aug 30, 2021

Current Status:
Now we are implementing Boolean operations for solids in the case where all interfering faces are transversely intersected. We already implemented:

  • extraction of intersection polyline curves between two polygon meshes,
  • the struct IntersectionCurve for describing intersection curve between two surfaces, (Each intersection curve is leaded by a polyline curve extracted the above function.) and
  • creation of the loop wires (topological element) by collecting existing edges and new edges which consist the above intersection curves.

The picture below shows the polygons of the common part of the two parabolas, achieved by ad-hoc choosing the extracted loop wires.
intersection

Future tasks:

  • selection of the loop wires included in an AND , OR or MINUS shape of two solids
  • stabilization and acceleration of implementation. Now, it is unstable so that the unit tests fail 30% of the time and the constructed polygon have some holes. Moreover, they take very long time.
  • Implementation for the case where some faces are in close contact with each other

@ytanimura
Copy link
Contributor

ytanimura commented Oct 2, 2021

The basic implementation has been completed, and the operation has become reasonably stable, although not yet at the enterprise level. ruststep has been released, so the set operations will be documented, and work on STEP I/O will be resumed first.

@MattFerraro
Copy link

You mention:

Implementation for the case where some faces are in close contact with each other

My current project, a CAD program, is unable to proceed until this feature is implemented. Is there any way I can help to get it done?

@qff233
Copy link

qff233 commented Jun 14, 2024

How to boolean operate for mesh? truck-meshalgo has not this operation. TAT

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

4 participants