Close
0%
0%

Boxes.py

Cut out boxes and other stuff with a laser cutter

Similar projects worth following
A small python library for generating SVG drawings used for cutting out boxes or other structures using a laser cutter. It also offers a command line and web interface allowing control over many parameters.

It also comes with a growing set of ready-to-use, fully parametrized generators:

* Various simple boxes
* Flex boxes with rounded corners and living hinges
* Boxes with proper hinges
* Type trays with and without walls and floors
* Bin trays
* Display shelf
* Book cover with flex spine
* Magazine file
* Traffic lights
* Honey comb wine rack

Parts to be used in other projects:

* Pulleys
* Gears
* Knobs

And a few one trick ponies:

* An arcade cabinet
* A small robot
* A drill stand
* A rotary attachment for a laser cutter
* A castle tower
* A cutlery stand


It also offers an API to easily draw your own parts. See link to the documentation below. It is licensed under GPL v3+.

You can get the sources directly from github. You can also find some more examples there.

Usage
There are multiple ways to use the available generators:

  • Use them online
  • Use them as Inkscape plugins
  • Run scripts/boxesserver which provides an web interface on port 8000
  • Execute the scripts/boxes tool and pass the name of the generator together with the measurements on the command line
  • scripts/boxes --list gives you the list of available generators
  • Run scripts/boxesserver as an WSGI script in your web server.

You can also create your own generators using boxes/generators/_template.py or any of the generators in boxes/generators as a starting point.

