General updates (#5)
* Add wire posts * Add wire posts for the thumb. * Move teensy screw insert back * Thicken wire posts * Add model * Add in a projection for the bottom plate * Improved (but not perfect) support for Maltron spacings * Factor out the common code in key-place and key-position * Add another screw insert for a standard-size Teensy * Create a left-side model * 5x6 version with less tenting
This commit is contained in:
parent
29edd64d88
commit
e2b1568c84
|
@ -13,17 +13,17 @@
|
||||||
;; Shape parameters ;;
|
;; Shape parameters ;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
(def nrows 4)
|
(def nrows 5)
|
||||||
(def ncols 5)
|
(def ncols 6)
|
||||||
|
|
||||||
(def α (/ π 12)) ; curvature of the columns
|
(def α (/ π 12)) ; curvature of the columns
|
||||||
(def β (/ π 36)) ; curvature of the rows
|
(def β (/ π 36)) ; curvature of the rows
|
||||||
(def centerrow (- nrows 3)) ; controls front-back tilt
|
(def centerrow (- nrows 3)) ; controls front-back tilt
|
||||||
(def centercol 3) ; controls left-right tilt / tenting (higher number is more tenting)
|
(def centercol 2) ; controls left-right tilt / tenting (higher number is more tenting)
|
||||||
(def orthographic-x (> nrows 5)) ; for larger number of rows don't curve them in as much
|
(def tenting-angle (/ π 12)) ; or, change this for more precise tenting control
|
||||||
; (def orthographic-x true) ; controls curvature of rows
|
(def column-style
|
||||||
(def maltron-style false) ; use fixed angles for columns
|
(if (> nrows 5) :orthographic :standard)) ; options include :standard, :orthographic, and :fixed
|
||||||
(def maltron-angles [(deg2rad 10) (deg2rad 10) 0 0 0 (deg2rad -15) (deg2rad -15)]) ; starting point: http://patentimages.storage.googleapis.com/EP0219944A2/imgf0002.png
|
; (def column-style :fixed)
|
||||||
|
|
||||||
(defn column-offset [column] (cond
|
(defn column-offset [column] (cond
|
||||||
(= column 2) [0 2.82 -4.5]
|
(= column 2) [0 2.82 -4.5]
|
||||||
|
@ -32,7 +32,7 @@
|
||||||
|
|
||||||
(def thumb-offsets [6 -3 7])
|
(def thumb-offsets [6 -3 7])
|
||||||
|
|
||||||
(def keyboard-z-offset 9) ; controls height; original=24
|
(def keyboard-z-offset 14) ; controls overall height; original=9 with centercol=3; use 15 for centercol=2
|
||||||
|
|
||||||
(def extra-width 2.5) ; extra space between the base of keys; original= 2
|
(def extra-width 2.5) ; extra space between the base of keys; original= 2
|
||||||
(def extra-height 1.0) ; original= 0.5
|
(def extra-height 1.0) ; original= 0.5
|
||||||
|
@ -41,6 +41,16 @@
|
||||||
(def wall-xy-offset 5) ; offset in the x and/or y direction for the first downward-sloping part of the wall (negative)
|
(def wall-xy-offset 5) ; offset in the x and/or y direction for the first downward-sloping part of the wall (negative)
|
||||||
(def wall-thickness 2) ; wall thickness parameter; originally 5
|
(def wall-thickness 2) ; wall thickness parameter; originally 5
|
||||||
|
|
||||||
|
;; Settings for column-style == :fixed
|
||||||
|
;; The defaults roughly match Maltron settings
|
||||||
|
;; http://patentimages.storage.googleapis.com/EP0219944A2/imgf0002.png
|
||||||
|
;; Fixed-z overrides the z portion of the column ofsets above.
|
||||||
|
;; NOTE: THIS DOESN'T WORK QUITE LIKE I'D HOPED.
|
||||||
|
(def fixed-angles [(deg2rad 10) (deg2rad 10) 0 0 0 (deg2rad -15) (deg2rad -15)])
|
||||||
|
(def fixed-x [-41.5 -22.5 0 20.3 41.4 65.5 89.6]) ; relative to the middle finger
|
||||||
|
(def fixed-z [12.1 8.3 0 5 10.7 14.5 17.5])
|
||||||
|
(def fixed-tenting (deg2rad 0))
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;; General variables ;;
|
;; General variables ;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
@ -144,25 +154,63 @@
|
||||||
(def column-x-delta (+ -1 (- (* column-radius (Math/sin β)))))
|
(def column-x-delta (+ -1 (- (* column-radius (Math/sin β)))))
|
||||||
(def column-base-angle (* β (- centercol 2)))
|
(def column-base-angle (* β (- centercol 2)))
|
||||||
|
|
||||||
(defn key-place [column row shape]
|
(defn apply-key-geometry [translate-fn rotate-x-fn rotate-y-fn column row shape]
|
||||||
(let [row-placed-shape (->> shape
|
(let [column-angle (* β (- centercol column))
|
||||||
(translate [0 0 (- row-radius)])
|
placed-shape (->> shape
|
||||||
(rotate (* α (- centerrow row)) [1 0 0])
|
(translate-fn [0 0 (- row-radius)])
|
||||||
(translate [0 0 row-radius]))
|
(rotate-x-fn (* α (- centerrow row)))
|
||||||
column-angle (* β (- centercol column))
|
(translate-fn [0 0 row-radius])
|
||||||
placed-shape (->> row-placed-shape
|
(translate-fn [0 0 (- column-radius)])
|
||||||
(translate [0 0 (- column-radius)])
|
(rotate-y-fn column-angle)
|
||||||
(rotate column-angle [0 1 0])
|
(translate-fn [0 0 column-radius])
|
||||||
(translate [0 0 column-radius])
|
(translate-fn (column-offset column)))
|
||||||
(translate (column-offset column)))
|
|
||||||
column-z-delta (* column-radius (- 1 (Math/cos column-angle)))
|
column-z-delta (* column-radius (- 1 (Math/cos column-angle)))
|
||||||
placed-shape-ortho (->> row-placed-shape
|
placed-shape-ortho (->> shape
|
||||||
(rotate (if maltron-style (+ column-base-angle (nth maltron-angles column)) column-angle) [0 1 0])
|
(translate-fn [0 0 (- row-radius)])
|
||||||
(translate [(- (* (- column centercol) column-x-delta)) 0 column-z-delta])
|
(rotate-x-fn (* α (- centerrow row)))
|
||||||
(translate (column-offset column)))]
|
(translate-fn [0 0 row-radius])
|
||||||
(->> (if (or maltron-style orthographic-x) placed-shape-ortho placed-shape)
|
(rotate-y-fn column-angle)
|
||||||
(rotate (/ π 12) [0 1 0])
|
(translate-fn [(- (* (- column centercol) column-x-delta)) 0 column-z-delta])
|
||||||
(translate [0 0 keyboard-z-offset]))))
|
(translate-fn (column-offset column)))
|
||||||
|
placed-shape-fixed (->> shape
|
||||||
|
(rotate-y-fn (nth fixed-angles column))
|
||||||
|
(translate-fn [(nth fixed-x column) 0 (nth fixed-z column)])
|
||||||
|
(translate-fn [0 0 (- (+ row-radius (nth fixed-z column)))])
|
||||||
|
(rotate-x-fn (* α (- centerrow row)))
|
||||||
|
(translate-fn [0 0 (+ row-radius (nth fixed-z column))])
|
||||||
|
(rotate-y-fn fixed-tenting)
|
||||||
|
(translate-fn [0 (second (column-offset column)) 0])
|
||||||
|
)]
|
||||||
|
(->> (case column-style
|
||||||
|
:orthographic placed-shape-ortho
|
||||||
|
:fixed placed-shape-fixed
|
||||||
|
placed-shape)
|
||||||
|
(rotate-y-fn tenting-angle)
|
||||||
|
(translate-fn [0 0 keyboard-z-offset]))))
|
||||||
|
|
||||||
|
(defn key-place [column row shape]
|
||||||
|
(apply-key-geometry translate
|
||||||
|
(fn [angle obj] (rotate angle [1 0 0] obj))
|
||||||
|
(fn [angle obj] (rotate angle [0 1 0] obj))
|
||||||
|
column row shape))
|
||||||
|
|
||||||
|
(defn rotate-around-x [angle position]
|
||||||
|
(mmul
|
||||||
|
[[1 0 0]
|
||||||
|
[0 (Math/cos angle) (- (Math/sin angle))]
|
||||||
|
[0 (Math/sin angle) (Math/cos angle)]]
|
||||||
|
position))
|
||||||
|
|
||||||
|
(defn rotate-around-y [angle position]
|
||||||
|
(mmul
|
||||||
|
[[(Math/cos angle) 0 (Math/sin angle)]
|
||||||
|
[0 1 0]
|
||||||
|
[(- (Math/sin angle)) 0 (Math/cos angle)]]
|
||||||
|
position))
|
||||||
|
|
||||||
|
(defn key-position [column row position]
|
||||||
|
(apply-key-geometry (partial map +) rotate-around-x rotate-around-y column row position))
|
||||||
|
|
||||||
|
|
||||||
(def key-holes
|
(def key-holes
|
||||||
(apply union
|
(apply union
|
||||||
|
@ -182,40 +230,6 @@
|
||||||
(->> (sa-cap (if (= column 5) 1 1))
|
(->> (sa-cap (if (= column 5) 1 1))
|
||||||
(key-place column row)))))
|
(key-place column row)))))
|
||||||
|
|
||||||
(defn rotate-around-x [angle position]
|
|
||||||
(mmul
|
|
||||||
[[1 0 0]
|
|
||||||
[0 (Math/cos angle) (- (Math/sin angle))]
|
|
||||||
[0 (Math/sin angle) (Math/cos angle)]]
|
|
||||||
position))
|
|
||||||
|
|
||||||
(defn rotate-around-y [angle position]
|
|
||||||
(mmul
|
|
||||||
[[(Math/cos angle) 0 (Math/sin angle)]
|
|
||||||
[0 1 0]
|
|
||||||
[(- (Math/sin angle)) 0 (Math/cos angle)]]
|
|
||||||
position))
|
|
||||||
|
|
||||||
(defn key-position [column row position]
|
|
||||||
(let [row-position (->> position
|
|
||||||
(map + [0 0 (- row-radius)])
|
|
||||||
(rotate-around-x (* α (- centerrow row)))
|
|
||||||
(map + [0 0 row-radius]))
|
|
||||||
column-angle (* β (- centercol column))
|
|
||||||
placed-position (->> row-position
|
|
||||||
(map + [0 0 (- column-radius)])
|
|
||||||
(rotate-around-y column-angle)
|
|
||||||
(map + [0 0 column-radius])
|
|
||||||
(map + (column-offset column)))
|
|
||||||
column-z-delta (* column-radius (- 1 (Math/cos column-angle)))
|
|
||||||
placed-position-ortho (->> row-position
|
|
||||||
(rotate-around-y (if maltron-style (+ column-base-angle (nth maltron-angles column)) column-angle))
|
|
||||||
(map + [(- (* (- column centercol) column-x-delta)) 0 column-z-delta])
|
|
||||||
(map + (column-offset column)))]
|
|
||||||
(->> (if (or maltron-style orthographic-x) placed-position-ortho placed-position)
|
|
||||||
(rotate-around-y (/ π 12))
|
|
||||||
(map + [0 0 keyboard-z-offset]))))
|
|
||||||
|
|
||||||
; (pr (rotate-around-y π [10 0 1]))
|
; (pr (rotate-around-y π [10 0 1]))
|
||||||
; (pr (key-position 1 cornerrow [(/ mount-width 2) (- (/ mount-height 2)) 0]))
|
; (pr (key-position 1 cornerrow [(/ mount-width 2) (- (/ mount-height 2)) 0]))
|
||||||
|
|
||||||
|
@ -664,22 +678,52 @@
|
||||||
(def screw-insert-bottom-radius (/ 5.31 2))
|
(def screw-insert-bottom-radius (/ 5.31 2))
|
||||||
(def screw-insert-top-radius (/ 5.1 2))
|
(def screw-insert-top-radius (/ 5.1 2))
|
||||||
(def screw-insert-holes (screw-insert-all-shapes screw-insert-bottom-radius screw-insert-top-radius screw-insert-height))
|
(def screw-insert-holes (screw-insert-all-shapes screw-insert-bottom-radius screw-insert-top-radius screw-insert-height))
|
||||||
(def screw-insert-outers (screw-insert-all-shapes (+ screw-insert-bottom-radius 1.6) (+ screw-insert-top-radius 1.6) (+ screw-insert-height 1.6)))
|
(def screw-insert-outers (screw-insert-all-shapes (+ screw-insert-bottom-radius 1.6) (+ screw-insert-top-radius 1.6) (+ screw-insert-height 1.5)))
|
||||||
|
(def screw-insert-screw-holes (screw-insert-all-shapes 1.7 1.7 350))
|
||||||
|
|
||||||
(defn teensy-screw-insert-place [shape]
|
(defn teensy-screw-insert-place [shape length]
|
||||||
(let [position (vec (map - teensy-bot-xy (map (partial * 0.3) (map - teensy-top-xy teensy-bot-xy))))]
|
(let [position (vec (map - teensy-bot-xy (map (partial * 0.3) (map - teensy-top-xy teensy-bot-xy))))]
|
||||||
(->> shape
|
(->> shape
|
||||||
(rotate (/ π 2) [0 -1 0])
|
(rotate (/ π 2) [0 -1 0])
|
||||||
(translate [(- 3 teensy-holder-width (/ screw-insert-height 2)) (- (+ teensy2-length 4)) 0])
|
(translate [(- 3 teensy-holder-width (/ screw-insert-height 2)) (- (+ length 7)) 0])
|
||||||
(rotate teensy-holder-angle [0 0 -1])
|
(rotate teensy-holder-angle [0 0 -1])
|
||||||
(translate [(first teensy-top-xy) (second teensy-top-xy) 15])
|
(translate [(first teensy-top-xy) (second teensy-top-xy) 15])
|
||||||
)))
|
)))
|
||||||
|
|
||||||
(def teensy-screw-insert-hole (teensy-screw-insert-place (cylinder [screw-insert-bottom-radius screw-insert-top-radius] (+ screw-insert-height 0.4))))
|
(def teensy-screw-insert-holes
|
||||||
(def teensy-screw-insert-outer (teensy-screw-insert-place (translate [0 0 1] (cylinder [(+ screw-insert-bottom-radius 1.6) (+ screw-insert-top-radius 1.6)] (+ screw-insert-height 2)))))
|
(union
|
||||||
|
(teensy-screw-insert-place (cylinder [screw-insert-bottom-radius screw-insert-top-radius] (+ screw-insert-height 0.4)) teensy-length)
|
||||||
|
(teensy-screw-insert-place (cylinder [screw-insert-bottom-radius screw-insert-top-radius] (+ screw-insert-height 0.4)) teensy2-length)))
|
||||||
|
(def teensy-screw-insert-outers
|
||||||
|
(union
|
||||||
|
(teensy-screw-insert-place (translate [0 0 1] (cylinder [(+ screw-insert-bottom-radius 1.6) (+ screw-insert-top-radius 1.6)] (+ screw-insert-height 1.7))) teensy-length)
|
||||||
|
(teensy-screw-insert-place (translate [0 0 1] (cylinder [(+ screw-insert-bottom-radius 1.6) (+ screw-insert-top-radius 1.6)] (+ screw-insert-height 1.7))) teensy2-length)))
|
||||||
|
|
||||||
(spit "things/right.scad"
|
|
||||||
(write-scad (difference
|
(def wire-post-height 7)
|
||||||
|
(def wire-post-overhang 3.5)
|
||||||
|
(def wire-post-diameter 2.6)
|
||||||
|
(defn wire-post [direction offset]
|
||||||
|
(->> (union (translate [0 (* wire-post-diameter -0.5 direction) 0] (cube wire-post-diameter wire-post-diameter wire-post-height))
|
||||||
|
(translate [0 (* wire-post-overhang -0.5 direction) (/ wire-post-height -2)] (cube wire-post-diameter wire-post-overhang wire-post-diameter)))
|
||||||
|
(translate [0 (- offset) (+ (/ wire-post-height -2) 3) ])
|
||||||
|
(rotate (/ α -2) [1 0 0])
|
||||||
|
(translate [3 (/ mount-height -2) 0])))
|
||||||
|
|
||||||
|
(def wire-posts
|
||||||
|
(union
|
||||||
|
(thumb-ml-place (translate [-5 0 -2] (wire-post 1 0)))
|
||||||
|
(thumb-ml-place (translate [ 0 0 -2.5] (wire-post -1 6)))
|
||||||
|
(thumb-ml-place (translate [ 5 0 -2] (wire-post 1 0)))
|
||||||
|
(for [column (range 0 lastcol)
|
||||||
|
row (range 0 cornerrow)]
|
||||||
|
(union
|
||||||
|
(key-place column row (translate [-5 0 0] (wire-post 1 0)))
|
||||||
|
(key-place column row (translate [0 0 0] (wire-post -1 6)))
|
||||||
|
(key-place column row (translate [5 0 0] (wire-post 1 0)))))))
|
||||||
|
|
||||||
|
|
||||||
|
(def model-right (difference
|
||||||
(union
|
(union
|
||||||
key-holes
|
key-holes
|
||||||
connectors
|
connectors
|
||||||
|
@ -688,21 +732,27 @@
|
||||||
(difference (union (difference
|
(difference (union (difference
|
||||||
(union case-walls
|
(union case-walls
|
||||||
screw-insert-outers
|
screw-insert-outers
|
||||||
teensy-screw-insert-outer)
|
teensy-screw-insert-outers)
|
||||||
teensy-holder-hole)
|
teensy-holder-hole)
|
||||||
teensy-holder)
|
teensy-holder)
|
||||||
rj9-space
|
rj9-space
|
||||||
usb-cutout
|
usb-cutout
|
||||||
teensy-screw-insert-hole
|
teensy-screw-insert-holes
|
||||||
screw-insert-holes)
|
screw-insert-holes)
|
||||||
rj9-holder
|
rj9-holder
|
||||||
|
wire-posts
|
||||||
; thumbcaps
|
; thumbcaps
|
||||||
; caps
|
; caps
|
||||||
)
|
)
|
||||||
(translate [0 0 -20] (cube 350 350 40))
|
(translate [0 0 -20] (cube 350 350 40))
|
||||||
; (translate [0 0 -150] (cube 5 5 20))
|
))
|
||||||
)))
|
|
||||||
|
(spit "things/right.scad"
|
||||||
|
(write-scad model-right))
|
||||||
|
|
||||||
|
(spit "things/left.scad"
|
||||||
|
(write-scad (mirror [-1 0 0] model-right)))
|
||||||
|
|
||||||
(spit "things/right-test.scad"
|
(spit "things/right-test.scad"
|
||||||
(write-scad
|
(write-scad
|
||||||
(union
|
(union
|
||||||
|
@ -711,37 +761,15 @@
|
||||||
thumb
|
thumb
|
||||||
thumb-connectors
|
thumb-connectors
|
||||||
case-walls
|
case-walls
|
||||||
teensy-holder
|
thumbcaps
|
||||||
; teensy-holder-hole
|
caps
|
||||||
screw-insert-outers
|
; teensy-holder
|
||||||
teensy-screw-insert-hole
|
; ; teensy-holder-hole
|
||||||
teensy-screw-insert-outer
|
; screw-insert-outers
|
||||||
usb-cutout
|
; teensy-screw-insert-holes
|
||||||
rj9-space
|
; teensy-screw-insert-outers
|
||||||
|
; usb-cutout
|
||||||
|
; rj9-space
|
||||||
|
; wire-posts
|
||||||
)))
|
)))
|
||||||
|
|
||||||
; (spit "things/test.scad"
|
|
||||||
; (write-scad (intersection (translate [29 -5 0] (cube 30 30 30))
|
|
||||||
; (difference (union case-walls screw-insert-outers)
|
|
||||||
; screw-insert-holes)
|
|
||||||
; )))
|
|
||||||
|
|
||||||
; (spit "things/test.scad"
|
|
||||||
; (write-scad screw-insert-holes))
|
|
||||||
|
|
||||||
; (spit "things/test-half.scad"
|
|
||||||
; (write-scad (difference
|
|
||||||
; (union
|
|
||||||
; key-holes
|
|
||||||
; connectors
|
|
||||||
; thumb
|
|
||||||
; thumb-connectors
|
|
||||||
; (difference (union case-walls screw-insert-outers)
|
|
||||||
; ; rj9-space
|
|
||||||
; usb-cutout
|
|
||||||
; screw-insert-holes)
|
|
||||||
; ; rj9-holder
|
|
||||||
; ; (if (= nrows 4) teensy-holder)
|
|
||||||
; )
|
|
||||||
; (translate [0 0 -5] (cube 350 350 40))
|
|
||||||
; )))
|
|
31942
things/right-4x5.stl
31942
things/right-4x5.stl
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue