title=CAD|code=
// Here we define the user editable parameters:
function getParameterDefinitions() {
return [
{ type: 'float', name: 'beam_width', caption: 'Beam width', default: 40 },
{ type: 'float', name: 'hole_radius', caption: 'Radius of holes', default: 6 },
{ type: 'choice', name: 'length', caption: 'Frame length (holes)', values: [2,3,4,5,10,15,20,25,30,40,50], captions: ["2","3","4","5","10","15","20","25","30","40","50"], default: 10 }
];
}
// zBeam(length) - create a vertical bitbeam strut 'length' long
// xBeam(length) - create a horizontal bitbeam strug along the X axis
// yBeam(length) - create a horizontal bitbeam strut along the Y axis
// translateBeam(beam, [x, y, z]) - translate bitbeam struts in X, Y, or Z axes in units 'beam_width'
var cylresolution=16;
var beam_width=38;
var hole_radius=8;
function main(params) {
cylresolution=(params.quality == "1")? 64:16;
beam_width=params.beam_width;
hole_radius=params.hole_radius;
return zBeam(params.length);
}
function xHole(i) {
return CSG.cylinder( {
start: [-1, beam_width/2, i*beam_width + beam_width/2],
end: [beam_width+1, beam_width/2, i*beam_width + beam_width/2],
radius: hole_radius,
resolution: cylresolution
} );
}
function yHole(i) {
return CSG.cylinder( {
start: [beam_width/2, -1, i*beam_width + beam_width/2],
end: [beam_width/2, beam_width+1, i*beam_width + beam_width/2],
radius: hole_radius,
resolution: cylresolution
} );
}
function zBeam(length) {
var cube = CSG.cube({
center: [beam_width/2, beam_width/2, (length*beam_width)/2],
radius: [beam_width/2, beam_width/2, (length*beam_width)/2]
});
var holes = [];
for (var i = 0; i < length; i++)
{
holes.push(xHole(i));
holes.push(yHole(i));
}
var beam = cube.subtract(holes);
beam.properties.myConnector = new CSG.Connector([10, 0, 0], [1, 0, 0], [0, 0, 1]);
return beam;
}
function yBeam(length) {
return translateBeam(zBeam(length).rotateX(-90), [0,0,1]);
}
function xBeam(length) {
return translateBeam(zBeam(length).rotateY(90), [0,0,1]);
}
function translateBeam(beam, t_vector) {
return beam.translate(t_vector.map(function(n) { return beam_width*n; }));
}