Features

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 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 available generators.

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

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

  • Finally!

    Florian Festi17 hours ago 0 comments

    OK, OK. I know you are actually all waiting for cool new boxes and other generators - or at least new features for the existing ones. But there is even more infrastructure work that need to be done. I do have some new generators in some - not quite finished - branches. So there will be new stuff to cut out. I promise!

    One long standing issue with the project has been the logo. The web site used a gray cube that was added as a place holder in the web UI mock up and just didn't get replaced. I wanted the logo to also be a box generator  and I have a branch that does that. It applies some transformation matrices to render a box with finger joints in an isometric projection. But the result was still closer to a technical drawing that a proper logo. After some encouragement in the GitHub tickets I finally ditched the idea and sketched something in Inkscape. It's not that great but it is a box that's green like a Python (mascot) and has a laser welding it together. There is probably some things that can be improved. The contrast between the greens and the light gray used as a background in many web browsers could be better and and the laser could be nicer, brighter ans shinier. But so far I am happy with what I have achieved - given my artistic talent. If you have some design skills and some improvements feel free to open an pull request.

    PS: The logo is also - finally - used as a favicon. So I can now find all those still open boxes browser tabs.

  • Update for the Web Instance

    Florian Festi09/17/2018 at 15:50 0 comments

    Some may have noted that I recently added a Dockerfile to the repository. Playing around a bit more I moved the public web instance into a more modern docker container. This is not in its final form. Several things still need to be done right. Nevertheless it already solves two long standing and annoying issues:

    For the later I still need to fix the docs with still state those formats or only available for local installations.

    Overall the docker container is considered being in beta test. So if you encounter any issues, please report here or in a GH ticket. But in general I expect things to work.

  • More Documentation

    Florian Festi09/14/2018 at 13:30 0 comments

    Updating the API docs has been on the ToDo list for one and a half year. Turns out being on vacation far away from a laser cutter is helping. Not only did I update some doc strings - which are the basis for the Sphinx generated API docs - but I wrote some new documents:

    And I added an Introduction to the Edge classes. The rest of the page probably still needs some work as some Edge types are still missing. The Settings classes and their role in creating the HTML and Inkscape user interfaces and in creating the Edge instances probably also deserves a bit more text.

    What also helped getting it done - probably not getting it done well - was a good amount of medication. It at least prevented me from doing something more complicated - and may be more rewarding - instead. I hope it does not show too much. So if something looks weird or doesn't make sense please open a ticket on GitHub or leave a comment below.

  • Boxes.py goes to Jupyter

    Florian Festi09/10/2018 at 14:19 0 comments

    No, Boxes.py didn't make it to space - yet. But @speendo used a Jupyter notebook to develop a housing for his switch. After a bit of back and forth we now have an example notebook that allows to play around interactively in your web browser - sort of. You still need Boxes.py running on your system - or where ever your Jupyter instance is running. If you do not have Boxes.py installed in your Python path you can uncomment and adjust the sys.path line in the first code cell.

    The example code - a simple, single shelve to screw to the wall - did not yet make it into the regular code. So it is only available in the notebook for now.

  • Reuse your previous Box settings

    Florian Festi08/14/2018 at 10:40 0 comments

    When designing the web interface I was deliberately using URL parameters so the link to the rendered SVG can be used to generate it again and to adjust the values. But so far there was no way to get those values back into the input form. Yes, you *can* edit the URL directly but this got much less convenient when the settings for the edges got added and the URL looks like a database.

    bwente rightly complained about this in #66. So I finally fixed it. Now you can just remove the &render=1  at the end of the URL or turn the 1 into a 0 to open the input form filled with the previously used values.

    The actual issue in #66 - adding the URL as a comment in the SVG file - is still unresolved. So far I could not yet bring myself to re-open and rework the SVG file. But there are several issues open that would require this. So one day eventually...

    In the mean time Rotzbua created a greasemonkey script that adds the comment on the client side.

  • 3rd Party Instructions

    Florian Festi04/26/2018 at 19:51 0 comments

    I accidentally stumbled across an Instructable for laser cutting boxes and though to my self: They look nice but very much like the ones my generator does. Did someone just steal my ideas?

    After scrolling down I realized that the instructable is actually about Boxes.py - which explains the similarity of the boxes quite nicely. It is also quite nicely done.

    Thanks to Andrea Biffi for all the work!

  • Trouble with pstoedit

    Florian Festi04/15/2018 at 11:47 0 comments

    Although it is not available on the public online generator Boxes.py supports generating formats like DXF directly using the pstoedit utility. Unfortunately this broke recently due to ghostscript dropping the -dDELAYBIND parameter in 9.22.

    Luckily ghostscript upstream decided to add it back in 9.23. So if you run into trouble consider updating or downgrading your ghostscript installation. 

    Pstoedit also indicated that the next version may work without -dDELAYBIND. So as soon as 3.71 comes out the issue may be off the table for ever.

    Fedora Bug report

  • Boxes.py on Windows?

    Florian Festi12/20/2017 at 09:47 5 comments

    Hi!

    I am getting questions about Boxes.py on Windows I can't really answer - both as private message or as GitHub tickets. I personally have not used Windows for anything else than occasionally using a Desktop program (like the control software for our laser cutter) in over a decade. So I really have no clue.

    Has anyone been able to run Boxes.py on their Windows machine and is able to share the steps needed preferably including links to the libraries and tools required. Are there any changes that would make installing it easier?

    Has any one been able to make the Inkscape plugins work on Windows?

    Any feed back that help improving the (very thin) install documentation or the installation itself is welcome!

  • Boxes.py gets musical

    Florian Festi11/25/2017 at 23:04 0 comments

    Due to the many requests of a single person I added another thing that is not completely unlike a box:

    This contraption is an end pin for a bass recorder. Well it is an end pin if you add the pin at the clamp on the right. Imagine a black, metal, telescopic mono pod - as you might use with a camera but a bit shorter (for some reason it did not make it on the pictures). May be at least adding the bottom piece of the recorder gives a better idea ...

    Although these things are weird and serve a very rare purpose they multiply rather quickly.

  • Side Projects

    Florian Festi11/16/2017 at 20:30 0 comments

    I has been a bit quiet here the last couple of weeks. But this has little to do with me not working on Boxes.py but rather with me working on something so big it needs its own project page: Flipper the Cocktail Bot

    Yes, yes, it is only in part made with Boxes.py and still not in the GitHub repository. But it turns out a working cocktail bot doesn't help with that...

    As a consolation I made you a new box.

View all 38 project logs

Enjoy this project?

Share

Discussions

Thomas Pearce wrote 08/14/2018 at 15:46 point

What would be the feasibility of adding a grayscale based dovetail joint to this generator? I made them a while ago, but it didn't go anywhere because it was too tedious to make the joints. This is an awesome project, I'll have to play with it when I get the chance. the old link to the dovetails, I probably should rewrite it and move it somewhere better at some point. https://www.thingiverse.com/thing:1300977

  Are you sure? yes | no

