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 7821a5143c
Merge pull request from adrianVmariano/master
path_sweep doc: bit about anchors
2025-04-05 09:13:16 -04:00
.github Minor docs fixes. Removed VersionBump workflow. 2024-02-06 10:26:34 -08:00
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 add isovalue range to contour(), add more frames to animation, doc updates 2025-03-28 19:07:15 -07:00
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 descriptions additions/fixes 2025-03-19 22:41:56 -04:00
tutorials Fix - 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 Corrected errors in documentation 2025-01-24 10:46:18 -08:00
.openscad_mdimggen_rc Make docs use PNG animations. 2023-02-03 12:09:46 -08:00
affine.scad Fix teardrop for threaded screws 2024-01-27 10:52:54 -05:00
attachments.scad textured_tile & prismoid attachment spin fixes 2025-04-04 16:17:27 -04:00
ball_bearings.scad Added rounding parameter as discussed in 2024-12-12 10:20:17 -08:00
beziers.scad Merge pull request from amatulic/rounding 2025-01-26 17:21:12 -05:00
bosl1compat.scad doc fixes 2022-10-23 08:05:40 -04:00
bottlecaps.scad Change Extra Anchors to Named Anchors 2024-05-20 19:42:07 -04:00
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 fix 2024-10-03 23:00:16 -04:00
CONTRIBUTING.md Moving to BelfrySCAD org. 2023-05-21 21:00:05 -07:00
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 arc_copies was creating an extra copy for 360 deg angles 2025-03-24 21:17:17 -04:00
drawing.scad fix bug for empty attachments in 2d 2025-04-01 06:57:55 -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 fix doc errors 2025-03-24 22:03:24 -04:00
hinges.scad fix anchors for offset_sweep 2024-02-15 18:32:17 -05:00
isosurface.scad added explanation of isovalue range to metaballs() and metaballs2d() 2025-04-04 21:37:43 -07:00
joiners.scad See Also updates 2025-02-26 11:39:29 -08:00
LICENSE Updated copyright years. Split math.scad up. Enabled attach for lots of shapes. Removed backwards compatability. 2019-04-19 17:02:17 -07:00
linalg.scad All the SynTags. 2023-05-29 21:48:48 -07:00
linear_bearings.scad Deprecating metric_screws.scad 2023-06-01 21:44:23 -07:00
lists.scad handle undef properly in cuboid 2025-02-23 18:06:57 -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 mean_angle 2025-03-17 21:02:31 -04:00
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 All the SynTags. 2023-05-29 21:48:48 -07:00
nema_steppers.scad All the SynTags. 2023-05-29 21:48:48 -07:00
nurbs.scad nurbs bugfix singleton point evaluation 2025-02-07 17:47:06 -05:00
partitions.scad See Also updates 2025-02-26 11:39:29 -08:00
paths.scad textured sweep fix & contour isovalue change 2025-04-02 20:20:13 -04:00
polyhedra.scad doc fix 2024-11-19 19:01:01 -05:00
README.md improve directions for finding library directory 2024-02-18 10:40:38 -05:00
regions.scad textured sweep fix & contour isovalue change 2025-04-02 20:20:13 -04:00
rounding.scad doc fixes 2025-03-31 20:55:58 -04:00
screw_drive.scad attachability for torx, roberson, screw_head 2023-06-18 20:20:01 -04:00
screws.scad doc fixes and screws fix 2024-08-09 21:52:51 -04:00
shapes2d.scad fix bug for empty attachments in 2d 2025-04-01 06:57:55 -04:00
shapes3d.scad remove "dimples" texture; fix "bricks" and "rough" to be on [0,1] 2025-04-04 19:47:36 -04:00
skin.scad doc tweak 2025-04-05 08:23:13 -04:00
sliders.scad Expose slider() chamfer as parameter 2025-02-07 21:01:22 +01:00
std.scad fix rotate_sweep texture endcaps 2025-04-03 16:56:46 -04:00
strings.scad allow lists in some cases 2025-01-08 18:36:43 -05: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 Fix teardrop for threaded screws 2024-01-27 10:52:54 -05:00
transforms.scad transform logging 2024-12-03 20:34:58 -05:00
trigonometry.scad Synopses, etc for trigonometry.scad 2023-04-28 18:39:26 -07:00
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 doc fix 2025-03-20 22:00:10 -04:00
vectors.scad add vnf_bounds 2025-02-16 21:01:19 -05:00
version.scad Merge branch 'master' into master 2024-02-12 00:19:58 -08:00
vnf.scad fix rotate_sweep texture endcaps 2025-04-03 16:56:46 -04:00
walls.scad improved size error handling, round3d docs & default size change 2025-02-23 16:09:24 -05:00
wiring.scad All the SynTags. 2023-05-29 21:48:48 -07:00
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);