{"id":18862601,"url":"https://github.com/zk-phi/switch42-keyboard","last_synced_at":"2026-02-10T15:30:19.587Z","repository":{"id":152679726,"uuid":"164009113","full_name":"zk-phi/switch42-keyboard","owner":"zk-phi","description":"My first DIY keyboard / 3x6+3 split ortho","archived":false,"fork":false,"pushed_at":"2019-07-16T02:56:47.000Z","size":9484,"stargazers_count":9,"open_issues_count":0,"forks_count":1,"subscribers_count":3,"default_branch":"master","last_synced_at":"2024-12-30T21:15:18.436Z","etag":null,"topics":["keyboard"],"latest_commit_sha":null,"homepage":"","language":"OpenSCAD","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/zk-phi.png","metadata":{"files":{"readme":"Readme.markdown","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2019-01-03T18:32:02.000Z","updated_at":"2024-02-18T10:10:37.000Z","dependencies_parsed_at":null,"dependency_job_id":"91738fde-34fc-4e7d-9901-9ddf250af6b0","html_url":"https://github.com/zk-phi/switch42-keyboard","commit_stats":null,"previous_names":[],"tags_count":4,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zk-phi%2Fswitch42-keyboard","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zk-phi%2Fswitch42-keyboard/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zk-phi%2Fswitch42-keyboard/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zk-phi%2Fswitch42-keyboard/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/zk-phi","download_url":"https://codeload.github.com/zk-phi/switch42-keyboard/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":239808125,"owners_count":19700440,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["keyboard"],"created_at":"2024-11-08T04:35:12.221Z","updated_at":"2026-02-10T15:30:19.528Z","avatar_url":"https://github.com/zk-phi.png","language":"OpenSCAD","readme":"Switch42 Keyboard の紹介＆組み立てガイド\n\n(これは基板バージョン rev3 ベースの紹介です)\n\n# 概要\n\n![Switch42](images/switch42.jpg)\n\nSwitch42 は zk-phi が初めて設計した自作キーボードキットです。\n\n以下の特徴があります：\n\n- 直行配列・分割キーボード\n\n- Corne Keyboard などとちょうど同じ 42 キー\n  - (ホームポジションからひとマスで到達できる行・列が過不足なくついています)\n\n- 指の腹で押せるよう、少し張り出して配置した親指キー\n\n- フルカラー LED / LED テープに対応\n\n- ProMicro を下部に格納し、スッキリした外観\n\n- MX 互換スイッチ専用\n\n- (非リバーシブル基板で表裏を間違いづらい)\n\nLED 以外には表面実装品を使わないので、組み立て難易度は初〜中級者向けだと思います。二箇所だけ一般的な自作キーボードキットには出てこない作業が登場します：\n\n- 基板の不要部分をカットする作業\n- Pro Micro と干渉する部品の足をカット・絶縁\n\n# 設計の経緯＆工夫など\n## なぜ作ったの？\n\nErgo42 で自作キーボードデビューしてから、よりキー数の少ない Corne に挑戦し、使っているうちにこんな実感が湧いてきました：\n\n- このキー数でも十分仕事になるけど、これより少ないくなると自分には辛いな\n  - = これがコンパクトさと実用性の落としどころだな\n\n6 x 3 + 3 というキー配列に大満足していた一方で、だんだんと Ergo42 の格子配列も恋しくなってきたりもして、ヨシそれなら「格子配列の 42 キー」を作ってみよう、と設計に挑戦しました。\n\nオリジナルな工夫もなにか入れたいなということで、以前から気になっていた「親指キー押しづらい問題」に対する自分なりのアイデア（張り出させて配置する）も盛り込んでみました。\n\nまた、それまで LED のハンダづけにビビってキーボードを光らせてこなかったのですが、自分で設計すればきっと試作基板がたくさん余るので失敗も怖くないぞ！ということで、初のキーボード設計から LED 対応に挑戦しました。\n\n同じ「格子配列＋親指キー」ということで、 コンセプトの近い MiniAxe を組むことも考えたのですが、以下のポイントが決め手になって、自分で設計することにしました：\n\n- ６列キーボードが絶対必要だったこと\n\n自分は Emacs のヘビーユーザーで、 Alt-Ctrl-, Alt-Shift- などの複雑な組み合わせにもいちいちショートカットを設定しているので、 Ctrl, Shift を小指で押せる仕様がマストでした。\n\n- Pro Micro を採用したかったこと\n\nMiniAxe は定番のマイコンボード \"Pro Micro\" を採用しない、より進んだ設計になっています。これによって、とても薄く、「モゲ」問題とも無縁なキーボードを実現しています。一方、半田付け難易度は Pro Micro を使用したキーボードよりも上がっていて、組み立てられるか不安だったのと、自分以上に初心者な友人に提供したかったこともあったので、オーソドックスな Pro Micro (コンスルー) を採用したいモチベーションがありました。\n\n## 設計上の工夫\n\nリバーシブル基板をやめて、代わりに基板の不要部分を切り取れるようにしました。もともとは ProMicro を下部に格納しつつコンスルーに対応するために考えた仕様でしたが、結果的に部品の向きを間違えるミスも減らせてよかったんじゃないかなと思っています。\n\n# 組み立てガイド\n## オプション\n\n以下の箇所は組み立て方に選択肢があるので、好みでカスタマイズしてください。\n\n- Pro Micro などを覆う底板を省略することで、 3mm ほど薄くすることができます\n\n- LED をつけることがきます (難しいです。つけなくても使えます)\n\n## 必要な部品 (両手分)\n\n- Switch42 専用部品\n  - 基板 2 枚\n  - トッププレート 2 枚\n  - ボトムプレート (穴あき) 2 枚 [左右別]\n  - 底板 (穴なし) 2 枚\n\n- 汎用電子部品\n  - ダイオード [1N4148 / 1N4148w] 42 個\n  - TRRS ジャック [MJ-4PP-9] 2 個\n  - タクトスイッチ [TVBP06] 2 個\n  - コンスルー (スプリングピンヘッダ) 付き Pro Micro 2 セット\n  - MX 互換キースイッチ 42 個\n  - MX スイッチ用キーキャップ 42 個\n  - 光らせたい場合はどちらか選択:\n    - WS2812B の LED テープ (幅 1cm) 2 本 [簡単]\n    - SK6812mini 42 個 [難しい]\n  - 絶縁テープ (カプトンテープなど)\n\n- ケースの組み立て材\n  - M2 スペーサ 7mm 10 本\n  - クッションゴム 10 個\n  - 底板をつけるどうかによって選択:\n    - M2 ネジ 5mm 20 本 [底板なし]\n    - M2 ネジ 8mm 20 本 [底板あり]\n\n- ケーブル類\n  - Micro USB ケーブル\n  - TRRS ケーブル\n\n- あると便利なもの\n  - マスキングテープ\n\n※ダイオードは表面実装品でもリード部品でも ok です。初めての場合はリード部品を選択しましょう。\n\n※コンスルーは必須ではないですが、リカバリや修理が簡単になるので強く推奨します\n\n## 主な爆死ポイント\n\n組み立てる時はチェックしましょう。\n\n- 定番\n  - ハンダ不良\n  - ProMicro / ダイオードの向き間違い\n  - トッププレートをはめずにキースイッチをつけてしまう\n  - TRRS ジャック、リセットスイッチをつける前にキースイッチをつけてしまう\n  - トッププレートを割る\n  - (ProMicro の MicroUSB 端子モゲ)\n\n- Switch42 特有\n  - 基板の不要部分をカットするときに、必要な部分も破壊してしまう\n  - 絶縁テープを貼り忘れる (コンスルーならリカバリー可)\n\n## 組み立て手順\n\n組み立ての手順を順に紹介してゆきます。\n\nハマりどころはなるべくフォローしてゆくつもりで書いていますが、半田付け自体の基本的な知識、たとえば道具の持ち方・使い方、ハンダ不良の見分け方などはより詳しい資料があるはずなので、そちらで復習しておくと確実です。\n\n### Pro Micro の準備\n#### Pro Micro にファームウェアを書き込む\n\nPro Micro にファームウェアを書き込みます。\n\n私のリポジトリ (https://github.com/zk-phi/qmk_firmware) からコードをダウンロード後、QMK Firmware の公式ページを参考に環境を構築します。\n\nキーボードを光らせるためにテープ LED を使用する場合、 qmk_firmware/keyboards/switch42/keymaps/default/config.h の「USE_BAKCLIGHT」 の行をコメントアウトします。\n\n![promicro_usb](images/promicro_usb.JPG)\n\n環境ができたら、 Pro Micro を USB で接続した上で\n\n```terminal\nmake switch42/rev1:default:avrdude\n```\n\nを実行し、 Pro Micro の `GND` ピンと `RST` ピンをピンセットなどでショートすることで書き込むことができます。\n\n初期不良の確認も兼ねて、２台とも書き込んでしまいましょう。後から書き換えも可能です。\n\n#### Pro Micro にコンスルーを立てる\n\nLED の動作確認ですぐに使うので、 Pro Micro にあらかじめコンスルーを取り付けておきます。\n\n向きが少しややこしいので注意して下さい：\n\nコンスルーのプラスチック部分に空いた穴に注目します。 *穴の空いている方が「Pro Micro」側になるように、また二つのコンスルーで穴が同じ方を向くように、* コンスルーを Pro Micro に差し込みます。 *Pro Micro の「部品が乗っている面と同じ面に」* コンスルーを立てます。\n\n斜めになってしまわないように注意しながら半田付けします。\n\n詳細は (Helix のビルドガイド)[https://github.com/MakotoKurauchi/helix/blob/master/Doc/buildguide_jp.md#pro-micro] に詳しいです。\n\n### PCB の準備\n\n基板は右手用・左手用で同じものを使います。スイッチの乗りそうな四角がたくさん並んでいる方が表です。\n\n２枚の基板を同じ向きで（たとえば、表を上に）置いて、 *一方は左の、他方は右の、* 親指クラスタを落とします。同じ側を落として右手・右手や左手・左手のキーボードになってしまわないように注意してください。\n\n![pcb_cut](images/pcb_cut.jpg)\n\n力技で折ろうとすると、写真のように基板を損傷します。\n\n![pcb_broken](images/pcb_broken.jpg)\n\n*ニッパやカッターなどであらかじめ傷をつけて、* なるべく少ない力で折り取ります。切りしろ部分以外に傷をつけないように注意してください。最悪、そこを通っている配線を断線してしまうと、動作に問題が起こる場合があります (特に LED)。バリはある程度残したままでもケースに収められるようになっています。うっかり傷つけるくらいならそのままにしましょう。\n\n### SK6812mini をつける (光らせる場合)\n\nSK6812mini を半田付けしてゆきます。コの字の印のあるパッドが SK6812mini の Vcc になります。\n\n![sk68_soldering](images/sk68_soldering.jpg)\n\n基板の個体差で LED が穴に落ちてしまう場合、マスキングテープで軽く固定するとつけやすくなります。\n\n熱で壊れやすいので、高くとも 270 度程度に抑えて半田付けします。\n\n![led_order](images/led_order.jpg)\n\nLED は図のように直列に並んでいるので、一つ目から順に半田付けし、都度次のように動作確認すると安全です：\n\n1. 基板にコンスルー付き Pro Micro を差し込む\n2. USB ケーブルを刺して PC やモバイルバッテリーから電源を供給\n3. 光れば ok\n\n![sk68_light](images/sk68_light.jpg)\n\nPro Micro は写真のように、基板にプリントされた枠線に合わせて差し込みます。\n\nハンダは付いているのに光らない LED がある場合、おそらく熱で壊れているので、ハンダを丁寧に除去し、基板のパッドを剥がさないように慎重に LED だけを外します（外れない場合、無理に力を加えずに、ハンダを除去し直してください）。\n\n### ダイオードをつける\n\nキー数分のダイオードをつけてゆきます。表面実装品・リード部品から好みの方を選んで取り付けることができます。\n\nダイオードには向きがあるので注意してください。リード部品の場合、基板の表側から、印刷されたアイコンと同じ向きで挿入します。表面実装品の場合、基板裏面のパッドに、 *カソードがコの字の印のところに来るように* 乗せます。\n\n![diode](images/diode.jpg)\n\nLED をつけた場合、ここからはコテの温度を元に戻して構いませんが、 *高温のコテで LED に触ってしまって、せっかく取り付けた LED を破壊することがないように* 注意してください。\n\n余談ですが、プレート２枚と基板１枚を重ねると、ダイオードの足を曲げるのにちょうどいい厚さになります。\n\n![diode_bending](images/diode_bending.jpg)\n\n### リセットスイッチ、TRRS ジャック をつける\n\nリセットスイッチ、 TRRS ジャックをこの順にとりつけます。順番を間違えても致命傷にはなりませんが、先に背の高い部品をつけてしまうと、後から背の低い部品をつけるのは若干厄介です。\n\n![trrs_and_reset](images/trrs_and_reset.jpg)\n\n基板の裏面に取り付け位置の目印があるので、ここに取り付けます。\n\n### Pro Micro を差し込み、動作確認をする\n\n以降の手順を終えるとリカバリの難易度が一気に上がるので、ここで 一度 Pro Micro を装着し、動作確認をします。\n\n- [LED] LED が光るか\n- [ダイオード] スイッチが入る予定のピンをピンセットなどで直接ショートした時、キー入力が行われるか\n- [TRRS] TRRS ケーブルで左右を繋いだ時、 USB が直接刺さっていない側のキーボードからもキー入力ができるか\n- [リセットスイッチ] ファームウェア書き込み時のリセット操作を、タクトスイッチで代用できるか\n\n![testing](images/testing.jpg)\n\n### トッププレート・キースイッチをつける\n\n*トッププレートにキースイッチをはめ、* 基板とドッキングします。\n\n![switch_with_plate](images/switch_with_plate.jpg)\n\n![pcb_with_plate](images/pcb_with_plate.jpg)\n\nプレートの保護シートはスイッチをはめてから剥がすと、指紋をつけにくいです。\n\n![unvail](images/unvail.jpg)\n\nトッププレートを挟まずに直接スイッチを取り付けてしまうと、後からトッププートを組み込むことができなくなります。\n\n基板からスイッチが浮いてしまわないよう、しっかり押し付けます。プレートは基板に押しつける必要はありません。基板とプレートの間に 2mm ほど隙間がある状態が正しいです。\n\n無事ドッキングできたら、キースイッチを半田付けします。\n\nこのとき、 *Pro Micro が上に重なるところのスイッチだけは、あらかじめ足をカットしておき、基板とツライチで* （飛び出さないように）半田付けをします。その後、 *絶縁テープを貼って Pro Micro に触れないようにします* 。耐熱のカプトンテープなどがあれば理想的です (私はビニテを貼っています。。)。デザイン上の都合で Pro Micro をここに装着するしかなかったため、やむを得ずこのような手順になっています。\n\n![tape](images/tape.jpg)\n\n### LED テープをつける\n\nLED テープを使ってキーボードを光らせる場合、基板裏面のパッドに合わせて LED テープをベタッと貼り付け、半田付けします。 DOUT ではなく DIN を接続するように注意してください。\n\n![underglow](images/underglow.jpg)\n\nLED テープは長すぎる場合、適宜な箇所でカットすることができます。\n\n### Pro Micro を装着、ケースを組み立てる\n\nスイッチを無事取り付けることができたらハンダ作業はこれでおしまいです。Pro Micro をもう一度取り付け、ケースを組み立てます。\n\nトッププレートにネジを使ってスペーサーを立てて、ボトムプレートと合体します。ボトムプレートは左右で形状が違うため注意してください。底板を使う場合は、ボトムプレートの下にさらに底板を重ね、長め (8mm) のネジで貫通するようにとめます。使わない場合は短め (5mm) のネジでとめます。\n\nケースが組めたら、クッションゴムを貼り付け、キーキャップを装着して完成です。\n\n### おまけ: マステ Mod について\n\nUnderglow を使用する場合、写真のように真下にマスキングテープなどを貼り付けると、光が拡散しボトムプレート全体を光らせることができます。\n\n![masking](images/masking.jpg)\n\n## デフォルトキーマップの紹介\n\nデフォルトのキーマップは次のようになっています。\n\n![keymap](images/keymap.png)\n\n単にキーを押すと、黒字のキーが入力されます。「英数 Alt」のように二つの機能が書かれているキーは、単独で押すと「英数」として、長押しすると「Alt」として機能します。「英数」「かな」は Mac 用のキー、「全角半角」は Windows 用のキーです。\n\n橙のキー（「かな」）を押しながら他のキーを押すと、橙の字で書かれたキーが入力されます。数字や各種記号の入力にはこれを使います。\n\n青のキー（「Esc」）を押しながら他のキーを押すと、青の字で書かれたキーが入力されます。主にファンクションキーなど、特殊なキーを入力するために使います。\n\n緑のキー（「D」）を押しながら「HJKL」キーを押すと、マウスを操作できます。さらに「F」キーも同時に押すと、マウスカーソルの代わりにスクロールホイールを操作できます。\n\n### ガラケーモードについて\n\n橙のキー（「かな」）を押しながら「Tab」を押すと「ガラケーモード」に突入します。 LED が実装されている場合、ガラケーモードになっているかどうかは LED の色で識別できます。\n\nこのモードでは、同じキーの連打回数によって異なるアルファベットを入力でき、 Switch42 を片手キーボードとして利用できます。たとえば、「abc」キーを 2 回連打すると「b」が入力されます。\n\n![garakemap](images/garakemap.png)\n\nガラケーモードでも同様に、橙のキーを押しながら他のキーを押すと、マウス操作、ホイール操作などを行うことができます。\n\n「テンキー」キーを押すとテンキーモードとなり、緑の文字で示された数字を入力できるようになります。もう一度「テンキー」キーを押すことで通常のガラケーモードに戻ります。\n\n左手の右下キー「終了」を押すとガラケーモードを終了します。\n\n### キーマップの書き換え\n\nキーマップの定義は qmk_firmware/keyboards/switch42/keymaps/default/keymap.c にあります。このファイルを編集し、あらためてファームウェアの書き込み作業を行うことで、キーマップを変更できます。\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fzk-phi%2Fswitch42-keyboard","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fzk-phi%2Fswitch42-keyboard","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fzk-phi%2Fswitch42-keyboard/lists"}