Florian Festi wrote 09/11/2018 at 21:18 point

It should be possible to add something like this to Boxes.py. The question is what parameters are needed, to make things fit. One would also need some test piece to read the parameters from.

  Are you sure? yes | no

ornery shard wrote 08/06/2018 at 14:44 point

This tool is really great.

@Florian Festi Do you have pics and/or instructions how to  assemble the "rotary attachment for a laser cutter"

What kind of raw materials would I need for this?

  Are you sure? yes | no

Florian Festi wrote 08/07/2018 at 12:28 point

I don't. I am currently travelling so it may take a while until I can take pictures. The rotary attachment consist of two parts that slide on a metal bar. One side houses a NEMA 23 stepper that drives two rollers. The other part is a scissor lift with two free rollers.

You will need to adjust the bottom hole for the metal bar you are using.

Overall I am not 100% satisfied with the rotary attachment. The scissor lift is not as smooth and rigid as I'd want. But IIRC I made it from 5 or 6mm poppler. You want to use birch ply for that. I am still thinking about making a version without scissor lift that can be tilted as a whole.

You need a stepper motor that is electrically compatible with your Y axis of your laser cutter. Mine has 3 phase steppers which make getting one a bit more difficult. Your laser cutter needs to have a outlet for plugging the rotary device in. Or you need to do the wiring yourself.

The attachment also is still missing some accessories like rollers to limit left to right movement and pressing the inside of glasses against the driven rollers.

Beside these short coming it works reasonably well and we have engraved several glasses and bottles with it.

  Are you sure? yes | no

Jan wrote 08/03/2018 at 11:50 point

Love this tool. One can spend so much time optimizing stuff like that but you "just" write a script for it and automate it for everyone to use for free. NICE!
But I wonder: don't use wood laser-cutters DXF files like the whole sheet metal industry?

  Are you sure? yes | no

Florian Festi wrote 08/03/2018 at 17:00 point

Yes, they do. Boxes.py can generate DXF using ps2edit. But it's not available in the online generator. You can run it locally, though.

  Are you sure? yes | no

paul wrote 08/02/2018 at 12:00 point

this tool is great but it outputs the svg into the browser, how do I download it?

  Are you sure? yes | no

Florian Festi wrote 08/02/2018 at 16:01 point

Just right click and "save as"

  Are you sure? yes | no

dejan.k wrote 06/26/2018 at 08:13 point

Hello, absolutly fenomenal work, thank you very much, you shoud think about adding a feature to universal box top_edge edge with hinges and click on, on other side so it closes :) 

  Are you sure? yes | no

Florian Festi wrote 08/03/2018 at 11:32 point

The click-on edge probably deserves some more love before that becomes really feasible. But adding lock and latches to the lids is on my todo list. To my shame I have to admit that I hand drew a pair of latches for the box I recently build...

  Are you sure? yes | no

Cristian wrote 06/04/2018 at 16:44 point

Hello people... Mr. Florian, your application it is of great help, thank you very much!!! if you are interested i have a kinda new project for you. Letter shaped boxes with and without lid. Those are used for led lighting lettes and so. 

  Are you sure? yes | no

Chris Jones wrote 02/06/2018 at 05:39 point

I really appreciate this project! It has helped me make card boxes and trays to help me organise board game components better inside their boxes.

This evening I have been having trouble, though. When I use traylayout to generate a tray from a layout file, the walls of the layout have gaps in them, and they are overlapping. I don't think there is anything different that I am doing, and I have screenshots to show you my input and the svg that is output. I can send them to you if you like. 

Thank you again for an incredibly useful tool!

  Are you sure? yes | no

Ian Hubbertz wrote 12/31/2017 at 13:03 point

What's the easiest way to split a large part into two (or more) parts with dovetail joints? 

I want to build a large "RoundedBox", so that the flexible part around the box is too long for the  laser cutter. It would be nice to split this part into two or even more parts?

  Are you sure? yes | no

Florian Festi wrote 01/14/2018 at 21:32 point

Oh, sorry! I missed your comment over the holidays.

