Skip to main content

Convert STEP files to GLB using OpenCASCADE

Project description

cascadio

A Python library which uses OpenCASCADE to convert STEP files to a GLB file which can quickly be loaded by trimesh and other libraries.

The primary effort here is build and packaging using the wonderful work done recently on scikit-build-core and cibuildwheel. The goal is to produce wheels that don't require users to build OpenCASCADE themselves.

This is not intended to be a full binding of OpenCASCADE like OCP or PythonOCC. Rather it is intended to be an easy minimal way to load boundary representation files into a triangulated scene in Python. There are a few options for loading STEP geometry in the open-source ecosystem: GMSH, FreeCAD, etc. However nearly all of them use OpenCASCADE under the hood as it is pretty much the only open-source BREP kernel.

Install

The primary goal of this project is building wheels so vanilla pip can be used:

pip install cascadio

Currently this is building for non-MUSL flavors of manylinux, Windows x64, and MacOS x64+ARM. You can check PyPi for current platforms.

Motivation

A lot of analysis can be done on triangulated surface meshes that doesn't need the analytical surfaces from a STEP or BREP file.

Contributing

Developed on Linux which should build wheels locally with docker:

# this doesn't cache the OCCT build unfortunately.
# It would be nice if it did! You could do it by building OCCT
# in the manylinux images and then passing the new tag to CIBW
CIBW_BUILD="cp312-manylinux_x86_64" cibuildwheel --platform linux

Or, if you want to develop that will only work in your local environment for development:

# just run the `before-all` from pyproject.toml which is approximatly:
cd upstream/OCCT
cmake -G Ninja -DCMAKE_BUILD_TYPE=Release \
      -DUSE_RAPIDJSON:BOOL="ON" \
      -D3RDPARTY_RAPIDJSON_INCLUDE_DIR="../rapidjson/include" .
ninja
mv lin64/gcc/lib .

Then pip install . will build and install locally. Make sure to point LD_LIBRARY_PATH=upstream/OCCT/lin64/gcc/lib or wherever you put the libraries.

Future Work

Pull requests welcome!

  • Add passable parameters for options included in the RWGLTF writer.
  • use in-memory data for input and output, i.e. stepReader.ReadStream() instead of a file name. Ideally the Python function signature would be:
    • convert_to_glb(data: bytes, file_type: str, **parameters) -> bytes
    • Currently using file names because it's easier.
  • Support IGES
    • Investigate using OpenCASCADE "Advanced Data Exchange" for Parasolid .x_b/.x_t and JT .jt support.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

cascadio-0.0.12-pp310-pypy310_pp73-win_amd64.whl (14.0 MB view hashes)

Uploaded PyPy Windows x86-64

cascadio-0.0.12-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-pp310-pypy310_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

cascadio-0.0.12-pp310-pypy310_pp73-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

cascadio-0.0.12-pp310-pypy310_pp73-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

cascadio-0.0.12-pp39-pypy39_pp73-win_amd64.whl (14.0 MB view hashes)

Uploaded PyPy Windows x86-64

cascadio-0.0.12-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-pp39-pypy39_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

cascadio-0.0.12-pp39-pypy39_pp73-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

cascadio-0.0.12-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

cascadio-0.0.12-pp38-pypy38_pp73-win_amd64.whl (14.0 MB view hashes)

Uploaded PyPy Windows x86-64

cascadio-0.0.12-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-pp38-pypy38_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

cascadio-0.0.12-pp38-pypy38_pp73-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded PyPy macOS 11.0+ ARM64

cascadio-0.0.12-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

cascadio-0.0.12-pp37-pypy37_pp73-win_amd64.whl (14.0 MB view hashes)

Uploaded PyPy Windows x86-64

cascadio-0.0.12-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-pp37-pypy37_pp73-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686

cascadio-0.0.12-pp37-pypy37_pp73-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

cascadio-0.0.12-cp312-cp312-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.12 Windows x86-64

cascadio-0.0.12-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp312-cp312-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp312-cp312-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded CPython 3.12 macOS 11.0+ ARM64

cascadio-0.0.12-cp312-cp312-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.12 macOS 10.9+ x86-64

cascadio-0.0.12-cp311-cp311-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.11 Windows x86-64

cascadio-0.0.12-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp311-cp311-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp311-cp311-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

cascadio-0.0.12-cp311-cp311-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

cascadio-0.0.12-cp310-cp310-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.10 Windows x86-64

cascadio-0.0.12-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp310-cp310-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp310-cp310-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

cascadio-0.0.12-cp310-cp310-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

cascadio-0.0.12-cp39-cp39-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

cascadio-0.0.12-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp39-cp39-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp39-cp39-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

cascadio-0.0.12-cp39-cp39-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

cascadio-0.0.12-cp38-cp38-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.8 Windows x86-64

cascadio-0.0.12-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp38-cp38-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp38-cp38-macosx_11_0_arm64.whl (20.1 MB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

cascadio-0.0.12-cp38-cp38-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.8 macOS 10.9+ x86-64

cascadio-0.0.12-cp37-cp37m-win_amd64.whl (14.0 MB view hashes)

Uploaded CPython 3.7m Windows x86-64

cascadio-0.0.12-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (26.1 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

cascadio-0.0.12-cp37-cp37m-manylinux_2_17_i686.manylinux2014_i686.whl (26.8 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ i686

cascadio-0.0.12-cp37-cp37m-macosx_10_9_x86_64.whl (23.3 MB view hashes)

Uploaded CPython 3.7m macOS 10.9+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page