Transform a KiCad footprint into a OpenPnP package
Project description
kicad-to-openpnp
Note: this is heavily WIP, and may introduce ghosts into your machine.
kicad-to-openpnp helps you convert your KiCad project into a set of full-fledged
OpenPnP packages and parts, including pin definitions, as well as dimensions
taken from 3D models of the footprints.
It does not replace OpenPnP's KiCad position file import process, it enhances it.
Installation
Using pipx (installation instructions) is recommended:
pipx install --system-site-packages kicad-to-openpnp
(--system-site-packages is required due to how KiCad distributes its Python bindings.)
Alternatively, if the above doesn't work for you (PyPi doesn't allow GitHub dependencies, so CadQuery version there is quite outdated), you can try installing directly from GitHub:
pipx install --system-site-packages git+https://github.com/mmalecki/kicad-to-openpnp.git
Usage
Assuming your board file is called board.kicad_pcb, and you're in your .openpnp2 directory,
you can run the following two commands to generate your new packages.xml and parts.xml:
kicad-board-to-openpnp-packages --board board.kicad_pcb --join packages.xml > packages.new.xml
kicad-board-to-openpnp-parts --board board.kicad_pcb --join parts.xml > parts.new.xml
The --join option will preserve your previous packages and parts and add them without modification
to your new files. An option to allow for updating old entities based on new findings is in the works.
Therefore, if you just want to look at what the tool would output for your current board only:
kicad-board-to-openpnp-packages --board board.kicad_pcb
kicad-board-to-openpnp-parts --board board.kicad_pcb
If the new package and part files look correct, and your OpenPnP application is closed, you can now move them in place of the old files (making backups beforehand, if you'd like):
mv packages.new.xml packages.xml
mv parts.new.xml parts.xml
Why and how?
I found inputting part heights, sizes and pads into OpenPnP to be a rather large time commitment, so I begun looking for ways to automate that.
I quickly realized that KiCad footprints don't actually contain part body size information.
However, manufacturers now happily publish STEP files of their products, and
I'm yet to find a model which would be so wildly inaccurate that it would be a problem for
PnP process (0.1 ~ 0.2 mm variations are typical, though).
I then used the KiCad Python bindings to read in the pads and 3D models from the footprints (accounting for rotation), and CadQuery to load the models and measure their bounding boxes. This turned out to work. I was able to run several PnP jobs using the data generated by these here scripts.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kicad_to_openpnp-0.1.4.tar.gz.
File metadata
- Download URL: kicad_to_openpnp-0.1.4.tar.gz
- Upload date:
- Size: 6.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.0.1 CPython/3.12.10 Linux/6.16.12+deb14-amd64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ea3ca8712528a831ec796d9c3d3fc8bdcbae721e6e46d77da2b7aa843e927e96
|
|
| MD5 |
409a820f2e1ac37ae3d05714ebed0e42
|
|
| BLAKE2b-256 |
8f2e71e416d48a015c5bafb46d6f4fc65b655518c0980c16822b1d934c771cb2
|
File details
Details for the file kicad_to_openpnp-0.1.4-py3-none-any.whl.
File metadata
- Download URL: kicad_to_openpnp-0.1.4-py3-none-any.whl
- Upload date:
- Size: 10.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.0.1 CPython/3.12.10 Linux/6.16.12+deb14-amd64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
14e045bc46a2a0de3dc906fff4a30116f63371a06ed66141ea1d8ada08c3dd4e
|
|
| MD5 |
d33f10015bb334728a5a9df925353599
|
|
| BLAKE2b-256 |
98a9516e581b619ab87d409372b3d2eaa2dc347bc759acd6ffdd5b38fba970ab
|