The Belfry OpenScad Library, v2.0. An OpenSCAD library of shapes, masks, and manipulators to make working with OpenSCAD easier. BETA
Find a file
2025-03-12 02:49:06 -07:00
.github
examples include beziers.scad in std.scad, remove include line from all other files containing it 2025-01-05 11:40:20 -08:00
images
resources PDF font size tweaks. 2023-05-09 18:08:32 -07:00
scripts mutators-> misc, add flip1/flip2 styles to vnf 2024-05-04 23:32:48 -04:00
tests
tutorials Fix #1547 - typos in example, minor spelling and grammar improvements 2025-01-23 11:54:16 -08:00
.gitignore Improved mkdocspdf.sh 2023-05-08 16:45:38 -07:00
.openscad_docsgen_rc
.openscad_mdimggen_rc
affine.scad Fix teardrop for threaded screws 2024-01-27 10:52:54 -05:00
attachments.scad doc fixes 2025-03-10 18:49:30 -04:00
ball_bearings.scad
beziers.scad
bosl1compat.scad
bottlecaps.scad
builtins.scad
color.scad add highlight and highlight_this 2024-12-11 16:20:58 -05:00
comparisons.scad
constants.scad
CONTRIBUTING.md
coords.scad
cubetruss.scad
distributors.scad
drawing.scad doc fixes 2025-03-10 18:49:30 -04:00
fnliterals.scad Some 2-arg fnliteral factory fixes. 2023-08-07 23:24:28 -07:00
gears.scad Fix missing shorten parameter 2024-12-29 11:28:12 +01:00
geometry.scad
hinges.scad fix anchors for offset_sweep 2024-02-15 18:32:17 -05:00
isosurface.scad removed anchoring from regions until we figure it out 2025-03-12 02:49:06 -07:00
joiners.scad See Also updates 2025-02-26 11:39:29 -08:00
LICENSE
linalg.scad
linear_bearings.scad
lists.scad
masks2d.scad
masks3d.scad
math.scad
metric_screws.scad Change Extra Anchors to Named Anchors 2024-05-20 19:42:07 -04:00
miscellaneous.scad improved size error handling, round3d docs & default size change 2025-02-23 16:09:24 -05:00
modular_hose.scad
nema_steppers.scad
nurbs.scad
partitions.scad See Also updates 2025-02-26 11:39:29 -08:00
paths.scad Fixed bug in path_merge_collinear() 2024-04-22 14:39:12 -07:00
polyhedra.scad
README.md improve directions for finding library directory 2024-02-18 10:40:38 -05:00
regions.scad misc fixes 2024-10-13 20:03:00 -04:00
rounding.scad
screw_drive.scad
screws.scad
shapes2d.scad doc fixes 2025-03-10 18:49:30 -04:00
shapes3d.scad fix typo 2025-03-08 09:19:51 -05:00
skin.scad add angle to rotate_sweep 2025-03-04 22:08:46 -05:00
sliders.scad All the SynTags. 2023-05-29 21:48:48 -07:00
std.scad
strings.scad
structs.scad
threading.scad Fix teardrop for threaded screws 2024-01-27 10:52:54 -05:00
transforms.scad
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 revert scalar_vec3 2025-02-23 16:14:28 -05:00
vectors.scad
version.scad
vnf.scad
walls.scad improved size error handling, round3d docs & default size change 2025-02-23 16:09:24 -05:00
wiring.scad
WRITING_DOCS.md include beziers.scad in std.scad, remove include line from all other files containing it 2025-01-05 11:40:20 -08:00

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);