procon_bypass_man 0.3.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +7 -0
  3. data/Gemfile.lock +1 -1
  4. data/docs/setting/splatoon2_macro_forward_ikarole.md +34 -0
  5. data/docs/setup_raspi.md +12 -15
  6. data/lib/procon_bypass_man/buttons_setting_configuration/layer.rb +1 -0
  7. data/lib/procon_bypass_man/buttons_setting_configuration/loader.rb +2 -1
  8. data/lib/procon_bypass_man/buttons_setting_configuration.rb +11 -0
  9. data/lib/procon_bypass_man/bypass/bypass_command.rb +1 -1
  10. data/lib/procon_bypass_man/bypass/procon_to_switch.rb +13 -2
  11. data/lib/procon_bypass_man/configuration.rb +1 -0
  12. data/lib/procon_bypass_man/device_connection/procon_setting_overrider.rb +0 -3
  13. data/lib/procon_bypass_man/ephemeral_configuration.rb +9 -0
  14. data/lib/procon_bypass_man/plugin/splatoon2/macro/{dasei_cancel.rb → forward_ikarole.rb} +4 -4
  15. data/lib/procon_bypass_man/plugins.rb +1 -1
  16. data/lib/procon_bypass_man/procon/analog_stick_manipulator.rb +16 -4
  17. data/lib/procon_bypass_man/procon/macro_builder.rb +11 -0
  18. data/lib/procon_bypass_man/procon/performance_measurement.rb +1 -1
  19. data/lib/procon_bypass_man/procon/rumbler.rb +18 -0
  20. data/lib/procon_bypass_man/procon/user_operation.rb +1 -1
  21. data/lib/procon_bypass_man/procon.rb +5 -13
  22. data/lib/procon_bypass_man/runner.rb +0 -1
  23. data/lib/procon_bypass_man/version.rb +1 -1
  24. data/lib/procon_bypass_man.rb +6 -1
  25. data/project_template/app.rb +1 -1
  26. data/project_template/app.rb.erb +1 -1
  27. data/project_template/setting.yml +3 -0
  28. metadata +6 -5
  29. data/docs/setting/splatoon2_macro_dasei_cancel.md +0 -77
  30. data/lib/procon_bypass_man/support/analog_stick_hypotenuse_tilting_power_scaler.rb +0 -59
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 556a827cf03895e4212aa4c524963ca7efd24499c2ea14edff2d692bc3e1e63f
4
- data.tar.gz: bf7cf5a735fffa13e1ff99c259a329a4c6981be755440477884ece0246188f21
3
+ metadata.gz: 3d7e6a739dbaf4be4022b97c591828d5ccca8d947c0c3bc0a0a8ffa8097a2b95
4
+ data.tar.gz: f7ad824a4e34d051c3f3514d18f6c6ab4b3e23b0cf6d9c574af1038afe9118b0
5
5
  SHA512:
6
- metadata.gz: 7bdfd9d2c5bee033c8f6a1f87acebcf3374e353c0ea4d373c76f86ee33b87b248665b087276998f20dee9f0d1258ab2c7c49906cc55b94b51a5e35d84712da5c
7
- data.tar.gz: 176ac515a48935df2953c36fb747e09be71c31f7850b09397e338bc0685b5da25bcd7ff81795d235287f2a5870fcdec3fec5aa9334e12ba90ca26662fe8807e7
6
+ metadata.gz: 5ab67436d5d4dbca83ec68d42b0621d6737370388e10d5d86738914506dd6261aa6f495b7074f36ec685d1392b433ec1d7070f9417c2dfe4e7927b6840829633
7
+ data.tar.gz: 4c0034304beda74a99126b4dfd1cd35b2f0ac00b78c200dea9f6bfd64a19b0c39407a4e24afcd0914764e9899058a328e4a1c18130efc83421eb7202b2543e1c
data/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## [0.3.1] - 2022-10-07
2
+ * レイヤーを変更しているときにコントローラーを振動できるようになりました
3
+ * setting.yml で `enable(:rumble_on_layer_change)` と記述してください
4
+ * イカロールをするマクロを追加しました
5
+ * 詳しい設定方法については docs/setting/splatoon2_macro_forward_ikarole.md を参照してください
6
+ * スプラ用マクロ、惰性キャンセルを削除しました
7
+
1
8
  ## [0.3.0] - 2022-9-9
2
9
  * 表示入力機能を一時的に削除しました #185
3
10
  * バイパス処理中の小さなラグがほぼなくなりました #185
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- procon_bypass_man (0.3.0)
4
+ procon_bypass_man (0.3.1)
5
5
  action_cable_client
6
6
  blue_green_process
7
7
  pbmenv (>= 0.1.9)
@@ -0,0 +1,34 @@
1
+ # スプラトゥーン2: イカロール マクロの設定方法
2
+
3
+ * procon_bypass_man: 0.3.1以上が必要です
4
+ * このマクロは、右から上へ高速にスティックを入れることでイカロールを行います
5
+ * 後述する設定例では、左スティックを押し込むことでイカロールを発動してます
6
+
7
+ https://user-images.githubusercontent.com/1664497/193837089-1c56af8d-2c1b-436a-b2a7-89c083a408d7.mov
8
+
9
+
10
+ ## 設定例1
11
+ ```yaml
12
+ version: 1.0
13
+ setting: |-
14
+ prefix_keys_for_changing_layer [:zr, :zl, :l]
15
+
16
+ layer :up do
17
+ open_macro :forward_ikarole, steps: [:forward_ikarole1], if_pressed: [:thumbl], force_neutral: []
18
+ end
19
+ ```
20
+
21
+ ## 設定例2
22
+ pluginとして登録してあるので、 `macro` を使っても同じことができます。
23
+
24
+ ```yaml
25
+ version: 1.0
26
+ setting: |-
27
+ prefix_keys_for_changing_layer [:zr, :zl, :l]
28
+
29
+ install_macro_plugin(ProconBypassMan::Plugin::Splatoon2::Macro::ForwardIkarole)
30
+
31
+ layer :up do
32
+ macro ProconBypassMan::Plugin::Splatoon2::Macro::ForwardIkarole, if_pressed: [:thumbl], force_neutral: []
33
+ end
34
+ ```
data/docs/setup_raspi.md CHANGED
@@ -1,41 +1,38 @@
1
1
  https://github.com/splaplapla/procon_bypass_man/blob/master/docs/setup_raspi_by_mitamae.md に半自動化した手順があります
2
2
 
3
3
  # Raspberry Pi4のセットアップ手順
4
- * SDカードにRaspberry Pi OS (32-bit)を焼く
4
+ * SDカードにRaspberry Pi OS (32 or 64-bit)を焼く
5
5
  * SDカードをRaspberry Pi4本体に挿して起動する
6
6
  * ラズパイGUI
7
7
  * 無線LANに接続する
8
8
  * sshdを許可する
9
9
  * macからsshする
10
+ * sudo apt-get update
10
11
  * sudo apt-get dist-upgrade
11
- * hostnameを変える
12
- * sudo hostnamectl set-hostname raspizero
13
- * /etc/hosts に追記する
14
- * 仮想メモリを増やす(optional)
15
- * /etc/dphys-swapfile を CONF_SWAPSIZE=1024 にする
16
- * sudo /etc/init.d/dphys-swapfile restart && swapon -s
17
- * tailscale をインストールする(optional)
18
12
  * sudo apt-get install vim rbenv git -y
19
13
  * rbenvでrubyを入れる
20
14
  * git clone https://github.com/rbenv/ruby-build.git "$(rbenv root)"/plugins/ruby-build
21
15
  * rbenv install 3.0.1
22
16
  * rbenv local 3.0.1
23
17
  * gem i bundler
24
- * sshkeyを作成する
25
- * github に鍵を登録する
26
- * ~/.ssh/authorized_keys に鍵を登録する
27
18
  * ガジェットモードで起動する
28
19
  * /boot/config.txtに、dtoverlay=dwc2を追記
29
20
  * echo "dwc2" | sudo tee -a /etc/modules
30
21
  * echo "libcomposite" | sudo tee -a /etc/modules
31
22
  * sudo cat /etc/modules
32
- * cd ~ && wget https://gist.githubusercontent.com/jiikko/3f9fb3194c0cc7685e31fbfcb5b5f9ff/raw/23ddee29d94350be80b79d290ac3c8ce8400bd88/add_procon_gadget.sh
33
- * chmod 755 ~/add_procon_gadget.sh
34
23
  * sudo reboot
35
- * sudo sh ~/add_procon_gadget.sh の実行に成功させる
36
24
  * cd ~ && mkdir -p src && cd ~/src && git clone https://github.com/jiikko/procon_bypass_man_sample && cd procon_bypass_man_sample
37
25
 
