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-09-26 19:03:50 -04:00
.github Minor docs fixes. Removed VersionBump workflow. 2024-02-06 10:26:34 -08:00
examples Fixes for stale examples. 2024-03-03 19:19:14 -08:00
images Added logo to README. 2020-12-30 15:44:17 -08: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 sum/product optimizations 2024-06-25 19:24:48 -04:00
tutorials add sweep_attach 2024-05-04 17:44:53 -04:00
.gitignore Improved mkdocspdf.sh 2023-05-08 16:45:38 -07:00
.openscad_docsgen_rc Change Extra Anchors to Named Anchors 2024-05-20 19:42:07 -04: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 spin direction sign fix 2024-09-02 08:14:30 -04:00
ball_bearings.scad Added examples for flanged and shielded and flanged and unshielded bearings 2023-11-28 07:56:36 -08:00
beziers.scad doc tweaks 2024-07-27 09:36:51 -04: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 Added color_overlaps() 2023-07-07 19:21:59 -07:00
comparisons.scad fix typo 2024-03-03 11:36:40 -05:00
constants.scad SynTags for attachments.scad to geometry.scad 2023-05-27 01:42:09 -07: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 Tweaks to make cubetruss prints more reliable. 2024-01-04 21:57:17 -08:00
distributors.scad bugfix for rot_copies: sa parameter was ignored 2024-07-27 10:04:58 -04:00
drawing.scad doc fixes and screws fix 2024-08-09 21:52:51 -04:00
fnliterals.scad Some 2-arg fnliteral factory fixes. 2023-08-07 23:24:28 -07:00
gears.scad doc fixes 2024-09-26 17:00:02 -04:00
geometry.scad fix geometry offset() calls 2024-09-14 17:09:04 -04:00
hinges.scad fix anchors for offset_sweep 2024-02-15 18:32:17 -05:00
joiners.scad Change offset() default closed value to match builtin 2024-09-14 17:08:35 -04: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 All the SynTags. 2023-05-29 21:48:48 -07:00
masks2d.scad Fixed Figure reference. 2024-05-04 19:41:52 -07:00
masks3d.scad add sparse_cuboid plus doc fixes 2024-05-12 21:09:44 -04:00
math.scad sum/product optimizations 2024-06-25 19:24:48 -04:00
metric_screws.scad Change Extra Anchors to Named Anchors 2024-05-20 19:42:07 -04:00
miscellaneous.scad doc fix 2024-06-22 22:58:52 -04: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
partitions.scad add regular_prism(), fix anchors to prismoid() 2024-08-29 19:29:43 -04:00
paths.scad Fixed bug in path_merge_collinear() 2024-04-22 14:39:12 -07:00
polyhedra.scad remove comma 2023-09-01 22:10:15 -04:00
README.md improve directions for finding library directory 2024-02-18 10:40:38 -05:00
regions.scad Change offset() default closed value to match builtin 2024-09-14 17:08:35 -04:00
rounding.scad docs bugfixes 2024-09-26 19:03:50 -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 Change Courier references to Liberation Mono which we know is available 2024-09-26 16:59:12 -04:00
shapes3d.scad Change Courier references to Liberation Mono which we know is available 2024-09-26 16:59:12 -04:00
skin.scad spiral_sweep bugfix 2024-06-12 22:01:34 -04:00
sliders.scad All the SynTags. 2023-05-29 21:48:48 -07:00
std.scad mutators-> misc, add flip1/flip2 styles to vnf 2024-05-04 23:32:48 -04:00
strings.scad Synopses, etc for strings.scad 2023-04-28 19:23:15 -07:00
structs.scad Adds initialisation example documentation to structs. 2023-08-12 18:36:32 +01:00
threading.scad Fix teardrop for threaded screws 2024-01-27 10:52:54 -05:00
transforms.scad Added Ext Syntag 2024-01-02 14:10:19 -08: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 fix example bug 2023-12-09 21:15:26 -05:00
utility.scad change n to $fn for round vnf textures; descriptive error message for 2024-01-10 23:55:51 -05:00
vectors.scad All the SynTags. 2023-05-29 21:48:48 -07:00
version.scad Merge branch 'master' into master 2024-02-12 00:19:58 -08:00
vnf.scad Change VNF hull anchors to point in more rational directions 2024-09-01 21:21:24 -04:00
walls.scad doc fix 2024-05-21 22:16:42 -04:00
wiring.scad All the SynTags. 2023-05-29 21:48:48 -07:00
WRITING_DOCS.md Document FPS= in examples. 2023-11-17 22:11:06 -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);