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/>.
//
//
//! Models timing belt running over toothed or smooth pulleys and calculates an accurate length.
//! Only models 2D paths, so not core XY!
//!
2019-08-21 06:36:48 -04:00
//! To make the back of the belt run against a smooth pulley on the outside of the loop specify a negative pitch radius.
//!
2019-06-08 17:10:47 -04:00
//! By default the path is a closed loop but a gap length and position can be specified to make open loops.
2020-08-22 06:16:56 -04:00
//! To draw the gap its XY position is specified by ```gap_pos```. ```gap_pos.z``` can be used to specify a rotation if the gap is not at the bottom of the loop.
2019-06-08 17:10:47 -04:00
//!
//! Individual teeth are not drawn, instead they are represented by a lighter colour.
//
2020-02-29 12:52:36 -05:00
include < ../utils/core/core.scad >
2019-06-08 17:10:47 -04:00
use < ../utils/rounded_polygon.scad >
2020-08-22 06:16:56 -04:00
use < ../utils/maths.scad >
2019-06-08 17:10:47 -04:00
function belt_pitch ( type ) = type [ 1 ] ; //! Pitch in mm
function belt_width ( type ) = type [ 2 ] ; //! Width in mm
function belt_thickness ( type ) = type [ 3 ] ; //! Total thickness including teeth
function belt_tooth_height ( type ) = type [ 4 ] ; //! Tooth height
2020-08-22 04:45:13 -04:00
function belt_pitch_height ( type ) = type [ 5 ] + belt_tooth_height ( type ) ; //! Offset of the pitch radius from the tips of the teeth
function belt_pitch_to_back ( type ) = belt_thickness ( type ) - belt_pitch_height ( type ) ; //! Offset of the back from the pitch radius
2019-06-08 17:10:47 -04:00
//
// We model the belt path at the pitch radius of the pulleys and the pitch line of the belt to get an accurate length.
// The belt is then drawn by offseting each side from the pitch line.
//
2020-08-22 06:16:56 -04:00
module belt ( type , points , gap = 0 , gap_pos = undef , belt_colour = grey ( 20 ) , tooth_colour = grey ( 50 ) ) { //! Draw a belt path given a set of points and pitch radii where the pulleys are. Closed loop unless a gap is specified
2019-06-08 17:10:47 -04:00
width = belt_width ( type ) ;
pitch = belt_pitch ( type ) ;
thickness = belt_thickness ( type ) ;
part = str ( type [ 0 ] , pitch ) ;
2020-08-22 06:16:56 -04:00
vitamin ( str ( "belt(" , no_point ( part ) , "x" , width , ", " , points , arg ( gap , 0 ) , arg ( gap_pos , undef ) , "): Belt " , part , " x " , width , "mm x " , length , "mm" ) ) ;
2019-06-08 17:10:47 -04:00
len = len ( points ) ;
tangents = rounded_polygon_tangents ( points ) ;
length = ceil ( ( rounded_polygon_length ( points , tangents ) - gap ) / pitch ) * pitch ;
module shape ( ) rounded_polygon ( points , tangents ) ;
2020-08-22 04:45:13 -04:00
ph = belt_pitch_height ( type ) ;
th = belt_tooth_height ( type ) ;
2019-06-08 17:10:47 -04:00
module gap ( )
if ( gap )
2020-08-22 06:16:56 -04:00
translate ( [ gap_pos . x , gap_pos . y ] )
rotate ( is_undef ( gap_pos . z ) ? 0 : gap_pos . z )
translate ( [ 0 , ph - thickness / 2 ] )
square ( [ gap , thickness + eps ] , center = true ) ;
2019-06-08 17:10:47 -04:00
color ( belt_colour )
2020-03-29 15:18:57 -04:00
linear_extrude ( width , center = true )
2019-06-08 17:10:47 -04:00
difference ( ) {
2020-08-22 04:45:13 -04:00
offset ( - ph + thickness ) shape ( ) ;
offset ( - ph + th ) shape ( ) ;
2019-06-08 17:10:47 -04:00
gap ( ) ;
}
2020-08-22 06:16:56 -04:00
2019-06-08 17:10:47 -04:00
color ( tooth_colour )
2020-03-29 15:18:57 -04:00
linear_extrude ( width , center = true )
2019-06-08 17:10:47 -04:00
difference ( ) {
2020-08-22 04:45:13 -04:00
offset ( - ph + th ) shape ( ) ;
offset ( - ph ) shape ( ) ;
2019-06-08 17:10:47 -04:00
gap ( ) ;
}
}
function belt_length ( points , gap = 0 ) = rounded_polygon_length ( points , rounded_polygon_tangents ( points ) ) - gap ; //! Compute belt length given path and optional gap