38
- おわり. 起動する時は都度 sudo ruby app.rb を実行する
26
+ おわりです.
27
+
28
+ 起動する時は下記を確認の上、`sudo /home/pi/.rbenv/versions/3.0.1/bin/ruby app.rb` を実行してください。
29
+
30
+ * 「ラズパイとSwitch」と「ラズパイとプロコン」を **データ通信可能なケーブル** で接続する
31
+ * **Proコントローラーの有線通信** をONにする
32
+
33
+
34
+ ![image](https://user-images.githubusercontent.com/1664497/193258615-1da27049-6d1f-4bfc-af1d-2f894f9c610e.png)
35
+
39
36
 
40
37
  ## 参考
41
38
  * https://mtosak-tech.hatenablog.jp/entry/2020/08/22/114622
@@ -53,6 +53,7 @@ module ProconBypassMan
53
53
  end
54
54
 
55
55
  # @param [String, Class] プラグインのclass
56
+ # @param [Hash, NilClass] if_tilted_left_stick 非推奨
56
57
  def macro(name, if_pressed: nil, if_tilted_left_stick: nil, force_neutral: nil)
57
58
  case if_tilted_left_stick
58
59
  when Integer, String, Symbol, Array
@@ -21,7 +21,7 @@ module ProconBypassMan
21
21
  rescue SyntaxError
22
22
  fallback_setting_if_has_backup(current_setting_path: setting_path)
23
23
  raise ProconBypassMan::CouldNotLoadConfigError, "Rubyスクリプトのシンタックスエラーです"
24
- rescue NoMethodError
24
+ rescue NameError
25
25
  fallback_setting_if_has_backup(current_setting_path: setting_path)
26
26
  raise ProconBypassMan::CouldNotLoadConfigError, "Rubyスクリプトに未定義の定数・変数があります"
27
27
  rescue Psych::SyntaxError
@@ -52,6 +52,7 @@ module ProconBypassMan
52
52
  end
53
53
 
54
54
  def self.reload_setting
55
+ ProconBypassMan.ephemeral_config.reset!
55
56
  self.load(setting_path: ProconBypassMan::ButtonsSettingConfiguration.instance.setting_path)
56
57
  end
57
58
 
@@ -98,6 +98,17 @@ module ProconBypassMan
98
98
  @prefix_keys_for_changing_layer
99
99
  end
100
100
 
101
+ # @param [Symbol, String] setting_name
102
+ # @return [void]
103
+ def enable(setting_name)
104
+ case setting_name.to_sym
105
+ when :rumble_on_layer_change
106
+ ProconBypassMan.ephemeral_config.enable_rumble_on_layer_change = true
107
+ else
108
+ warn "存在しないenable(#{setting_name.to_sym})が呼び出されました。"
109
+ end
110
+ end
111
+
101
112
  def reset!
102
113
  @prefix_keys_for_changing_layer = []
103
114
  self.mode_plugins = {}
@@ -58,8 +58,8 @@ class ProconBypassMan::BypassCommand
58
58
  if $will_terminate_token
59
59
  if $will_terminate_token == WILL_TERMINATE_TOKEN::TERMINATE
60
60
  bypass.direct_connect_switch_via_bluetooth
61
- process.shutdown
62
61
  end
62
+ process.shutdown
63
63
  break
64
64
  end
65
65
 
@@ -53,9 +53,20 @@ class ProconBypassMan::Bypass::ProconToSwitch
53
53
  begin
54
54
  # 終了処理を希望されているのでブロックを無視してメソッドを抜けてOK
55
55
  return(false) if $will_terminate_token # rubocop:disable Lint/NoReturnInBeginEndBlocks
56
- self.gadget.write_nonblock(
56
+ binary = ::ProconBypassMan::Procon::Rumbler.monitor do
57
57
  ProconBypassMan::Processor.new(bypass_value.binary).process
58
- )
58
+ end
59
+ self.gadget.write_nonblock(binary)
60
+
61
+ if ProconBypassMan.ephemeral_config.enable_rumble_on_layer_change && ProconBypassMan::Procon::Rumbler.must_rumble?
62
+ begin
63
+ self.procon.write_nonblock(ProconBypassMan::Procon::Rumbler.binary)
64
+ ProconBypassMan.logger.debug { ProconBypassMan::Procon::Rumbler.binary.unpack('H*').first }
65
+ rescue => e
66
+ ProconBypassMan::SendErrorCommand.execute(error: e)
67
+ end
68
+ end
69
+
59
70
  next(true)
60
71
  rescue IO::EAGAINWaitReadable
61
72
  return(false) if $will_terminate_token # rubocop:disable Lint/NoReturnInBeginEndBlocks
@@ -1,5 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ # app.rbから設定される値。プロセスを起動してから不変
3
4
  class ProconBypassMan::Configuration
4
5
  module ClassMethods
5
6
  def root
@@ -5,17 +5,14 @@ class ProconBypassMan::DeviceConnection::ProconSettingOverrider
5
5
  SUB_COMMAND_VIBRATION = "48"
6
6
 
7
7
  SUB_COMMAND_ARG_HOME_LED_ON = "1FF0FF"
8
- SUB_COMMAND_ARG_VIBRATION_OFF = "00"
9
8
 
10
9
  ALL_SETTINGS = {
11
10
  home_led_on: [SUB_COMMAND_HOME_LED_ON, SUB_COMMAND_ARG_HOME_LED_ON],
12
- vibration_off: [SUB_COMMAND_VIBRATION, SUB_COMMAND_ARG_VIBRATION_OFF],
13
11
  }
14
12
 
15
13
  # TODO 自動生成する
16
14
  SPECIAL_SUB_COMMAND_ARGS = {
17
15
  SUB_COMMAND_HOME_LED_ON => SUB_COMMAND_ARG_HOME_LED_ON,
18
- SUB_COMMAND_VIBRATION => SUB_COMMAND_ARG_VIBRATION_OFF,
19
16
  }
20
17
 
21
18
  def initialize(procon: )
@@ -0,0 +1,9 @@
1
+
2
+ # setting.yamlから設定される値。設定ファイルを再読み込みするとすべて消える
3
+ class ProconBypassMan::EphemeralConfiguration
4
+ attr_accessor :enable_rumble_on_layer_change
5
+
6
+ def reset!
7
+ self.enable_rumble_on_layer_change = false
8
+ end
9
+ end
@@ -2,17 +2,17 @@ module ProconBypassMan
2
2
  module Plugin
3
3
  module Splatoon2
4
4
  module Macro
5
- module DaseiCancel
5
+ module ForwardIkarole
6
6
  def self.display_name
7
- :dasei_cancel
7
+ :forward_ikarole
8
8
  end
9
9
 
10
10
  def self.steps
11
- [:pressing_r_for_0_03sec, :pressing_r_and_pressing_zl_for_0_2sec].freeze
11
+ [:forward_ikarole1].freeze
12
12
  end
13
13
 
14
14
  def self.description
15
- '惰性キャンセル'
15
+ '前方にイカロールをします'
16
16
  end
17
17
  end
18
18
  end
@@ -4,7 +4,7 @@ require_relative "plugin/splatoon2/macro/jump_to_right_key"
4
4
  require_relative "plugin/splatoon2/macro/jump_to_up_key"
5
5
  require_relative "plugin/splatoon2/macro/jump_to_left_key"
6
6
  require_relative "plugin/splatoon2/macro/sokuwari_for_splash_bomb"
7
- require_relative "plugin/splatoon2/macro/dasei_cancel"
7
+ require_relative "plugin/splatoon2/macro/forward_ikarole"
8
8
  require_relative "plugin/splatoon2/macro/charge_tansan_bomb"
9
9
  require_relative "plugin/splatoon2/mode/guruguru"
10
10
 
@@ -20,11 +20,23 @@ class ProconBypassMan::Procon::AnalogStickManipulator
20
20
  self.manipulated_abs_x = 3400
21
21
  self.manipulated_abs_y = 1808
22
22
  end
23
- else
24
- warn "error stick manipulator"
25
- self.manipulated_abs_x = analog_stick.abs_x
26
- self.manipulated_abs_y = analog_stick.abs_y
23
+
24
+ return
27
25
  end
26
+
27
+ if method =~ /tilt_left_stick_(completely)_to_(\d+)deg/
28
+ power_level = $1
29
+ arc_degree = $2.to_i
30
+ syahen = 1800 # 最大まで傾けた状態
31
+ neutral_position = ProconBypassMan::ButtonsSettingConfiguration.instance.neutral_position
32
+ self.manipulated_abs_x = (syahen * Math.cos(arc_degree * Math::PI / 180)).to_i - neutral_position.x
33
+ self.manipulated_abs_y = (syahen * Math.sin(arc_degree * Math::PI / 180)).to_i - neutral_position.y
34
+ return
35
+ end
36
+
37
+ warn "error stick manipulator"
38
+ self.manipulated_abs_x = analog_stick.abs_x
39
+ self.manipulated_abs_y = analog_stick.abs_y
28
40
  end
29
41
 
30
42
 
@@ -94,6 +94,17 @@ class ProconBypassMan::Procon::MacroBuilder
94
94
  ]
