forked from eden-emu/eden
		
	service/hid: Fix gesture input
This commit is contained in:
		
							parent
							
								
									6774c7988b
								
							
						
					
					
						commit
						8ea02d19a1
					
				
					 8 changed files with 158 additions and 90 deletions
				
			
		|  | @ -209,7 +209,7 @@ void GCAdapter::UpdateStateAxes(std::size_t port, const AdapterPayload& adapter_ | |||
|             pads[port].axis_origin[index] = axis_value; | ||||
|             pads[port].reset_origin_counter++; | ||||
|         } | ||||
|         const f32 axis_status = (axis_value - pads[port].axis_origin[index]) / 110.0f; | ||||
|         const f32 axis_status = (axis_value - pads[port].axis_origin[index]) / 100.0f; | ||||
|         SetAxis(pads[port].identifier, static_cast<int>(index), axis_status); | ||||
|     } | ||||
| } | ||||
|  | @ -530,7 +530,7 @@ std::string GCAdapter::GetUIName(const Common::ParamPackage& params) const { | |||
|         return fmt::format("Button {}", GetUIButtonName(params)); | ||||
|     } | ||||
|     if (params.Has("axis")) { | ||||
|         return fmt::format("Axis {}", params.Get("axis",0)); | ||||
|         return fmt::format("Axis {}", params.Get("axis", 0)); | ||||
|     } | ||||
| 
 | ||||
|     return "Bad GC Adapter"; | ||||
|  |  | |||
|  | @ -243,6 +243,33 @@ void UDPClient::OnPadData(Response::PadData data, std::size_t client) { | |||
|     }; | ||||
|     const PadIdentifier identifier = GetPadIdentifier(pad_index); | ||||
|     SetMotion(identifier, 0, motion); | ||||
| 
 | ||||
|     for (std::size_t id = 0; id < data.touch.size(); ++id) { | ||||
|         const auto touch_pad = data.touch[id]; | ||||
|         const int touch_id = static_cast<int>(client * 2 + id); | ||||
| 
 | ||||
|         // TODO: Use custom calibration per device
 | ||||
|         const Common::ParamPackage touch_param(Settings::values.touch_device.GetValue()); | ||||
|         const u16 min_x = static_cast<u16>(touch_param.Get("min_x", 100)); | ||||
|         const u16 min_y = static_cast<u16>(touch_param.Get("min_y", 50)); | ||||
|         const u16 max_x = static_cast<u16>(touch_param.Get("max_x", 1800)); | ||||
|         const u16 max_y = static_cast<u16>(touch_param.Get("max_y", 850)); | ||||
| 
 | ||||
|         const f32 x = | ||||
|             static_cast<f32>(std::clamp(static_cast<u16>(touch_pad.x), min_x, max_x) - min_x) / | ||||
|             static_cast<f32>(max_x - min_x); | ||||
|         const f32 y = | ||||
|             static_cast<f32>(std::clamp(static_cast<u16>(touch_pad.y), min_y, max_y) - min_y) / | ||||
|             static_cast<f32>(max_y - min_y); | ||||
| 
 | ||||
|         if (touch_pad.is_active) { | ||||
|             SetAxis(identifier, touch_id * 2, x); | ||||
|             SetAxis(identifier, touch_id * 2 + 1, y); | ||||
|             SetButton(identifier, touch_id, true); | ||||
|             continue; | ||||
|         } | ||||
|         SetButton(identifier, touch_id, false); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void UDPClient::StartCommunication(std::size_t client, const std::string& host, u16 port) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 german77
						german77