class ProconBypassMan::Procon::AnalogStickCap def initialize(binary) @binary = binary @analog_stick = ProconBypassMan::Procon::AnalogStick.new(binary: binary) end # @return [ProconBypassMan::AnalogStickPosition] def capped_position(cap_hypotenuse: ) if hypotenuse > cap_hypotenuse relative_capped_x = cap_hypotenuse * Math.cos(rad * Math::PI / 180).abs relative_capped_y = cap_hypotenuse * Math.sin(rad * Math::PI / 180).abs relative_capped_x = -(relative_capped_x.abs) if relative_x.negative? relative_capped_y = -(relative_capped_y.abs) if relative_y.negative? return ProconBypassMan::AnalogStickPosition.new( x: relative_capped_x + @analog_stick.neutral_position.x, y: relative_capped_y + @analog_stick.neutral_position.y, ) else return position end end # @return [ProconBypassMan::AnalogStickPosition] def position ProconBypassMan::AnalogStickPosition.new(x: abs_x, y: abs_y) end def abs_x; @analog_stick.abs_x; end # 0, 0からのx def abs_y; @analog_stick.abs_y; end # 0, 0からのy def relative_x; @analog_stick.relative_x; end def relative_y; @analog_stick.relative_y; end # @deprecated def x; relative_x; end def y; relative_y; end def rad ( Math.atan(relative_y / relative_x.to_f) * 180 / Math::PI ).floor(6) end def hypotenuse Math.sqrt((relative_x**2) + (relative_y**2)).floor(6) end end