mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-22 13:57:48 +00:00 
			
		
		
		
	input_common: touch: Rewrite touch driver to support multiple touch points
This commit is contained in:
		
							parent
							
								
									6c08d6ce1c
								
							
						
					
					
						commit
						b6d3a7d8cf
					
				
					 8 changed files with 140 additions and 92 deletions
				
			
		|  | @ -44,7 +44,6 @@ void Controller_Touchscreen::OnUpdate(const Core::Timing::CoreTiming& core_timin | |||
|     for (std::size_t id = 0; id < MAX_FINGERS; id++) { | ||||
|         const auto& current_touch = touch_status[id]; | ||||
|         auto& finger = fingers[id]; | ||||
|         finger.position = current_touch.position; | ||||
|         finger.id = current_touch.id; | ||||
| 
 | ||||
|         if (finger.attribute.start_touch) { | ||||
|  | @ -61,13 +60,18 @@ void Controller_Touchscreen::OnUpdate(const Core::Timing::CoreTiming& core_timin | |||
|         if (!finger.pressed && current_touch.pressed) { | ||||
|             finger.attribute.start_touch.Assign(1); | ||||
|             finger.pressed = true; | ||||
|             finger.position = current_touch.position; | ||||
|             continue; | ||||
|         } | ||||
| 
 | ||||
|         if (finger.pressed && !current_touch.pressed) { | ||||
|             finger.attribute.raw = 0; | ||||
|             finger.attribute.end_touch.Assign(1); | ||||
|             continue; | ||||
|         } | ||||
| 
 | ||||
|         // Only update position if touch is not on a special frame
 | ||||
|         finger.position = current_touch.position; | ||||
|     } | ||||
| 
 | ||||
|     std::array<Core::HID::TouchFinger, MAX_FINGERS> active_fingers; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 german77
						german77