The Belfry OpenScad Library, v2.0. An OpenSCAD library of shapes, masks, and manipulators to make working with OpenSCAD easier. BETA
Find a file
2024-12-19 17:28:48 +11:00
.github
examples
images Added logo to README. 2020-12-30 15:44:17 -08:00
resources
scripts
tests sum/product optimizations 2024-06-25 19:24:48 -04:00
tutorials add "shear" as synonym for skew 2024-11-27 20:21:27 -05:00
.gitignore
.openscad_docsgen_rc add structs.scad to std.scad; fix various it's typos in docs 2024-11-03 07:12:38 -05:00
.openscad_mdimggen_rc
affine.scad
attachments.scad add highlight and highlight_this 2024-12-11 16:20:58 -05:00
ball_bearings.scad Added rounding parameter as discussed in 2024-12-12 10:20:17 -08:00
beziers.scad doc fixes 2024-11-06 19:02:45 -05:00
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 fix 2024-10-03 23:00:16 -04:00
CONTRIBUTING.md
coords.scad
cubetruss.scad
distributors.scad check that rows is an integer for grid2d 2024-11-27 20:19:48 -05:00
drawing.scad arc() bugfix 2024-09-28 08:44:14 -04:00
fnliterals.scad
gears.scad spur_gear: fix negative helix angles 2024-12-18 16:36:38 -07:00
geometry.scad fix geometry offset() calls 2024-09-14 17:09:04 -04:00
hinges.scad
joiners.scad additional hirth fixes 2024-11-17 20:40:11 -05:00
LICENSE
linalg.scad
linear_bearings.scad
lists.scad doc fix for list_head 2024-11-27 20:20:56 -05:00
masks2d.scad Update masks2d.scad 2024-10-16 17:43:42 -07:00
masks3d.scad Add roundings to rounded_edge_mask and some $edge_angle fixes 2024-10-03 22:26:22 -04:00
math.scad add highlight and highlight_this 2024-12-11 16:20:58 -05:00
metric_screws.scad
miscellaneous.scad doc fix 2024-06-22 22:58:52 -04:00
modular_hose.scad
nema_steppers.scad
nurbs.scad bug fix for specified knots case 2024-12-07 13:57:15 -05:00
partitions.scad Propagate information about partition() part to children() 2024-10-06 12:53:45 +03:00
paths.scad
polyhedra.scad doc fix 2024-11-19 19:01:01 -05:00
README.md
regions.scad misc fixes 2024-10-13 20:03:00 -04:00
rounding.scad fix rounded prism docs 2024-12-05 22:47:08 -05:00
screw_drive.scad
screws.scad doc fixes and screws fix 2024-08-09 21:52:51 -04:00
shapes2d.scad doc fixes 2024-12-14 12:03:57 -05:00
shapes3d.scad tube rounding 2024-11-13 18:54:45 -05:00
skin.scad skin automatically flips faces when paths are reversed; bugfix in rounded_prism 2024-11-03 07:26:41 -05:00
sliders.scad
std.scad add structs.scad to std.scad; fix various it's typos in docs 2024-11-03 07:12:38 -05:00
strings.scad
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
turtle3d.scad add structs.scad to std.scad; fix various it's typos in docs 2024-11-03 07:12:38 -05:00
utility.scad
vectors.scad add vector_perp 2024-12-03 20:34:17 -05:00
version.scad
vnf.scad Fixed typo in new example for vnf_vertex_array 2024-12-12 19:35:37 -08:00
walls.scad
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);