37 lines
1 KiB
Clojure
37 lines
1 KiB
Clojure
(ns threedvis.core
|
|
(:require [scad-clj.model :refer :all]
|
|
[scad-clj.scad :refer :all]))
|
|
|
|
(defn print-scad [shape]
|
|
(spit "threedvis.scad" (write-scad shape)))
|
|
|
|
(defn led []
|
|
(union
|
|
(color [0.5 0.5 2]
|
|
(difference
|
|
(union
|
|
(cylinder 10 20)
|
|
(translate [0 0 10] (sphere 10))
|
|
(translate [0 0 -8] (cylinder 13 4)))
|
|
(translate [0 13 -7] (cube 30 5 10))))
|
|
(color [0.3 0.3 0.3]
|
|
(union
|
|
(translate [0 5 -30] (cylinder 1.5 50))
|
|
(translate [7 5 -60] (rotate (/ pi 4) [0 -1 0] (cylinder 1.5 20))))
|
|
(translate [14 5 -122] (cylinder 1.5 110))
|
|
(union
|
|
(translate [0 -5 -10] (cylinder 1.5 15))
|
|
(translate [0 -44 -17] (rotate (/ pi 2) [1 0 0] (cylinder 1.5 80)))))))
|
|
|
|
(defn one-pos []
|
|
(union
|
|
(translate [0 0 0] (led))
|
|
(translate [0 0 100] (led))
|
|
(translate [0 0 200] (led))))
|
|
|
|
(print-scad
|
|
(union
|
|
(translate [0 0 0] (one-pos))
|
|
(translate [0 100 0] (one-pos))
|
|
(translate [0 200 0] (one-pos))))
|