95
95
  end
96
96
 
97
+ # NOTE: マクロ構文で生成したいけど、スティックとボタン同時押しの構文が思いつかないので、ハードコードする
98
+ if /forward_ikarole1/ =~ step
99
+ # NOTE: 0degはx: 1, y: 0, 90degはx: 0, y: 1, 180degはx: -1, y: 0.
100
+ # NOTE: スティックを前方に倒している状態で270度回転させる
101
+ for_forward_ikarole_steps = [
102
+ [:tilt_left_stick_completely_to_0deg, :b],
103
+ [:tilt_left_stick_completely_to_90deg],
104
+ ]
105
+ return { steps: for_forward_ikarole_steps }
106
+ end
107
+
97
108
  if %r!^(pressing_|toggle_|shake_left_stick_)! =~ step && (subjects = step.scan(%r!pressing_[^_]+|shake_left_stick|toggle_[^_]+!)) && (match = step.match(%r!_for_([\d_]+)(sec)?\z!))
98
109
  if sec = match[1]
99
110
  return {
@@ -48,7 +48,7 @@ module ProconBypassMan::Procon::PerformanceMeasurement
48
48
  # 全部送ると負荷になるので適当にまびく
49
49
  def self.is_not_measure_with_random_or_if_fast(span: )
50
50
  return false if span.time_taken > 0.1
51
- return true if rand(20) != 0 # 19/20は捨てる
51
+ return true if rand(100) != 0 # 99/100は捨てる
52
52
  return false
53
53
  end
54
54
 
@@ -0,0 +1,18 @@
1
+ class ProconBypassMan::Procon::Rumbler
2
+ def self.monitor
3
+ @@must_rumble = false
4
+ return yield
5
+ end
6
+
7
+ def self.rumble!
8
+ @@must_rumble = true
9
+ end
10
+
11
+ def self.must_rumble?
12
+ @@must_rumble
13
+ end
14
+
15
+ def self.binary
16
+ ["100c00000000" + "00001010"].pack("H*")
17
+ end
18
+ end
@@ -38,7 +38,7 @@ class ProconBypassMan::Procon::UserOperation
38
38
  # @param [Symbol, Array<Symbol>] macro_step
39
39
  def press_button_only_or_tilt_sticks(macro_step)
40
40
  macro_step = [macro_step] if not macro_step.is_a?(Array)
41
- # スティック操作の時はボタン入力を通す
41
+ # スティック操作を含む時はボタン入力を通す
42
42
  binary.set_no_action! if is_button?(macro_step)
43
43
 
44
44
  macro_step.uniq.each do |ms|
@@ -22,6 +22,7 @@ class ProconBypassMan::Procon
22
22
  require "procon_bypass_man/procon/flip_cache"
23
23
  require "procon_bypass_man/procon/press_button_aware"
24
24
  require "procon_bypass_man/procon/suppress_rumble"
25
+ require "procon_bypass_man/procon/rumbler"
25
26
 
26
27
  attr_accessor :user_operation
27
28
 
@@ -32,7 +33,6 @@ class ProconBypassMan::Procon
32
33
  }
