example007.scad

Download example007.stl

File Content

module cutout()
{
    intersection() {
      rotate(90, [1, 0, 0])
        translate([0, 0, -50])
          linear_extrude(height = 100, convexity = 1)
            import(file = "example007.dxf", layer = "cutout1");
      
      rotate(90, [0, 0, 1])
        rotate(90, [1, 0, 0])
          translate([0, 0, -50])
            linear_extrude(height = 100, convexity = 2)
              import(file = "example007.dxf", layer = "cutout2");
    }
}

module clip()
{
  difference() {
    rotate_extrude(convexity = 3, $fn = 0, $fa = 12, $fs = 2) {
      import(file = "example007.dxf", layer = "dorn");
    }
    for (r = [0, 90])
      rotate(r, [0, 0, 1])
        cutout();
  }
}

module cutview()
{
  difference() {
    difference() {
      translate([0, 0, -10]) clip();

      rotate(20, [0, 0, 1])
        rotate(-20, [0, 1, 0])
          translate([18, 0, 0])
            cube(30, center = true);
    }

    # render(convexity = 5) intersection() {
      translate([0, 0, -10])
        clip();
    
      rotate(20, [0, 0, 1])
        rotate(-20, [0, 1, 0])
          translate([18, 0, 0])
            cube(30, center = true);
    }
  }
}

echo(version=version());

translate([0, 0, -10]) clip();

// cutview();

// Written by Clifford Wolf  and Marius
// Kintel 
//
// To the extent possible under law, the author(s) have dedicated all
// copyright and related and neighboring rights to this software to the
// public domain worldwide. This software is distributed without any
// warranty.
//
// You should have received a copy of the CC0 Public Domain
// Dedication along with this software.
// If not, see .