Skip to main content

build123d development with live preview and interactive parameters.

Project description

bdbox

build123d development with live preview and interactive parameters

License PyPI Python CI Coverage Renovate GitHub stars

Screenshot

See the documentation site for full project details!

Why?

I discovered build123d after modeling with OpenSCAD. build123d has some great advantages over OpenSCAD:

Comparatively, build123d's development experience was lacking. OpenSCAD previews a model on save or hotkey, makes exporting a model render simple, and even provides a GUI for setting toplevel variables! I started with some self-made tooling to work around these drawbacks, but having to remember how to use and maintain it resulted in me working on models less.

I built bdbox to be the missing tool I wanted: Let models just define their geometry plus optional parameters, and let bdbox handle everything else!

See more background info in the documentation!

Installation

Install user-wide with uv or pipx for use across all projects:

uv tool install bdbox
pipx install bdbox

Install in any environment where pip is available:

pip install bdbox

Installation in projects

Install in a project, such as with uv or poetry:

uv add bdbox
poetry add bdbox

bdbox detects and automatically uses virtual environments also containing bdbox.

This enables running via bdbox model.py instead of uv run bdbox model.py, for example.

Works with any build123d model

Use bdbox with any existing build123d script:

# mymodel.py
from build123d import Box

result = Box(10, 10, 10)

Export geometry files:

bdbox mymodel.py export           # Export STEP files to current directory
bdbox mymodel.py export output/   # Export STEP files to output/
bdbox mymodel.py export -f stl    # Export STL files to current directory

View your model using the web UI, which includes OCP CAD Viewer and an interactive parameters panel:

bdbox mymodel.py view

Module paths work too:

bdbox mypackage.mymodule view
bdbox mypackage.mymodule export

See more about actions in the documentation!

Add parameters

Declare typed parameters with defaults and constraints:

from bdbox import Float, Int, Params, Preset, show
from build123d import Box

class P(Params):
    width = Float(10.0, min=5, max=100)
    length = Float(20.0, min=5, max=100)
    thickness = Int(2, min=1, max=10)
    presets = (
        Preset("small", width=5.0, length=8.0),
        Preset("large", width=80.0, length=40.0, thickness=5),
    )

result = Box(P.width, P.length, P.thickness)
show(result)

Or inherit from Model for reusable, importable models:

from bdbox import Float, Int, Model, Preset
from build123d import Box

class MyModel(Model):
    width = Float(10.0, min=5, max=100)
    length = Float(20.0, min=5, max=100)
    thickness = Int(2, min=1, max=10)
    presets = (
        Preset("small", width=5.0, length=8.0),
        Preset("large", width=80.0, length=40.0, thickness=5),
    )

    def build(self):
        return Box(self.width, self.length, self.thickness)

Parameters become CLI flags automatically:

python mymodel.py                 # Run with default values
python mymodel.py view            # View with live reload and parameter panel
python mymodel.py --width 50      # Override a field value
python mymodel.py --preset large  # Apply a named preset
python mymodel.py --help          # Usage info with all parameters

Export geometry files using the built-in export action:

python mymodel.py export          # Export STEP files to current directory
python mymodel.py export -f stl   # Export STL files to current directory

See more about parameters in the documentation!

Project template

This project is generated and maintained with copier-python.

Project details


Download files

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

Source Distribution

bdbox-0.14.1.tar.gz (306.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bdbox-0.14.1-py3-none-any.whl (256.4 kB view details)

Uploaded Python 3

File details

Details for the file bdbox-0.14.1.tar.gz.

File metadata

  • Download URL: bdbox-0.14.1.tar.gz
  • Upload date:
  • Size: 306.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bdbox-0.14.1.tar.gz
Algorithm Hash digest
SHA256 5e9707fe9800d40dbbf288c7cb00b7da3d474f21ab051ab91f51a59ff7efb6b7
MD5 774262cb83ecd85890e1ad8755a139a2
BLAKE2b-256 8b67c0f55f9f9f1bf933a63ce32f54d194d70fe42da3792768881d4655eb7c67

See more details on using hashes here.

Provenance

The following attestation bundles were made for bdbox-0.14.1.tar.gz:

Publisher: release.yaml on smkent/bdbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bdbox-0.14.1-py3-none-any.whl.

File metadata

  • Download URL: bdbox-0.14.1-py3-none-any.whl
  • Upload date:
  • Size: 256.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for bdbox-0.14.1-py3-none-any.whl
Algorithm Hash digest
SHA256 081b6a9c5243e95a10c2dd7e97e4d50c3f6aab958c1e2c2cf59dd2f3e87f7db6
MD5 48412d86c0cfa1f5589177bb1843f291
BLAKE2b-256 bf706a1d7a9643a4eac8e28ece63b1549f9ac326bab639d94245a17ad32a56f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for bdbox-0.14.1-py3-none-any.whl:

Publisher: release.yaml on smkent/bdbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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