33
34
  BlueGreenProcess::SharedVariable.instance.data["buttons"] = {}
34
35
  BlueGreenProcess::SharedVariable.instance.data["current_layer_key"] = :up
35
- @@left_stick_tilting_power_scaler = ProconBypassMan::AnalogStickTiltingPowerScaler.new
36
36
  end
37
37
  reset!
38
38
 
@@ -66,13 +66,15 @@ class ProconBypassMan::Procon
66
66
  def apply!
67
67
  layer_changer = ProconBypassMan::Procon::LayerChanger.new(binary: user_operation.binary)
68
68
  if layer_changer.change_layer?
69
- self.current_layer_key = layer_changer.next_layer_key if layer_changer.pressed_next_layer?
69
+ if layer_changer.pressed_next_layer?
70
+ self.current_layer_key = layer_changer.next_layer_key
71
+ ProconBypassMan::Procon::Rumbler.rumble!
72
+ end
70
73
  user_operation.set_no_action!
71
74
  return
72
75
  end
73
76
 
74
77
  analog_stick = ProconBypassMan::Procon::AnalogStick.new(binary: user_operation.binary.raw)
75
- dumped_tilting_power = @@left_stick_tilting_power_scaler.add_sample(analog_stick.relative_hypotenuse)
76
78
 
77
79
  enable_all_macro = true
78
80
  enable_macro_map = Hash.new {|h,k| h[k] = true }
