The Belfry OpenScad Library, v2.0. An OpenSCAD library of shapes, masks, and manipulators to make working with OpenSCAD easier. BETA
Find a file
adrianVmariano 79d725be97
Merge pull request #1667 from amatulic/general_dev
Improvements to line_from_points() and plane_from_points()
2025-05-04 23:01:42 -04:00
.github Update release.yml 2025-04-25 19:56:29 -07:00
examples
images add isovalue range to contour(), add more frames to animation, doc updates 2025-03-28 19:07:15 -07:00
resources
scripts fixed bug that maximized file size 2025-04-27 23:31:00 -07:00
tests adjust regression test for new best-fit line result 2025-05-03 23:46:39 -07:00
tutorials Removed executable permission from tutorials/Beziers_for_Beginners.md 2025-04-15 21:42:04 +03:00
.gitignore
.openscad_docsgen_rc
.openscad_mdimggen_rc
affine.scad
attachments.scad textured_tile & prismoid attachment spin fixes 2025-04-04 16:17:27 -04:00
ball_bearings.scad
beziers.scad Deprecated thickness in vnf_sheet and bezier_sheet 2025-04-15 23:16:21 -07:00
bosl1compat.scad
bottlecaps.scad remove debug echoes 2025-05-02 23:27:28 -04:00
builtins.scad
color.scad
comparisons.scad
constants.scad
CONTRIBUTING.md
coords.scad reverted project_plane() and lift_plane() back to enforcing coplanaryity of input 2025-05-04 16:58:39 -07:00
cubetruss.scad cubetruss anchor fix 2025-03-17 20:57:46 -04:00
distributors.scad arc_copies was creating an extra copy for 360 deg angles 2025-03-24 21:17:17 -04:00
drawing.scad path_sweep texture bugfix 2025-04-14 18:29:31 -04:00
fnliterals.scad
gears.scad user faceing root_radius() 2025-04-27 09:01:46 -04:00
geometry.scad Add deprecation messages 2025-05-04 16:07:20 -07:00
hinges.scad
isosurface.scad comment out example 2025-04-24 07:32:33 -04:00
joiners.scad See Also updates 2025-02-26 11:39:29 -08:00
LICENSE
linalg.scad
linear_bearings.scad
lists.scad fix typo 2025-04-28 19:16:26 -04:00
masks2d.scad remove debug echoes 2025-05-02 23:27:28 -04:00
masks3d.scad
math.scad Updated Topics in fit_to_range and fit_to_box 2025-04-30 13:45:50 -07:00
metric_screws.scad
miscellaneous.scad doc fixes 2025-04-18 06:15:59 -04:00
modular_hose.scad
nema_steppers.scad
nurbs.scad
partitions.scad See Also updates 2025-02-26 11:39:29 -08:00
paths.scad texture code cleanup 2025-04-15 20:01:57 -04:00
polyhedra.scad
README.md Fix typo in README.md 2025-04-11 23:49:39 +12:00
regions.scad syntax error fix 2025-05-04 12:28:21 -07:00
rounding.scad doc fixes 2025-05-01 22:27:03 -04:00
screw_drive.scad
screws.scad
shapes2d.scad fix bug for empty attachments in 2d 2025-04-01 06:57:55 -04:00
shapes3d.scad Bugfix for _teardrop_corner with ang != 45 2025-05-03 23:22:48 -07:00
skin.scad Merge branch 'master' into revarbat_dev 2025-04-30 19:00:19 -07:00
sliders.scad Fixed slider anchors. 2025-05-04 02:14:04 -07:00
std.scad fix rotate_sweep texture endcaps 2025-04-03 16:56:46 -04:00
strings.scad strings doc fixes 2025-04-21 19:20:55 -04:00
structs.scad
threading.scad
transforms.scad
trigonometry.scad
tripod_mounts.scad
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 Improved fit_to_box(), added example 2025-04-30 16:17:03 -07:00
version.scad
vnf.scad doc fixes 2025-04-27 14:52:08 -04:00
walls.scad improved size error handling, round3d docs & default size change 2025-02-23 16:09:24 -05:00
wiring.scad
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);