| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  | // Copyright 2020 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | #include "common/quaternion.h"
 | 
					
						
							|  |  |  | #include "common/vector_math.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Core::HID { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class MotionInput { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit MotionInput(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MotionInput(const MotionInput&) = default; | 
					
						
							|  |  |  |     MotionInput& operator=(const MotionInput&) = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MotionInput(MotionInput&&) = default; | 
					
						
							|  |  |  |     MotionInput& operator=(MotionInput&&) = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SetPID(f32 new_kp, f32 new_ki, f32 new_kd); | 
					
						
							|  |  |  |     void SetAcceleration(const Common::Vec3f& acceleration); | 
					
						
							|  |  |  |     void SetGyroscope(const Common::Vec3f& gyroscope); | 
					
						
							|  |  |  |     void SetQuaternion(const Common::Quaternion<f32>& quaternion); | 
					
						
							|  |  |  |     void SetGyroDrift(const Common::Vec3f& drift); | 
					
						
							|  |  |  |     void SetGyroThreshold(f32 threshold); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void EnableReset(bool reset); | 
					
						
							|  |  |  |     void ResetRotations(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void UpdateRotation(u64 elapsed_time); | 
					
						
							|  |  |  |     void UpdateOrientation(u64 elapsed_time); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] std::array<Common::Vec3f, 3> GetOrientation() const; | 
					
						
							|  |  |  |     [[nodiscard]] Common::Vec3f GetAcceleration() const; | 
					
						
							|  |  |  |     [[nodiscard]] Common::Vec3f GetGyroscope() const; | 
					
						
							|  |  |  |     [[nodiscard]] Common::Vec3f GetRotations() const; | 
					
						
							|  |  |  |     [[nodiscard]] Common::Quaternion<f32> GetQuaternion() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] bool IsMoving(f32 sensitivity) const; | 
					
						
							|  |  |  |     [[nodiscard]] bool IsCalibrated(f32 sensitivity) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     void ResetOrientation(); | 
					
						
							|  |  |  |     void SetOrientationFromAccelerometer(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // PID constants
 | 
					
						
							|  |  |  |     f32 kp; | 
					
						
							|  |  |  |     f32 ki; | 
					
						
							|  |  |  |     f32 kd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // PID errors
 | 
					
						
							|  |  |  |     Common::Vec3f real_error; | 
					
						
							|  |  |  |     Common::Vec3f integral_error; | 
					
						
							|  |  |  |     Common::Vec3f derivative_error; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  |     // Quaternion containing the device orientation
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     Common::Quaternion<f32> quat{{0.0f, 0.0f, -1.0f}, 0.0f}; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Number of full rotations in each axis
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     Common::Vec3f rotations; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Acceleration vector measurement in G force
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     Common::Vec3f accel; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Gyroscope vector measurement in radians/s.
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     Common::Vec3f gyro; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Vector to be substracted from gyro measurements
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     Common::Vec3f gyro_drift; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  |     // Minimum gyro amplitude to detect if the device is moving
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     f32 gyro_threshold = 0.0f; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Number of invalid sequential data
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     u32 reset_counter = 0; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // If the provided data is invalid the device will be autocalibrated
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     bool reset_enabled = true; | 
					
						
							| 
									
										
										
										
											2021-11-01 19:49:14 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Use accelerometer values to calculate position
 | 
					
						
							| 
									
										
										
										
											2021-09-20 16:29:43 -05:00
										 |  |  |     bool only_accelerometer = true; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Core::HID
 |