@@ -90,16 +92,6 @@ class ProconBypassMan::Procon
90
92
  current_layer.macros.each do |macro_name, options|
91
93
  next unless enable_macro_map[macro_name]
92
94
 
93
- if(if_tilted_left_stick_value = options[:if_tilted_left_stick])
94
- threshold = (if_tilted_left_stick_value.is_a?(Hash) && if_tilted_left_stick_value[:threshold]) || ProconBypassMan::AnalogStickTiltingPowerScaler::DEFAULT_THRESHOLD
95
- if dumped_tilting_power&.tilting?(threshold: threshold, current_position_x: analog_stick.relative_x, current_position_y: analog_stick.relative_y) && user_operation.pressing_all_buttons?(options[:if_pressed])
96
- @@status[:ongoing_macro] = MacroRegistry.load(macro_name)
97
- break
98
- end
99
-
100
- next
101
- end
102
-
103
95
  if user_operation.pressing_all_buttons?(options[:if_pressed])
104
96
  @@status[:ongoing_macro] = MacroRegistry.load(macro_name, force_neutral_buttons: options[:force_neutral])
105
97
  break
@@ -19,7 +19,6 @@ class ProconBypassMan::Runner
19
19
  end
20
20
 
21
21
  loop do
22
- # NOTE メインプロセスではThreadをいくつか起動しているので念のためパフォーマンスを優先するためにforkしていく
23
22
  child_pid = Kernel.fork do
24
23
  $will_terminate_token = false
25
24
  ProconBypassMan.after_fork_on_bypass_process
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module ProconBypassMan
4
- VERSION = "0.3.0"
4
+ VERSION = "0.3.1"
5
5
  end
@@ -35,7 +35,6 @@ require_relative "procon_bypass_man/support/remote_macro_http_client"
35
35
  require_relative "procon_bypass_man/support/update_remote_pbm_action_status_http_client"
36
36
  require_relative "procon_bypass_man/support/send_device_stats_http_client"
37
37
  require_relative "procon_bypass_man/support/procon_performance_http_client"
38
- require_relative "procon_bypass_man/support/analog_stick_hypotenuse_tilting_power_scaler"
39
38
  require_relative "procon_bypass_man/support/never_exit_accidentally"
40
39
  require_relative "procon_bypass_man/support/cycle_sleep"
41
40
  require_relative "procon_bypass_man/support/can_over_process"
@@ -50,6 +49,7 @@ require_relative "procon_bypass_man/device_status"
50
49
  require_relative "procon_bypass_man/runner"
51
50
  require_relative "procon_bypass_man/processor"
52
51
  require_relative "procon_bypass_man/configuration"
52
+ require_relative "procon_bypass_man/ephemeral_configuration"
53
53
  require_relative "procon_bypass_man/buttons_setting_configuration"
54
54
  require_relative "procon_bypass_man/procon"
55
55
  require_relative "procon_bypass_man/device_model"
@@ -143,6 +143,11 @@ module ProconBypassMan
143
143
  @@configuration ||= ProconBypassMan::Configuration.new
144
144
  end
145
145
 
146
+ # @return [ProconBypassMan::EphemeralConfiguration]
147
+ def self.ephemeral_config
148
+ @@ephemeral_configuration ||= ProconBypassMan::EphemeralConfiguration.new
149
+ end
150
+
146
151
  # @return [void]
147
152
  def self.reset!
148
153
  ProconBypassMan::Procon::MacroRegistry.reset!
@@ -12,7 +12,7 @@ begin
12
12
  gemfile do
13
13
  source 'https://rubygems.org'
14
14
  git_source(:github) {|repo_name| "https://github.com/#{repo_name}" }
15
- gem 'procon_bypass_man', '0.3.0'
15
+ gem 'procon_bypass_man', '0.3.1'
16
16
  end
17
17
  rescue Bundler::Source::Git::GitCommandError => e
18
18
  retry_count_on_git_command_error = retry_count_on_git_command_error + 1
@@ -12,7 +12,7 @@ begin
12
12
  gemfile do
13
13
  source 'https://rubygems.org'
14
14
  git_source(:github) {|repo_name| "https://github.com/#{repo_name}" }
15
- gem 'procon_bypass_man', '0.3.0'
15
+ gem 'procon_bypass_man', '0.3.1'
16
16
  end
17
17
  rescue Bundler::Source::Git::GitCommandError => e
18
18
  retry_count_on_git_command_error = retry_count_on_git_command_error + 1
