The Belfry OpenScad Library, v2.0. An OpenSCAD library of shapes, masks, and manipulators to make working with OpenSCAD easier. BETA
Find a file
Adrian Mariano dfd5c0abfe more fixes
2025-04-29 07:40:37 -04:00
.github Update release.yml 2025-04-25 19:56:29 -07:00
examples
images
resources
scripts
tests
tutorials
.gitignore
.openscad_docsgen_rc
.openscad_mdimggen_rc
affine.scad
attachments.scad
ball_bearings.scad
beziers.scad Deprecated thickness in vnf_sheet and bezier_sheet 2025-04-15 23:16:21 -07:00
bosl1compat.scad doc fixes 2022-10-23 08:05:40 -04:00
bottlecaps.scad
builtins.scad bug fixes for "default" color 2022-03-20 09:03:18 -04:00
color.scad add highlight and highlight_this 2024-12-11 16:20:58 -05:00
comparisons.scad Doc improvements: spelling, grammar, examples 2025-01-17 17:27:36 -08:00
constants.scad
CONTRIBUTING.md
coords.scad doc fixes, snap hinge angle fix 2023-11-05 10:05:54 -05:00
cubetruss.scad cubetruss anchor fix 2025-03-17 20:57:46 -04:00
distributors.scad
drawing.scad
fnliterals.scad
gears.scad
geometry.scad fix doc errors 2025-03-24 22:03:24 -04:00
hinges.scad
isosurface.scad comment out example 2025-04-24 07:32:33 -04:00
joiners.scad
LICENSE
linalg.scad
linear_bearings.scad
lists.scad
masks2d.scad
masks3d.scad
math.scad
metric_screws.scad
miscellaneous.scad
modular_hose.scad
nema_steppers.scad
nurbs.scad nurbs bugfix singleton point evaluation 2025-02-07 17:47:06 -05:00
partitions.scad
paths.scad
polyhedra.scad
README.md
regions.scad
rounding.scad add region support to offset_sweep (module only) 2025-04-22 17:31:46 -04:00
screw_drive.scad attachability for torx, roberson, screw_head 2023-06-18 20:20:01 -04:00
screws.scad
shapes2d.scad
shapes3d.scad
skin.scad
sliders.scad
std.scad
strings.scad strings doc fixes 2025-04-21 19:20:55 -04:00
structs.scad add structs.scad to std.scad; fix various it's typos in docs 2024-11-03 07:12:38 -05:00
threading.scad
transforms.scad transform logging 2024-12-03 20:34:58 -05:00
trigonometry.scad
tripod_mounts.scad All the SynTags. 2023-05-29 21:48:48 -07:00
turtle3d.scad doc fixes 2025-03-10 18:49:30 -04:00
utility.scad bugfixes and a few new examples 2025-04-18 16:55:11 -04:00
vectors.scad
version.scad
vnf.scad doc fixes 2025-04-27 14:52:08 -04:00
walls.scad
wiring.scad All the SynTags. 2023-05-29 21:48:48 -07:00
WRITING_DOCS.md

BOSL2

BOSL2 Logo

The Belfry OpenScad Library, v2

A library for OpenSCAD, filled with useful tools, shapes, masks, math and manipulators, designed to make OpenSCAD easier to use.

Requires OpenSCAD 2021.01 or later.

  • NOTE: BOSL2 IS BETA CODE. THE CODE IS STILL BEING REORGANIZED.
  • NOTE2: CODE WRITTEN FOR BOSLv1 PROBABLY WON'T WORK WITH BOSL2!

Join the chat at https://gitter.im/revarbat/BOSL2

Documentation

You can find the full BOSL2 library documentation at: https://github.com/BelfrySCAD/BOSL2/wiki

Installation

  1. Download the .zip or .tar.gz release file for this library. Currently you should be able to find this at https://github.com/BelfrySCAD/BOSL2/archive/refs/heads/master.zip
  2. Unpack it. Make sure that you unpack the whole file structure. Some zipfile unpackers call this option "Use folder names". It should create either a BOSL-v2.0 or BOSL2-master directory with the library files within it. You should see "examples", "scripts", "tests", and other subdirectories.
  3. Rename the unpacked main directory to BOSL2.
  4. Move the BOSL2 directory into the apropriate OpenSCAD library directory. The library directory may be on the list below, but for SNAP or other prepackaged installations, it is probably somewhere else. To find it, run OpenSCAD and select Help→Library Info, and look for the entry that says "User Library Path". This is your default library directory. You may choose to change it to something more convenient by setting the environment variable OPENSCADPATH. Using this variable also means that all versions of OpenSCAD you install will look for libraries in the same location.
    • Windows: My Documents\OpenSCAD\libraries\
    • Linux: $HOME/.local/share/OpenSCAD/libraries/
    • Mac OS X: $HOME/Documents/OpenSCAD/libraries/
  5. Restart OpenSCAD.

Examples

A lot of the features of this library are to allow shorter, easier-to-read, intent-based coding. For example:

BOSL2/transforms.scad Examples Raw OpenSCAD Equivalent
up(5) translate([0,0,5])
xrot(30,cp=[0,10,20]) translate([0,10,20]) rotate([30,0,0]) translate([0,-10,-20])
xcopies(20,n=3) for (dx=[-20,0,20]) translate([dx,0,0])
zrot_copies(n=6,r=20) for (zr=[0:5]) rotate([0,0,zr*60]) translate([20,0,0])
skew(sxz=0.5,syz=0.333) multmatrix([[1,0,0.5,0],[0,1,0.333,0],[0,0,1,0],[0,0,0,1]])
BOSL2/shapes.scad Examples Raw OpenSCAD Equivalent
cube([10,20,30], anchor=BOTTOM); translate([0,0,15]) cube([10,20,30], center=true);
cuboid([20,20,30], rounding=5); minkowski() {cube([10,10,20], center=true); sphere(r=5, $fn=32);}
prismoid([30,40],[20,30],h=10); hull() {translate([0,0,0.005]) cube([30,40,0.01], center=true); translate([0,0,9.995]) cube([20,30,0.01],center=true);}
xcyl(l=20,d=4); rotate([0,90,0]) cylinder(h=20, d=4, center=true);
cyl(l=100, d=40, rounding=5); minkowski() {cylinder(h=90, d=30, center=true); sphere(r=5);}
tube(od=40,wall=5,h=30); difference() {cylinder(d=40,h=30,center=true); cylinder(d=30,h=31,center=true);}
torus(d_maj=100, d_min=30); rotate_extrude() translate([50,0,0]) circle(d=30);