Update dactyl.clj

-Renamed "default" thumb to "manuform" thumb
-Removed some unused code
-Modified case to accommodate old MCU holder
-Set default shape parameters to vanilla
-Modified screw positions
This commit is contained in:
♥ Minnie ♥ 2024-05-20 21:42:00 +08:00
parent f483c598e0
commit 6e3ddbd99c
No known key found for this signature in database

View file

@ -13,8 +13,8 @@
;; Shape parameters ;; ;; Shape parameters ;;
;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;
(def nrows 5) (def nrows 4)
(def ncols 7) (def ncols 5)
(def α (/ π 12)) ; curvature of the columns (def α (/ π 12)) ; curvature of the columns
(def β (/ π 36)) ; curvature of the rows (def β (/ π 36)) ; curvature of the rows
@ -22,13 +22,13 @@
(def centercol 4) ; controls left-right tilt / tenting (higher number is more tenting) (def centercol 4) ; controls left-right tilt / tenting (higher number is more tenting)
(def tenting-angle (/ π 12)) ; or, change this for more precise tenting control (def tenting-angle (/ π 12)) ; or, change this for more precise tenting control
(def pinky-15u true) ; controls whether the outer column uses 1.5u keys (def pinky-15u false) ; controls whether the outer column uses 1.5u keys
(def first-15u-row 0) ; controls which should be the first row to have 1.5u keys on the outer column (def first-15u-row 0) ; controls which should be the first row to have 1.5u keys on the outer column
(def last-15u-row 3) ; controls which should be the last row to have 1.5u keys on the outer column (def last-15u-row 3) ; controls which should be the last row to have 1.5u keys on the outer column
(def extra-row true) ; adds an extra bottom row to the outer columns (def extra-row false) ; adds an extra bottom row to the outer column(s)
(def inner-column true) ; adds an extra inner column (two less rows than nrows) (def inner-column false) ; adds an extra inner column (two less rows than nrows)
(def thumb-style "cf") ; toggles between "default", "mini", and "cf" thumb cluster (def thumb-style "manuform") ; toggles between "manuform", "mini", and "cf" thumb cluster
(def column-style :standard) (def column-style :standard)
@ -49,20 +49,10 @@
(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
(def wall-z-offset -8) ; length of the first downward-sloping part of the wall (negative) (def wall-z-offset -8) ; length of 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-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))
; If you use Cherry MX or Gateron switches, this can be turned on. ; If you use Cherry MX or Gateron switches, this can be turned on.
; If you use other switches such as Kailh, you should set this as false ; If you use other switches such as Kailh, you should set this as false
(def create-side-nubs? false) (def create-side-nubs? false)
@ -210,26 +200,8 @@
(rotate-y-fn column-angle) (rotate-y-fn column-angle)
(translate-fn [0 0 column-radius]) (translate-fn [0 0 column-radius])
(translate-fn (column-offset column))) (translate-fn (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 (->> shape (->> (case column-style placed-shape)
(translate-fn [0 0 (- row-radius)])
(rotate-x-fn (* α (- centerrow row)))
(translate-fn [0 0 row-radius])
(rotate-y-fn column-angle)
(translate-fn [(- (* (- column centercol) column-x-delta)) 0 column-z-delta])
(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) (rotate-y-fn tenting-angle)
(translate-fn [0 0 keyboard-z-offset])))) (translate-fn [0 0 keyboard-z-offset]))))
@ -424,9 +396,9 @@
(key-place (inc column) row web-post-bl) (key-place (inc column) row web-post-bl)
(key-place column row web-post-br))))))) (key-place column row web-post-br)))))))
;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;
;; Default Thumb ;; ;; Manuform Thumb ;;
;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;
(def thumborigin (def thumborigin
(map + (key-position (+ innercol-offset 1) cornerrow [(/ mount-width 2) (- (/ mount-height 2)) 0]) (map + (key-position (+ innercol-offset 1) cornerrow [(/ mount-width 2) (- (/ mount-height 2)) 0])
@ -776,7 +748,7 @@
(key-place (+ innercol-offset 4) cornerrow web-post-bl)))))) (key-place (+ innercol-offset 4) cornerrow web-post-bl))))))
;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;
;; cf Thumb ;; ;; CF Thumb ;;
;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;
(defn cfthumb-tl-place [shape] (defn cfthumb-tl-place [shape]
@ -952,7 +924,7 @@
(key-place (+ innercol-offset 4) cornerrow web-post-bl)))))) (key-place (+ innercol-offset 4) cornerrow web-post-bl))))))
;switching connectors, switchplates, etc. depending on thumb-style used ;switching connectors, switchplates, etc. depending on thumb-style used
(when (= thumb-style "default") (when (= thumb-style "manuform")
(def thumb-type thumb) (def thumb-type thumb)
(def thumb-connector-type thumb-connectors) (def thumb-connector-type thumb-connectors)
(def thumbcaps-type thumbcaps) (def thumbcaps-type thumbcaps)
@ -982,7 +954,7 @@
(defn bottom-hull [& p] (defn bottom-hull [& p]
(hull p (bottom 0.001 p))) (hull p (bottom 0.001 p)))
(def left-wall-x-offset 4) (def left-wall-x-offset (if inner-column 4 9))
(def left-wall-z-offset 1) (def left-wall-z-offset 1)
(defn left-key-position [row direction] (defn left-key-position [row direction]
@ -1059,13 +1031,14 @@
(key-wall-brace lastcol extra-cornerrow 0 -1 web-post-br lastcol extra-cornerrow 1 0 web-post-br) (key-wall-brace lastcol extra-cornerrow 0 -1 web-post-br lastcol extra-cornerrow 1 0 web-post-br)
))) )))
(def cf-thumb-offset (if inner-column -0.3 -1.7))
(def cf-thumb-wall (def cf-thumb-wall
(union (union
; thumb walls ; thumb walls
(wall-brace cfthumb-mr-place 0 -1 web-post-br cfthumb-tr-place 0 -1 web-post-br) (wall-brace cfthumb-mr-place 0 -1 web-post-br cfthumb-tr-place 0 -1 web-post-br)
(wall-brace cfthumb-mr-place 0 -1 web-post-br cfthumb-mr-place 0 -1.15 web-post-bl) (wall-brace cfthumb-mr-place 0 -1 web-post-br cfthumb-mr-place 0 -1.15 web-post-bl)
(wall-brace cfthumb-br-place 0 -1 web-post-br cfthumb-br-place 0 -1 web-post-bl) (wall-brace cfthumb-br-place 0 -1 web-post-br cfthumb-br-place 0 -1 web-post-bl)
(wall-brace cfthumb-bl-place -0.3 1 thumb-post-tr cfthumb-bl-place 0 1 thumb-post-tl) (wall-brace cfthumb-bl-place cf-thumb-offset 1 thumb-post-tr cfthumb-bl-place 0 1 thumb-post-tl)
(wall-brace cfthumb-br-place -1 0 web-post-tl cfthumb-br-place -1 0 web-post-bl) (wall-brace cfthumb-br-place -1 0 web-post-tl cfthumb-br-place -1 0 web-post-bl)
(wall-brace cfthumb-bl-place -1 0 thumb-post-tl cfthumb-bl-place -1 0 web-post-bl) (wall-brace cfthumb-bl-place -1 0 thumb-post-tl cfthumb-bl-place -1 0 web-post-bl)
; cfthumb corners ; cfthumb corners
@ -1079,13 +1052,13 @@
(bottom-hull (bottom-hull
(left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate2 -1 0) web-post)) (left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate2 -1 0) web-post))
(left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate3 -1 0) web-post)) (left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate3 -1 0) web-post))
(cfthumb-bl-place (translate (wall-locate2 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate2 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-bl-place (translate (wall-locate3 -0.3 1) thumb-post-tr))) (cfthumb-bl-place (translate (wall-locate3 cf-thumb-offset 1) thumb-post-tr)))
(hull (hull
(left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate2 -1 0) web-post)) (left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate2 -1 0) web-post))
(left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate3 -1 0) web-post)) (left-key-place (- cornerrow innercol-offset) -1 (translate (wall-locate3 -1 0) web-post))
(cfthumb-bl-place (translate (wall-locate2 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate2 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-bl-place (translate (wall-locate3 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate3 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-ml-place thumb-post-tl)) (cfthumb-ml-place thumb-post-tl))
(hull (hull
(left-key-place (- cornerrow innercol-offset) -1 web-post) (left-key-place (- cornerrow innercol-offset) -1 web-post)
@ -1100,9 +1073,9 @@
(cfthumb-ml-place thumb-post-tl)) (cfthumb-ml-place thumb-post-tl))
(hull (hull
(cfthumb-bl-place thumb-post-tr) (cfthumb-bl-place thumb-post-tr)
(cfthumb-bl-place (translate (wall-locate1 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate1 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-bl-place (translate (wall-locate2 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate2 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-bl-place (translate (wall-locate3 -0.3 1) thumb-post-tr)) (cfthumb-bl-place (translate (wall-locate3 cf-thumb-offset 1) thumb-post-tr))
(cfthumb-ml-place thumb-post-tl)) (cfthumb-ml-place thumb-post-tl))
; connectors below the inner column to the thumb & second column ; connectors below the inner column to the thumb & second column
(if inner-column (if inner-column
@ -1189,7 +1162,7 @@
(key-place 1 cornerrow web-post-bl) (key-place 1 cornerrow web-post-bl)
(minithumb-tl-place minithumb-post-tl)))))) (minithumb-tl-place minithumb-post-tl))))))
(def default-thumb-wall (def manuform-thumb-wall
(union (union
; thumb walls ; thumb walls
(wall-brace thumb-mr-place 0 -1 web-post-br thumb-tr-place 0 -1 thumb-post-br) (wall-brace thumb-mr-place 0 -1 web-post-br thumb-tr-place 0 -1 thumb-post-br)
@ -1260,7 +1233,7 @@
;switching walls depending on thumb-style used ;switching walls depending on thumb-style used
(def thumb-wall-type (def thumb-wall-type
(case thumb-style (case thumb-style
"default" default-thumb-wall "manuform" manuform-thumb-wall
"cf" cf-thumb-wall "cf" cf-thumb-wall
"mini" mini-thumb-wall)) "mini" mini-thumb-wall))
@ -1284,8 +1257,8 @@
(left-key-place y 1 web-post) (left-key-place y 1 web-post)
(left-key-place (dec y) -1 web-post) (left-key-place (dec y) -1 web-post)
))) )))
(wall-brace (partial key-place 0 0) 0 1 web-post-tl (partial left-key-place 0 1) -0.6 1 web-post) (wall-brace (partial key-place 0 0) 0 1 web-post-tl (partial left-key-place 0 1) (if inner-column -0.6 -0.3) (if inner-column 1 1.3) web-post)
(wall-brace (partial left-key-place 0 1) -0.6 1 web-post (partial left-key-place 0 1) -1 0 web-post) (wall-brace (partial left-key-place 0 1) (if inner-column -0.6 -0.3) (if inner-column 1 1.3) web-post (partial left-key-place 0 1) -1 0 web-post)
; front wall ; front wall
(key-wall-brace (+ innercol-offset 3) lastrow 0 -1 web-post-bl (+ innercol-offset 3) lastrow 0 -1 web-post-br) (key-wall-brace (+ innercol-offset 3) lastrow 0 -1 web-post-bl (+ innercol-offset 3) lastrow 0 -1 web-post-br)
(key-wall-brace (+ innercol-offset 3) lastrow 0 -1 web-post-br (+ innercol-offset 4) extra-cornerrow 0 -1 web-post-bl) (key-wall-brace (+ innercol-offset 3) lastrow 0 -1 web-post-br (+ innercol-offset 4) extra-cornerrow 0 -1 web-post-bl)
@ -1297,10 +1270,8 @@
(def holder-offset (def holder-offset
(case nrows (case nrows
4 -3.5 4 -3.5
5 0 5 (if inner-column 0 -6.5)
6 (if inner-column 6 (if inner-column 3.2 2.2)))
3.2
2.2)))
(def notch-offset (def notch-offset
(case nrows (case nrows
@ -1344,7 +1315,7 @@
(def screw-offset-tr [-3.5 6.5 0]) (def screw-offset-tr [-3.5 6.5 0])
(def screw-offset-br [-3.5 -6.5 0])) (def screw-offset-br [-3.5 -6.5 0]))
(when (and (false? pinky-15u) (false? extra-row)) (when (and (false? pinky-15u) (false? extra-row))
(def screw-offset-tr [-4 6.5 0]) (def screw-offset-tr [-2 6.5 0])
(def screw-offset-br [-6 13 0])) (def screw-offset-br [-6 13 0]))
; Offsets for the screw inserts dependent on thumb-style & inner-column ; Offsets for the screw inserts dependent on thumb-style & inner-column
@ -1353,7 +1324,7 @@
(def screw-offset-tm [9.5 -4.5 0]) (def screw-offset-tm [9.5 -4.5 0])
(def screw-offset-bm [13 -7 0])) (def screw-offset-bm [13 -7 0]))
(when (and (= thumb-style "cf") (false? inner-column)) (when (and (= thumb-style "cf") (false? inner-column))
(def screw-offset-bl [-7.7 2 0]) (def screw-offset-bl [-3.5 2 0])
(def screw-offset-tm [9.5 -4.5 0]) (def screw-offset-tm [9.5 -4.5 0])
(def screw-offset-bm [13 -7 0])) (def screw-offset-bm [13 -7 0]))
(when (and (= thumb-style "mini") inner-column) (when (and (= thumb-style "mini") inner-column)
@ -1364,12 +1335,12 @@
(def screw-offset-bl [-1 4.2 0]) (def screw-offset-bl [-1 4.2 0])
(def screw-offset-tm [9.5 -4.5 0]) (def screw-offset-tm [9.5 -4.5 0])
(def screw-offset-bm [-1 -7 0])) (def screw-offset-bm [-1 -7 0]))
(when (and (= thumb-style "default") inner-column) (when (and (= thumb-style "manuform") inner-column)
(def screw-offset-bl [5 -6 0]) (def screw-offset-bl [5 -6 0])
(def screw-offset-tm [9.5 -4.5 0]) (def screw-offset-tm [9.5 -4.5 0])
(def screw-offset-bm [8 -1 0])) (def screw-offset-bm [8 -1 0]))
(when (and (= thumb-style "default") (false? inner-column)) (when (and (= thumb-style "manuform") (false? inner-column))
(def screw-offset-bl [-11.7 -8 0]) (def screw-offset-bl [-8.7 -8 0])
(def screw-offset-tm [9.5 -4.5 0]) (def screw-offset-tm [9.5 -4.5 0])
(def screw-offset-bm [8 -1 0])) (def screw-offset-bm [8 -1 0]))