@@ -1,5 +1,8 @@
1
1
  version: 1.0
2
2
  setting: |-
3
+ # レイヤー変更時にコントローラーが振動する。有効にすると稀に、コントローラーが数秒間固まることがあります。
4
+ # enable(:rumble_on_layer_change)
5
+
3
6
  prefix_keys_for_changing_layer [:zr, :zl, :l]
4
7
 
5
8
  layer :up do
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: procon_bypass_man
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.0
4
+ version: 0.3.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - jiikko
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2022-09-08 00:00:00.000000000 Z
11
+ date: 2022-10-07 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: pbmenv
@@ -95,7 +95,7 @@ files:
95
95
  - docs/getting_started.md
96
96
  - docs/how_to_connect_procon.md
97
97
  - docs/setting/left-analogstick-cap.md
98
- - docs/setting/splatoon2_macro_dasei_cancel.md
98
+ - docs/setting/splatoon2_macro_forward_ikarole.md
99
99
  - docs/setting/splatoon2_macro_sokuwari_bubble.md
100
100
  - docs/setting/splatoon2_recommended_setting.md
101
101
  - docs/setting/splatoon2_shake_tansan.md
@@ -161,9 +161,10 @@ files:
161
161
  - lib/procon_bypass_man/device_connection/spoofing_output_report_watcher.rb
162
162
  - lib/procon_bypass_man/device_model.rb
163
163
  - lib/procon_bypass_man/device_status.rb
164
+ - lib/procon_bypass_man/ephemeral_configuration.rb
164
165
  - lib/procon_bypass_man/plugin/splatoon2/macro/charge_tansan_bomb.rb
165
- - lib/procon_bypass_man/plugin/splatoon2/macro/dasei_cancel.rb
166
166
  - lib/procon_bypass_man/plugin/splatoon2/macro/fast_return.rb
167
+ - lib/procon_bypass_man/plugin/splatoon2/macro/forward_ikarole.rb
167
168
  - lib/procon_bypass_man/plugin/splatoon2/macro/jump_to_left_key.rb
168
169
  - lib/procon_bypass_man/plugin/splatoon2/macro/jump_to_right_key.rb
169
170
  - lib/procon_bypass_man/plugin/splatoon2/macro/jump_to_up_key.rb
@@ -194,6 +195,7 @@ files:
194
195
  - lib/procon_bypass_man/procon/performance_measurement/span_queue.rb
195
196
  - lib/procon_bypass_man/procon/performance_measurement/span_transfer_buffer.rb
196
197
  - lib/procon_bypass_man/procon/press_button_aware.rb
198
+ - lib/procon_bypass_man/procon/rumbler.rb
197
199
  - lib/procon_bypass_man/procon/suppress_rumble.rb
198
200
  - lib/procon_bypass_man/procon/user_operation.rb
199
201
  - lib/procon_bypass_man/procon/value_objects/analog_stick.rb
@@ -232,7 +234,6 @@ files:
232
234
  - lib/procon_bypass_man/remote_pbm_action/value_objects/remote_pbm_action_object.rb
233
235
  - lib/procon_bypass_man/runner.rb
234
236
  - lib/procon_bypass_man/scheduler.rb
235
- - lib/procon_bypass_man/support/analog_stick_hypotenuse_tilting_power_scaler.rb
236
237
  - lib/procon_bypass_man/support/callbacks.rb
237
238
  - lib/procon_bypass_man/support/can_over_process.rb
238
239
  - lib/procon_bypass_man/support/compress_array.rb
