forked from eden-emu/eden
		
	core: hid: Enable pulling color data from controllers
This commit is contained in:
		
							parent
							
								
									3672362ce1
								
							
						
					
					
						commit
						59e89afde4
					
				
					 9 changed files with 246 additions and 2 deletions
				
			
		|  | @ -93,6 +93,7 @@ void EmulatedController::ReloadFromSettings() { | |||
|         motion_params[index] = Common::ParamPackage(player.motions[index]); | ||||
|     } | ||||
| 
 | ||||
|     controller.color_values = {}; | ||||
|     controller.colors_state.fullkey = { | ||||
|         .body = GetNpadColor(player.body_color_left), | ||||
|         .button = GetNpadColor(player.button_color_left), | ||||
|  | @ -132,6 +133,11 @@ void EmulatedController::LoadDevices() { | |||
|     trigger_params[LeftIndex] = button_params[Settings::NativeButton::ZL]; | ||||
|     trigger_params[RightIndex] = button_params[Settings::NativeButton::ZR]; | ||||
| 
 | ||||
|     color_params[LeftIndex] = left_joycon; | ||||
|     color_params[RightIndex] = right_joycon; | ||||
|     color_params[LeftIndex].Set("color", true); | ||||
|     color_params[RightIndex].Set("color", true); | ||||
| 
 | ||||
|     battery_params[LeftIndex] = left_joycon; | ||||
|     battery_params[RightIndex] = right_joycon; | ||||
|     battery_params[LeftIndex].Set("battery", true); | ||||
|  | @ -160,6 +166,7 @@ void EmulatedController::LoadDevices() { | |||
|                            Common::Input::CreateInputDevice); | ||||
|     std::ranges::transform(battery_params, battery_devices.begin(), | ||||
|                            Common::Input::CreateInputDevice); | ||||
|     std::ranges::transform(color_params, color_devices.begin(), Common::Input::CreateInputDevice); | ||||
|     camera_devices = Common::Input::CreateInputDevice(camera_params); | ||||
|     ring_analog_device = Common::Input::CreateInputDevice(ring_params); | ||||
|     nfc_devices = Common::Input::CreateInputDevice(nfc_params); | ||||
|  | @ -324,6 +331,19 @@ void EmulatedController::ReloadInput() { | |||
|         battery_devices[index]->ForceUpdate(); | ||||
|     } | ||||
| 
 | ||||
|     for (std::size_t index = 0; index < color_devices.size(); ++index) { | ||||
|         if (!color_devices[index]) { | ||||
|             continue; | ||||
|         } | ||||
|         color_devices[index]->SetCallback({ | ||||
|             .on_change = | ||||
|                 [this, index](const Common::Input::CallbackStatus& callback) { | ||||
|                     SetColors(callback, index); | ||||
|                 }, | ||||
|         }); | ||||
|         color_devices[index]->ForceUpdate(); | ||||
|     } | ||||
| 
 | ||||
|     for (std::size_t index = 0; index < motion_devices.size(); ++index) { | ||||
|         if (!motion_devices[index]) { | ||||
|             continue; | ||||
|  | @ -429,6 +449,9 @@ void EmulatedController::UnloadInput() { | |||
|     for (auto& battery : battery_devices) { | ||||
|         battery.reset(); | ||||
|     } | ||||
|     for (auto& color : color_devices) { | ||||
|         color.reset(); | ||||
|     } | ||||
|     for (auto& output : output_devices) { | ||||
|         output.reset(); | ||||
|     } | ||||
|  | @ -458,6 +481,11 @@ void EmulatedController::EnableConfiguration() { | |||
| void EmulatedController::DisableConfiguration() { | ||||
|     is_configuring = false; | ||||
| 
 | ||||
|     // Get Joycon colors before turning on the controller
 | ||||
|     for (const auto& color_device : color_devices) { | ||||
|         color_device->ForceUpdate(); | ||||
|     } | ||||
| 
 | ||||
|     // Apply temporary npad type to the real controller
 | ||||
|     if (tmp_npad_type != npad_type) { | ||||
|         if (is_connected) { | ||||
|  | @ -926,6 +954,58 @@ void EmulatedController::SetMotion(const Common::Input::CallbackStatus& callback | |||
|     TriggerOnChange(ControllerTriggerType::Motion, true); | ||||
| } | ||||
| 
 | ||||
| void EmulatedController::SetColors(const Common::Input::CallbackStatus& callback, | ||||
|                                    std::size_t index) { | ||||
|     if (index >= controller.color_values.size()) { | ||||
|         return; | ||||
|     } | ||||
|     std::unique_lock lock{mutex}; | ||||
|     controller.color_values[index] = TransformToColor(callback); | ||||
| 
 | ||||
|     if (is_configuring) { | ||||
|         lock.unlock(); | ||||
|         TriggerOnChange(ControllerTriggerType::Color, false); | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     if (controller.color_values[index].body == 0) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     controller.colors_state.fullkey = { | ||||
|         .body = GetNpadColor(controller.color_values[index].body), | ||||
|         .button = GetNpadColor(controller.color_values[index].buttons), | ||||
|     }; | ||||
|     if (npad_type == NpadStyleIndex::ProController) { | ||||
|         controller.colors_state.left = { | ||||
|             .body = GetNpadColor(controller.color_values[index].left_grip), | ||||
|             .button = GetNpadColor(controller.color_values[index].buttons), | ||||
|         }; | ||||
|         controller.colors_state.right = { | ||||
|             .body = GetNpadColor(controller.color_values[index].right_grip), | ||||
|             .button = GetNpadColor(controller.color_values[index].buttons), | ||||
|         }; | ||||
|     } else { | ||||
|         switch (index) { | ||||
|         case LeftIndex: | ||||
|             controller.colors_state.left = { | ||||
|                 .body = GetNpadColor(controller.color_values[index].body), | ||||
|                 .button = GetNpadColor(controller.color_values[index].buttons), | ||||
|             }; | ||||
|             break; | ||||
|         case RightIndex: | ||||
|             controller.colors_state.right = { | ||||
|                 .body = GetNpadColor(controller.color_values[index].body), | ||||
|                 .button = GetNpadColor(controller.color_values[index].buttons), | ||||
|             }; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     lock.unlock(); | ||||
|     TriggerOnChange(ControllerTriggerType::Color, true); | ||||
| } | ||||
| 
 | ||||
| void EmulatedController::SetBattery(const Common::Input::CallbackStatus& callback, | ||||
|                                     std::size_t index) { | ||||
|     if (index >= controller.battery_values.size()) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Narr the Reg
						Narr the Reg