forked from eden-emu/eden
		
	core: hid: Finish linking motion from virtual controllers
This commit is contained in:
		
							parent
							
								
									06104b04b6
								
							
						
					
					
						commit
						c4925fc96a
					
				
					 5 changed files with 57 additions and 9 deletions
				
			
		|  | @ -117,11 +117,13 @@ open class EmulationActivity : AppCompatActivity() { | ||||||
|     override fun onResume() { |     override fun onResume() { | ||||||
|         super.onResume() |         super.onResume() | ||||||
|         nfcReader.startScanning() |         nfcReader.startScanning() | ||||||
|  |         startMotionSensorListener() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     override fun onPause() { |     override fun onPause() { | ||||||
|         super.onPause() |         super.onPause() | ||||||
|         nfcReader.stopScanning() |         nfcReader.stopScanning() | ||||||
|  |         stopMotionSensorListener() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     override fun onNewIntent(intent: Intent) { |     override fun onNewIntent(intent: Intent) { | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ EmulatedConsole::~EmulatedConsole() = default; | ||||||
| void EmulatedConsole::ReloadFromSettings() { | void EmulatedConsole::ReloadFromSettings() { | ||||||
|     // Using first motion device from player 1. No need to assign any unique config at the moment
 |     // Using first motion device from player 1. No need to assign any unique config at the moment
 | ||||||
|     const auto& player = Settings::values.players.GetValue()[0]; |     const auto& player = Settings::values.players.GetValue()[0]; | ||||||
|     motion_params = Common::ParamPackage(player.motions[0]); |     motion_params[0] = Common::ParamPackage(player.motions[0]); | ||||||
| 
 | 
 | ||||||
|     ReloadInput(); |     ReloadInput(); | ||||||
| } | } | ||||||
|  | @ -74,14 +74,30 @@ void EmulatedConsole::ReloadInput() { | ||||||
|     // If you load any device here add the equivalent to the UnloadInput() function
 |     // If you load any device here add the equivalent to the UnloadInput() function
 | ||||||
|     SetTouchParams(); |     SetTouchParams(); | ||||||
| 
 | 
 | ||||||
|     motion_devices = Common::Input::CreateInputDevice(motion_params); |     motion_params[1] = Common::ParamPackage{"engine:virtual_gamepad,port:8,motion:0"}; | ||||||
|     if (motion_devices) { | 
 | ||||||
|         motion_devices->SetCallback({ |     for (std::size_t index = 0; index < motion_devices.size(); ++index) { | ||||||
|  |         motion_devices[index] = Common::Input::CreateInputDevice(motion_params[index]); | ||||||
|  |         if (!motion_devices[index]) { | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         motion_devices[index]->SetCallback({ | ||||||
|             .on_change = |             .on_change = | ||||||
|                 [this](const Common::Input::CallbackStatus& callback) { SetMotion(callback); }, |                 [this](const Common::Input::CallbackStatus& callback) { SetMotion(callback); }, | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // Restore motion state
 | ||||||
|  |     auto& emulated_motion = console.motion_values.emulated; | ||||||
|  |     auto& motion = console.motion_state; | ||||||
|  |     emulated_motion.ResetRotations(); | ||||||
|  |     emulated_motion.ResetQuaternion(); | ||||||
|  |     motion.accel = emulated_motion.GetAcceleration(); | ||||||
|  |     motion.gyro = emulated_motion.GetGyroscope(); | ||||||
|  |     motion.rotation = emulated_motion.GetRotations(); | ||||||
|  |     motion.orientation = emulated_motion.GetOrientation(); | ||||||
|  |     motion.is_at_rest = !emulated_motion.IsMoving(motion_sensitivity); | ||||||
|  | 
 | ||||||
|     // Unique index for identifying touch device source
 |     // Unique index for identifying touch device source
 | ||||||
|     std::size_t index = 0; |     std::size_t index = 0; | ||||||
|     for (auto& touch_device : touch_devices) { |     for (auto& touch_device : touch_devices) { | ||||||
|  | @ -100,7 +116,9 @@ void EmulatedConsole::ReloadInput() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmulatedConsole::UnloadInput() { | void EmulatedConsole::UnloadInput() { | ||||||
|     motion_devices.reset(); |     for (auto& motion : motion_devices) { | ||||||
|  |         motion.reset(); | ||||||
|  |     } | ||||||
|     for (auto& touch : touch_devices) { |     for (auto& touch : touch_devices) { | ||||||
|         touch.reset(); |         touch.reset(); | ||||||
|     } |     } | ||||||
|  | @ -133,11 +151,11 @@ void EmulatedConsole::RestoreConfig() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Common::ParamPackage EmulatedConsole::GetMotionParam() const { | Common::ParamPackage EmulatedConsole::GetMotionParam() const { | ||||||
|     return motion_params; |     return motion_params[0]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmulatedConsole::SetMotionParam(Common::ParamPackage param) { | void EmulatedConsole::SetMotionParam(Common::ParamPackage param) { | ||||||
|     motion_params = std::move(param); |     motion_params[0] = std::move(param); | ||||||
|     ReloadInput(); |     ReloadInput(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -29,10 +29,10 @@ struct ConsoleMotionInfo { | ||||||
|     MotionInput emulated{}; |     MotionInput emulated{}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| using ConsoleMotionDevices = std::unique_ptr<Common::Input::InputDevice>; | using ConsoleMotionDevices = std::array<std::unique_ptr<Common::Input::InputDevice>, 2>; | ||||||
| using TouchDevices = std::array<std::unique_ptr<Common::Input::InputDevice>, MaxTouchDevices>; | using TouchDevices = std::array<std::unique_ptr<Common::Input::InputDevice>, MaxTouchDevices>; | ||||||
| 
 | 
 | ||||||
| using ConsoleMotionParams = Common::ParamPackage; | using ConsoleMotionParams = std::array<Common::ParamPackage, 2>; | ||||||
| using TouchParams = std::array<Common::ParamPackage, MaxTouchDevices>; | using TouchParams = std::array<Common::ParamPackage, MaxTouchDevices>; | ||||||
| 
 | 
 | ||||||
| using ConsoleMotionValues = ConsoleMotionInfo; | using ConsoleMotionValues = ConsoleMotionInfo; | ||||||
|  |  | ||||||
|  | @ -193,6 +193,8 @@ void EmulatedController::LoadDevices() { | ||||||
|                            Common::Input::CreateInputDevice); |                            Common::Input::CreateInputDevice); | ||||||
|     std::ranges::transform(virtual_stick_params, virtual_stick_devices.begin(), |     std::ranges::transform(virtual_stick_params, virtual_stick_devices.begin(), | ||||||
|                            Common::Input::CreateInputDevice); |                            Common::Input::CreateInputDevice); | ||||||
|  |     std::ranges::transform(virtual_motion_params, virtual_motion_devices.begin(), | ||||||
|  |                            Common::Input::CreateInputDevice); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmulatedController::LoadTASParams() { | void EmulatedController::LoadTASParams() { | ||||||
|  | @ -253,6 +255,12 @@ void EmulatedController::LoadVirtualGamepadParams() { | ||||||
|     for (auto& param : virtual_stick_params) { |     for (auto& param : virtual_stick_params) { | ||||||
|         param = common_params; |         param = common_params; | ||||||
|     } |     } | ||||||
|  |     for (auto& param : virtual_stick_params) { | ||||||
|  |         param = common_params; | ||||||
|  |     } | ||||||
|  |     for (auto& param : virtual_motion_params) { | ||||||
|  |         param = common_params; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     // TODO(german77): Replace this with an input profile or something better
 |     // TODO(german77): Replace this with an input profile or something better
 | ||||||
|     virtual_button_params[Settings::NativeButton::A].Set("button", 0); |     virtual_button_params[Settings::NativeButton::A].Set("button", 0); | ||||||
|  | @ -284,6 +292,9 @@ void EmulatedController::LoadVirtualGamepadParams() { | ||||||
|     virtual_stick_params[Settings::NativeAnalog::LStick].Set("range", 1.0f); |     virtual_stick_params[Settings::NativeAnalog::LStick].Set("range", 1.0f); | ||||||
|     virtual_stick_params[Settings::NativeAnalog::RStick].Set("deadzone", 0.0f); |     virtual_stick_params[Settings::NativeAnalog::RStick].Set("deadzone", 0.0f); | ||||||
|     virtual_stick_params[Settings::NativeAnalog::RStick].Set("range", 1.0f); |     virtual_stick_params[Settings::NativeAnalog::RStick].Set("range", 1.0f); | ||||||
|  | 
 | ||||||
|  |     virtual_motion_params[Settings::NativeMotion::MotionLeft].Set("motion", 0); | ||||||
|  |     virtual_motion_params[Settings::NativeMotion::MotionRight].Set("motion", 0); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmulatedController::ReloadInput() { | void EmulatedController::ReloadInput() { | ||||||
|  | @ -463,6 +474,18 @@ void EmulatedController::ReloadInput() { | ||||||
|                 }, |                 }, | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     for (std::size_t index = 0; index < virtual_motion_devices.size(); ++index) { | ||||||
|  |         if (!virtual_motion_devices[index]) { | ||||||
|  |             continue; | ||||||
|  |         } | ||||||
|  |         virtual_motion_devices[index]->SetCallback({ | ||||||
|  |             .on_change = | ||||||
|  |                 [this, index](const Common::Input::CallbackStatus& callback) { | ||||||
|  |                     SetMotion(callback, index); | ||||||
|  |                 }, | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|     turbo_button_state = 0; |     turbo_button_state = 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -500,6 +523,9 @@ void EmulatedController::UnloadInput() { | ||||||
|     for (auto& stick : virtual_stick_devices) { |     for (auto& stick : virtual_stick_devices) { | ||||||
|         stick.reset(); |         stick.reset(); | ||||||
|     } |     } | ||||||
|  |     for (auto& motion : virtual_motion_devices) { | ||||||
|  |         motion.reset(); | ||||||
|  |     } | ||||||
|     for (auto& camera : camera_devices) { |     for (auto& camera : camera_devices) { | ||||||
|         camera.reset(); |         camera.reset(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -568,8 +568,10 @@ private: | ||||||
|     // Virtual gamepad related variables
 |     // Virtual gamepad related variables
 | ||||||
|     ButtonParams virtual_button_params; |     ButtonParams virtual_button_params; | ||||||
|     StickParams virtual_stick_params; |     StickParams virtual_stick_params; | ||||||
|  |     ControllerMotionParams virtual_motion_params; | ||||||
|     ButtonDevices virtual_button_devices; |     ButtonDevices virtual_button_devices; | ||||||
|     StickDevices virtual_stick_devices; |     StickDevices virtual_stick_devices; | ||||||
|  |     ControllerMotionDevices virtual_motion_devices; | ||||||
| 
 | 
 | ||||||
|     mutable std::mutex mutex; |     mutable std::mutex mutex; | ||||||
|     mutable std::mutex callback_mutex; |     mutable std::mutex callback_mutex; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Narr the Reg
						Narr the Reg