The canonical way of doing this would be extending the roundedPlate() and surroundingWall() methods in boxes/__init__.py to take a param on how many splits should be used (one to four - may be without three) and then adding a param to the RoundedBox generator that set them. 

As an alternative you can provide a instructions to get Boxes.py running on Windows and I'll do the coding for you (see https://hackaday.io/project/10649/log/71764-boxespy-on-windows ). 

  Are you sure? yes | no

Ian Hubbertz wrote 01/20/2018 at 11:18 point

Ha.. :-) thanks for the offer, but I have absolutely no experience with development (or deployment) on Windows.

When I find some free time (I have two other projects right now with higher priority), I will have a look to see how to enhance the surroundingWall() method.

  Are you sure? yes | no

Florian Festi wrote 08/06/2018 at 17:53 point

OK, I finally did just that. Instead of offering full control over where exactly to split the wall I just used a param allowing values from 1 to 4. This allows to split:

* front only

* front and back

* front and right and back

* all four sides

The new code is already online. Please double check before laser cutting. The change isn't entirely trivial.

  Are you sure? yes | no

Chris wrote 11/17/2017 at 19:27 point

Thanks for sharing this project with the world, it looks fantastic. Do you do any further post-processing of the generated SVGs prior to cutting, and if so what is your preferred application? Also what software do you use to generate gcode/control your laser? I'm using LaserWeb 4, and I can't figure out what I need to do to the boxes.py SVG output to make it work properly in LaserWeb 4. If I open the SVG in Adobe Illustrator and save it, that only seems to increase the number of errors. Any hints or tips would be greatly appreciated.

  Are you sure? yes | no

Florian Festi wrote 11/17/2017 at 19:45 point

Our Chinese laser cutter comes with some proprietorial front end program that allows arranging the pieces. For other stuff I often use Inkscape. But this also is a mixed bag as it is not really a CAD program and adds the line widths to all measurements.

There are a few pitfalls:

Boxes.py creates a lot of very short segments. If you have some auto connect feature that tries to connect single line segments to a continuous polygon make sure if has only 0.01mm range. The common default of 0.1mm is too big.

Both SVG and also DXF do not really come with units. So all lengths are just a numbers that can mean different things to different programs under different circumstances.

If you need DXF you might want to install Boxes.py locally and also install ps2edit. Then Boxes.py can create DXF directly (among some other formats).

  Are you sure? yes | no

Chris wrote 11/20/2017 at 19:11 point

Thanks for your quick reply. Based on https://darklylabs.zendesk.com/hc/en-us/community/posts/206123108/comments/115000442212, I've had some success with the following Illustrator workflow:

1) Save boxes.py output as SVG from browser.
2) Open in Illustrator.
3) One-by-one, select each path…
4) Right-click > Release Compound Path
5) Right-Click > Join
6) For each enclosed shape, select all edges, Right Click > Join
7) For circles, Right Click > Join
8) Save As > SVG 1.1, Style Attributes

9) Import into LaserWeb

  Are you sure? yes | no

Florian Festi wrote 11/21/2017 at 09:18 point

Wow! This still sounds really painful. Have you tried DXF as a format? IIRC it is even more primitive so may be the importer can deal with the non connected line segments better.

  Are you sure? yes | no

Yash Gupta wrote 10/21/2017 at 20:56 point

Great project. I wonder if there is a way to automate splitting of the files across pages of a specific size to laser cur larger projects on laser cutters with limited real estate?

  Are you sure? yes | no

Florian Festi wrote 10/21/2017 at 23:22 point

No, this is not possible right now and I am not planning to add this. It turns out that the parts need to be rearranged by hand most of the time anyway. Even if they fit in the laser cutter they do not fit on the leftover sheets which at least I often use for one ofs.

In case you want to do a larger run with one size you'll want to optimize by hand anyway to make sure you make the best use of the your sheets.

  Are you sure? yes | no

Jarrett wrote 10/02/2017 at 16:12 point

I just want you to know that I really appreciate this project! Especially the web interface. It has saved me so much time in CAD stuff to just be able to directly generate profiles.

  Are you sure? yes | no

Similar Projects

Does this project spark your interest?

Become a member to follow this project and never miss any updates