BoxesPy pour instance Profouzors
Go to file
Florian Festi a96a78f439 cc(): Add angle parameter
to allow placing the callbacks truly everywhere
2023-02-15 21:47:53 +01:00
.github Add more files to typing test 2023-01-23 16:32:26 +01:00
boxes cc(): Add angle parameter 2023-02-15 21:47:53 +01:00
documentation Use `format()` 2023-01-13 16:18:44 +01:00
examples Fix misspelled variables (#484) 2023-01-02 16:23:24 +01:00
inkex Build and ship inkscape inx files 2017-02-25 20:01:03 +01:00
locale Add compiled message catalogue in German 2023-01-27 22:38:41 +01:00
po german translation compiles now 2023-01-27 14:27:00 +01:00
scripts boxes_proxy (Inkscape): Fix issue with --id cli arguments 2023-02-10 22:06:32 +01:00
static Create a GridfinityTrayLayout object. 2023-02-13 21:10:35 +01:00
.gitattributes Create .gitattributes 2022-09-06 18:52:06 +02:00
.gitignore ignore vscode and venv 2020-05-18 22:30:28 +02:00
CODE_OF_CONDUCT.md Code of Conduct 2018-09-24 13:31:36 +02:00
CONTRIBUTING.rst Document where all to add new dependencies 2022-07-17 14:11:25 +02:00
LICENSE.txt Licence the code under GPLv3 2014-03-16 18:26:12 +01:00
MANIFEST.in Add boxes_proxy.py from the MightyScape project 2023-01-23 23:24:56 +01:00
README.rst More tables 2021-05-23 19:08:38 +02:00
requirements.txt Fix missing version in `requirements.txt` 2022-12-27 21:42:48 +01:00
setup.py Install both boxes and boxes_proxy into the Inkscape directory 2023-02-10 20:34:25 +01:00

README.rst

About Boxes.py
==============

+----------------------------------------------+----------------------------------------------+----------------------------------------------+----------------------------------------------+----------------------------------------------+
| .. image:: static/samples/NotesHolder.jpg    | .. image:: static/samples/OttoBody.jpg       | .. image:: static/samples/PaintStorage.jpg   | .. image:: static/samples/ShutterBox.jpg     | .. image:: static/samples/TwoPiece.jpg       |
+----------------------------------------------+----------------------------------------------+----------------------------------------------+----------------------------------------------+----------------------------------------------+

* Boxes.py is an online box generator

  * https://www.festi.info/boxes.py/index.html

* Boxes.py is an Inkscape plug-in
* Boxes.py is library to write your own
* Boxes.py is free software licensed under GPL v3+
* Boxes.py is written in Python and runs with Python 3

Boxes.py comes with a growing set of ready-to-use, fully parametrized
generators. See https://florianfesti.github.io/boxes/html/generators.html for the full list.

+----------------------------------------------+----------------------------------------------+----------------------------------------------+
| .. image:: static/samples/AngledBox.jpg      | .. image:: static/samples/FlexBox2.jpg       | .. image:: static/samples/HingeBox.jpg       |
+----------------------------------------------+----------------------------------------------+----------------------------------------------+

Features
--------

Boxes.py generates SVG images that can be viewed directly in a web browser but also
postscript and - with pstoedit as external helper - other vector formats
including dxf, plt (aka hpgl) and gcode.

Of course the library and the generators allow selecting the "thickness"
of the material used and automatically adjusts lengths and width of
joining fingers and other elements.

The "burn" parameter compensates for the material removed by the laser. This
allows fine tuning the gaps between joins up to the point where plywood
can be press fitted even without any glue.

Finger Joints are the work horse of the library. They allow 90° edges
and T connections. Their size is scaled up with the material
"thickness" to maintain the same appearance. The library also allows
putting holes and slots for screws (bed bolts) into finger joints,
although this is currently not supported for the included generators.

Dovetail joints can be used to join pieces in the same plane.

Flex cuts allows bending and stretching the material in one direction. This
is used for rounded edges and living hinges.

+----------------------------------------------+----------------------------------------------+----------------------------------------------+
|   .. image:: static/samples/TypeTray.jpg     |     .. image:: static/samples/BinTray.jpg    | .. image:: static/samples/DisplayShelf.jpg   |
+----------------------------------------------+----------------------------------------------+----------------------------------------------+
| .. image:: static/samples/AgricolaInsert.jpg | .. image:: static/samples/HeartBox.jpg       | .. image:: static/samples/Atreus21.jpg       |
+----------------------------------------------+----------------------------------------------+----------------------------------------------+

Documentation
-------------

Boxes.py comes with Sphinx based documentation for usage, installation
and development.

The rendered version can be viewed at <https://florianfesti.github.io/boxes/html/index.html>.