Skip to main content

OCP FreeCAD CAM

Project description

image

Overview

oc-freecad-cam exposes FreeCAD's Path workbench in a fluent python API that takes OCP TopoDS_Shape objects and their wrappers from CadQuery and Build123d to enable generating parametric tool paths from the comfort of your keyboard.

image

⚠ NOTE ⚠

This project is fairly experimental at this stage. Expect bugs and always double-check the generated gcode for naughty surprises.

Usage

See documentation at https://ocp-freecad-cam.readthedocs.io/en/latest/

Installation

ocp-freecad-cam is available on pypi: https://pypi.org/project/ocp-freecad-cam/ ocp-freecad-cam does not attempt to install runtime dependencies since it's designed to run with any combination of these three:

Additionally, FreeCAD module needs to be available.

General guideline for hooking on FreeCAD

There are at least three options to approach this

  1. Using the FreeCAD Python interpreter
  2. Using system interpreter with the same major version as the FreeCAD Python interpreter
  3. Compiling FreeCAD to use the system interpreter

Number one is now the recommended way and will be documented below

Acquiring FreeCAD and supported versions

FreeCAD version FreeCAD Python version ocp-freecad-cam version ocp-freecad-cam status
weekly 3.11 - work in progress
1.1.1 3.11 v2.0.0 ✅ dev
1.0.1 - 1.0.2 3.11 v1.1.0 ❌ EOL
0.21 3.10 v0.9.4 ❌ EOL
  1. Official distributions https://www.freecad.org/downloads.php
  2. Official portable packages https://github.com/FreeCAD/FreeCAD/releases
    • includes weekly packages

Linux AppImage installation example using a venv

This is fairly straightforward. Download the AppImage, extract it, create a virtual environment from the included interpreter, include lib, activate it and install your preferred packages.

mkdir freecad
cd freecad
wget https://github.com/voneiden/FreeCAD-Bundle/releases/download/0.21.2/FreeCAD_0.21.2-2023-12-26-conda-Linux-x86_64-py311.AppImage
chmod +x FreeCAD_0.21.2-2023-12-26-conda-Linux-x86_64-py311.AppImage
./FreeCAD_0.21.2-2023-12-26-conda-Linux-x86_64-py311.AppImage --appimage-extract
./squashfs-root/usr/bin/python -m venv --system-site-packages fcvenv
echo "$PWD/squashfs-root/usr/lib" > fcvenv/lib/python3.11/site-packages/freecad.pth
source fcvenv/bin/activate
pip install cadquery build123d ocp-freecad-cam

Test that your interpreter works by running

python -c "import FreeCAD"

Windows 7z installation example

While I would suggest using WLS, if you want to stick to pure windows, the general idea is the same as above in the linux example with two exceptions.

  1. Instead of "$PWD/squashfs-root/usr/lib" > fcvenv/lib/python3.11/site-packages/freecad.pth use
"$($PWD)\..\src" | Out-File -FilePath "fcvenv\Lib\site-packages\ocp_freecad_cam.pth"

or create the pth file manually somehow. Just note that the venv file structure is a bit different on Windows.

  1. Instead of source you activate the venv with just
.\fcvenv\Scripts\activate

Dev dependencies

Dev dependencies are listed in requirements-dev.txt, generated from requirements-dev.in with pip-compile

Limitations

Pocket3D does not work, possibly related to https://github.com/FreeCAD/FreeCAD/issues/6815 - shouldn't be a big loss though, Surface3D can get the same things done IMO.

VCarve can produce unstable toolpaths, but that is probably a bug in the underlying openvoronoi library. Tweaking the job params may help.

Contributing

Contributions are welcome.

  • Missing params, fixes
  • Tests
  • Documentation

Development Setup (Optional)

You can optionally use pre-commit hooks to automatically check your code before committing:

pip install pre-commit
pre-commit install

This will run ruff formatting, linting, and commitlint checks on your changes.

PR's

Format and lint your code with ruff and ensure that tests pass. Preferably also include test coverage for new code.

ruff format src tests
ruff check src tests
pytest

Commit messages should follow Conventional Commits format.

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

ocp_freecad_cam-2.0.0.tar.gz (158.2 kB view details)

Uploaded Source

Built Distribution

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

ocp_freecad_cam-2.0.0-py3-none-any.whl (33.7 kB view details)

Uploaded Python 3

File details

Details for the file ocp_freecad_cam-2.0.0.tar.gz.

File metadata

  • Download URL: ocp_freecad_cam-2.0.0.tar.gz
  • Upload date:
  • Size: 158.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ocp_freecad_cam-2.0.0.tar.gz
Algorithm Hash digest
SHA256 465ee4112439d07d1f3d7a29b59c8b231e3ad0d79b5e53aeec87dd63ca947644
MD5 f85eae8457493efb0b99d9bca3516e9e
BLAKE2b-256 4d61e8a96f2abb6cc576af389fbbab84a2460ae5333f69f5473fa8369e0fc817

See more details on using hashes here.

File details

Details for the file ocp_freecad_cam-2.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ocp_freecad_cam-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f53aba8a03457e6c4daa352dcc7fef04e7e2f7fd61780b85bfda9c84d92e8c11
MD5 a02502d05d7c41ee76b8ec5dba9dbfeb
BLAKE2b-256 8f69dcc3c6111312510e13a699f83338c3917b6dc48af96e874328dfefbe65d0

See more details on using hashes here.

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