NopSCADlib/vitamins/rod.scad

56 lines
1.8 KiB
OpenSCAD
Raw Normal View History

2019-06-08 17:10:47 -04:00
//
// NopSCADlib Copyright Chris Palmer 2018
// nop.head@gmail.com
// hydraraptor.blogspot.com
//
// This file is part of NopSCADlib.
//
// NopSCADlib is free software: you can redistribute it and/or modify it under the terms of the
// GNU General Public License as published by the Free Software Foundation, either version 3 of
// the License, or (at your option) any later version.
//
// NopSCADlib is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
// See the GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along with NopSCADlib.
// If not, see <https://www.gnu.org/licenses/>.
//
//
2019-08-18 07:18:12 -04:00
//! Steel rods and studding with chamfered ends.
2019-06-08 17:10:47 -04:00
//
include <../core.scad>
2020-01-10 05:26:12 -05:00
use <../utils/thread.scad>
2019-06-08 17:10:47 -04:00
rod_colour = grey80;
2019-08-18 07:18:12 -04:00
studding_colour = grey70;
2019-06-08 17:10:47 -04:00
2019-08-18 07:18:12 -04:00
module rod(d , l) { //! Draw a smooth rod with specified length and diameter
2019-06-08 17:10:47 -04:00
vitamin(str("rod(", d, ", ", l, "): Smooth rod ", d, "mm x ", l, "mm"));
chamfer = d / 10;
color(rod_colour)
hull() {
cylinder(d = d, h = l - 2 * chamfer, center = true);
cylinder(d = d - 2 * chamfer, h = l, center = true);
}
}
2019-08-18 07:18:12 -04:00
module studding(d , l) { //! Draw a threaded rod with specified length and diameter
vitamin(str("studding(", d, ", ", l,"): Threaded rod M", d, " x ", l, "mm"));
chamfer = d / 20;
2020-01-10 05:26:12 -05:00
pitch = metric_coarse_pitch(d);
2019-08-18 07:18:12 -04:00
color(studding_colour)
2020-01-10 05:26:12 -05:00
if(show_threads && pitch)
male_metric_thread(d, pitch, l);
else
hull() {
cylinder(d = d, h = l - 2 * chamfer, center = true);
cylinder(d = d - 2 * chamfer, h = l, center = true);
}
2019-08-18 07:18:12 -04:00
}