# ProconBypassMan
[![Ruby](https://github.com/splaplapla/procon_bypass_man/actions/workflows/ruby.yml/badge.svg?branch=master)](https://github.com/splaplapla/procon_bypass_man/actions/workflows/ruby.yml)
* Nintendo Switch Proコントローラーを連射機などにするRaspberry Pi上で動かすコンバータです
* ドキュメントは [getting_started.md](docs/getting_started.md) にまとめています
* https://pbm-cloud.herokuapp.com を使うと、webだけで運用が可能です
https://user-images.githubusercontent.com/1664497/171327108-f12f56a5-fc36-48da-95a5-65e976553a20.mov
## 使うハードウェア
* Nintendo Switch Proコントローラー
* Switch本体とドック
* Raspberry Pi4 (Raspberry Pi OS)
* 他のシリーズは未確認です
* データ通信が可能なUSBケーブル
## 使うソフトウェア
* ruby 2.5 以上
## プラグイン
* https://github.com/splaplapla/procon_bypass_man-splatoon2
* [スプラトゥーン3](docs/setting/splatoon3_recommended_setting.md)
## FAQ
* どうやって動かすの?
* このツールはRaspberry Pi4をUSBガジェットモードで起動して有線でプロコンとSwitchに接続して使います
* どうやって使うの?
* ケーブルでそれらを接続した状態で、Raspberry Pi4にsshして本プログラムを起動することで使用します
* ラズベリーパイ4のセットアップ方法は?
* https://github.com/splaplapla/procon_bypass_man/tree/master/docs/setup_raspi.md
* レイヤーとは?
* 自作キーボードみたいな感じでレイヤー毎に設定内容を記述して切り替えれます
* レイヤーは4つあって、up, down, left, rightです。十字キーに対応しています
* レイヤーを切り替える方法は?
* 設定ファイルに記述している `prefix_keys_for_changing_layer`の後ろにあるキーを同時押しながら、十字キーのどれかを押すことで任意のレイヤーに切り替わります
* このツールでできることは?
* キーリマップ, 連射, マクロ, 特定の同じ操作の繰り返し(mode)
* リマップは1つのキーを別のキーに割り当てます
* 連射中には特定のキーの入力を無視したり、複数のキーをトリガーに連射することができます
* どうしてsudoが必要なの?
* 操作するdeviceファイルの所有者がrootだからです
* 市販されているサードパーティ製連射機との違いは?
* サードパーティ製のコントローラーは、設定方法や形状が特殊で買い換えるたびに学習・設定コストが発生します。本ツールを使えば、設定内容はテキストで管理することができ、使い慣れたプロコンで同等のことができます
* sshなしで運用は可能ですか?
* https://pbm-cloud.herokuapp.com を使えば、sshを使わずに運用が可能です
## 仕様・制約
* 日を跨ぐ24時ちょうどになった瞬間はLinuxのcronが起動などがするようで、この時間は数秒間バイパスが激しく遅延します
* ログファイルのローテションが少なくとも走るはずなので、不要なデーモンを停止するなどで影響を小さくすることはできると思いますが、完全に抑制することは難しいと思います
* コントローラーから読み取ってSwitchに書き込む時間は、少なくとも0.02秒はかかります
* 動かしているRaspberry Piの負荷に依存するこの限りではありません
## Raspberry Pi4のセットアップを代行します
* Raspberry Pi4を開発者である私の家に配送してくれれば、セットアップを代行します。セットアップが終わり次第送り返します
* 使い方に関しては、https://pbm-cloud.herokuapp.com ですべて完結するので、Linuxの知識は不要です
* 何か問題が起きた時はリモートログインでサポート可能です
* 希望者はDiscordの `kawagu#7684` にDMを送ってください
* お金はかかりません
## 開発を支援してくれる人を募集しています
* https://jiikko.fanbox.cc/
* procon_bypassの運営・開発・サーバー費用に充てさせていただきます。また、問い合わせに優先して対応します。
## Links
* https://discord.gg/bEcRNKf4ep
* 質問などご意見をdiscordでも受け付けています
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).