@@ -1,77 +0,0 @@
1
- # スプラトゥーン2: 惰性キャンセル マクロの設定方法
2
-
3
- * 本マクロは実験段階で、オプション名などの仕様が変更される可能性が高いです
4
- * procon_bypass_man: 0.1.21以上が必要です
5
-
6
- ## 1. install_macro_pluginでマクロを有効化します
7
- * `setting.yml` に`install_macro_plugin ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel` と書きます
8
- * これを記述することで、layer内でmacroを呼び出せるようになります
9
-
10
- ```ruby
11
- install_macro_plugin ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel
12
- ```
13
-
14
- ## 2. どのlayerで発動するかを宣言します
15
- * `setting.yml` のlayer内に`macro ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel, if_pressed: [:zl]` と書きます
16
- * `if_pressed` がどのボタンを押したときにこのマクロが発動するかの設定です
17
- * 惰性キャンセルなのでイカ状態になるためにzlを押します
18
- * `if_tilted_left_stick` がスティックを倒した時に発動するオプションで、trueを渡すと有効になります
19
- * また、傾けた時の閾値を変更することができて、trueの代わりに `{ threshold: 500 }` と書くことができます
20
- * デフォルトが500で、ここの数値を上げると、スティックを倒した判定がより厳しくなります。最大1400くらいです。
21
- * 連打中に、マクロの発動を無効にしたい場合は `disable_macro` で無効にできます
22
-
23
- ```ruby
24
- layer :up do
25
- macro ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel, if_tilted_left_stick: true, if_pressed: [:zl]
26
- end
27
- ```
28
- ```ruby
29
- layer :up do
30
- macro ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel, if_tilted_left_stick: { threshold: 500 }, if_pressed: [:zl]
31
- end
32
- ```
33
- ```ruby
34
- layer :up do
35
- disable_macro :all, if_pressed: :a
36
- disable_macro :all, if_pressed: :zr
37
- macro ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel, if_tilted_left_stick: true, if_pressed: [:zl]
38
- end
39
- ```
40
-
41
- ## 3. 設定を反映させる
42
- * 上記の記述を加えたsetting.ymlを起動中のprocon_bypass_manプロセスで読み込むには、プロセスにその旨を伝える必要があります
43
- * ラズベリーパイを再起動して、プロセスを立ち上げ直す、でも目的は達成できますが、もっと簡単にsetting.ymlを再読み込みする必要があります
44
- * 書き換えたsetting.ymlを、起動中のprocon_bypass_manプロセスへ即時反映するには、procon_bypass_manプロセスを動かしたまま、別のshellから 以下をを実行してください
45
- * setting.ymlのシンタックスが正しければ、switchとの接続が継続したままsetting.ymlの内容を読み込んでいるはずです
46
-
47
- ```shell
48
- sudo kill -USR2 `cat ./pbm_pid`
49
- ```
50
-
51
- ## 設定例1
52
- ```yaml
53
- version: 1.0
54
- setting: |-
55
- prefix_keys_for_changing_layer [:zr, :zl, :l]
56
- install_macro_plugin ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel
57
-
58
- layer :up do
59
- disable_macro :all, if_pressed: :a
60
- disable_macro :all, if_pressed: :zr
61
- macro ProconBypassMan::Plugin::Splatoon2::Macro::DaseiCancel, if_tilted_left_stick: true, if_pressed: [:zl]
62
- end
63
- ```
64
-
65
- ## 設定例2
66
- * `open_macro` キーワードを使っても同じことが実行可能です。
67
- * この場合は、 `install_macro_plugin` が不要です。
68
-
69
- ```yaml
70
- version: 1.0
71
- setting: |-
72
- prefix_keys_for_changing_layer [:zr, :zl, :l]
73
-
74
- layer :up do
75
- open_macro :dacan, steps: [:pressing_r_for_0_03sec, :pressing_r_and_pressing_zl_for_0_2sec], if_tilted_left_stick: true, if_pressed: [:zl]
76
- end
77
- ```
@@ -1,59 +0,0 @@
1
- class ProconBypassMan::AnalogStickTiltingPowerScaler
2
- DEFAULT_THRESHOLD = 500
3
-
4
- class PowerChunk
5
- def initialize(list)
6
- @list = list
7
- end
8
-
9
- def moving_power
10
- max = @list.max
11
- min = @list.min
12
- moving_power = (max - min).abs
13
- end
14
-
15
- def tilting?(threshold: DEFAULT_THRESHOLD, current_position_x: , current_position_y: )
16
- # スティックがニュートラルな時
17
- if (-200..200).include?(current_position_x) && (-200..200).include?(current_position_y)
18
- return false
19
- end
20
-
21
- moving_power >= threshold
22
- end
23
- end
24
-
25
- def initialize
26
- @map = {}
27
- end
28
-
29
- # @return [NilClass, Chunk] ローテトしたらvalueを返す
30
- def add_sample(value)
31
- rotated = nil
32
- current_key = key
33
- if @map[current_key].nil?
34
- rotated = rotate
35
- @map = { current_key => [] } # renew or initialize
36
- end
37
-
38
- @map[current_key] << value
39
- rotated
40
- end
41
-
42
- private
43
-
44
- # 0.1sec刻みで進行する
45
- def key
46
- time = Time.now
47
- m1 = time.strftime('%L')[0]
48
- [time.to_i, m1].join.to_i
49
- end
50
-
51
- def rotate
52
- list = @map.values.first
53
- if list
54
- return PowerChunk.new(list)
55
- else
56
- return nil
57
- end
58
- end
59
- end