| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | // Copyright 2017 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-06 05:26:29 +01:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2017-12-06 05:26:29 +01:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2020-06-21 15:31:57 -04:00
										 |  |  | #include "input_common/gcadapter/gc_poller.h"
 | 
					
						
							| 
									
										
										
										
											2017-12-06 05:26:29 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Common { | 
					
						
							|  |  |  | class ParamPackage; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace InputCommon { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Initializes and registers all built-in input device factories.
 | 
					
						
							|  |  |  | void Init(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-14 09:15:39 +12:00
										 |  |  | /// Deregisters all built-in input device factories and shuts them down.
 | 
					
						
							| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | void Shutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Keyboard; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Gets the keyboard button device factory.
 | 
					
						
							|  |  |  | Keyboard* GetKeyboard(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-07 00:04:06 +03:00
										 |  |  | class MotionEmu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Gets the motion emulation factory.
 | 
					
						
							|  |  |  | MotionEmu* GetMotionEmu(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-21 12:36:28 -04:00
										 |  |  | GCButtonFactory* GetGCButtons(); | 
					
						
							| 
									
										
										
										
											2020-06-21 18:43:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-21 12:36:28 -04:00
										 |  |  | GCAnalogFactory* GetGCAnalogs(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | /// Generates a serialized param package for creating a keyboard button device
 | 
					
						
							|  |  |  | std::string GenerateKeyboardParam(int key_code); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-21 13:04:00 +02:00
										 |  |  | /// Generates a serialized param package for creating an analog device taking input from keyboard
 | 
					
						
							|  |  |  | std::string GenerateAnalogParamFromKeys(int key_up, int key_down, int key_left, int key_right, | 
					
						
							|  |  |  |                                         int key_modifier, float modifier_scale); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-06 05:26:29 +01:00
										 |  |  | namespace Polling { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class DeviceType { Button, Analog }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A class that can be used to get inputs from an input device like controllers without having to | 
					
						
							|  |  |  |  * poll the device's status yourself | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class DevicePoller { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual ~DevicePoller() = default; | 
					
						
							|  |  |  |     /// Setup and start polling for inputs, should be called before GetNextInput
 | 
					
						
							|  |  |  |     virtual void Start() = 0; | 
					
						
							|  |  |  |     /// Stop polling
 | 
					
						
							|  |  |  |     virtual void Stop() = 0; | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Every call to this function returns the next input recorded since calling Start | 
					
						
							|  |  |  |      * @return A ParamPackage of the recorded input, which can be used to create an InputDevice. | 
					
						
							|  |  |  |      *         If there has been no input, the package is empty | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual Common::ParamPackage GetNextInput() = 0; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Get all DevicePoller from all backends for a specific device type
 | 
					
						
							|  |  |  | std::vector<std::unique_ptr<DevicePoller>> GetPollers(DeviceType type); | 
					
						
							|  |  |  | } // namespace Polling
 | 
					
						
							| 
									
										
										
										
											2017-01-21 11:53:03 +02:00
										 |  |  | } // namespace InputCommon
 |