| 
									
										
										
										
											2020-09-02 11:58:15 -04:00
										 |  |  | // Copyright 2020 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included
 | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | #include "common/quaternion.h"
 | 
					
						
							|  |  |  | #include "common/vector_math.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-17 20:26:34 -05:00
										 |  |  | #include "core/frontend/input.h"
 | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace InputCommon { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class MotionInput { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-15 14:20:41 -05:00
										 |  |  |     explicit MotionInput(f32 new_kp, f32 new_ki, f32 new_kd); | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 20:41:59 -05:00
										 |  |  |     MotionInput(const MotionInput&) = default; | 
					
						
							|  |  |  |     MotionInput& operator=(const MotionInput&) = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MotionInput(MotionInput&&) = default; | 
					
						
							|  |  |  |     MotionInput& operator=(MotionInput&&) = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SetAcceleration(const Common::Vec3f& acceleration); | 
					
						
							| 
									
										
										
										
											2020-10-14 02:51:14 -04:00
										 |  |  |     void SetGyroscope(const Common::Vec3f& gyroscope); | 
					
						
							| 
									
										
										
										
											2020-08-23 20:41:59 -05:00
										 |  |  |     void SetQuaternion(const Common::Quaternion<f32>& quaternion); | 
					
						
							|  |  |  |     void SetGyroDrift(const Common::Vec3f& drift); | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  |     void SetGyroThreshold(f32 threshold); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void EnableReset(bool reset); | 
					
						
							|  |  |  |     void ResetRotations(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void UpdateRotation(u64 elapsed_time); | 
					
						
							|  |  |  |     void UpdateOrientation(u64 elapsed_time); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-15 14:18:09 -05:00
										 |  |  |     [[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]] Input::MotionStatus GetMotion() const; | 
					
						
							|  |  |  |     [[nodiscard]] Input::MotionStatus GetRandomMotion(int accel_magnitude, | 
					
						
							|  |  |  |                                                       int gyro_magnitude) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] bool IsMoving(f32 sensitivity) const; | 
					
						
							|  |  |  |     [[nodiscard]] bool IsCalibrated(f32 sensitivity) const; | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 20:41:59 -05:00
										 |  |  | private: | 
					
						
							|  |  |  |     void ResetOrientation(); | 
					
						
							| 
									
										
										
										
											2020-10-03 22:22:01 -05:00
										 |  |  |     void SetOrientationFromAccelerometer(); | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // PID constants
 | 
					
						
							| 
									
										
										
										
											2020-10-14 02:51:14 -04:00
										 |  |  |     f32 kp; | 
					
						
							|  |  |  |     f32 ki; | 
					
						
							|  |  |  |     f32 kd; | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // PID errors
 | 
					
						
							|  |  |  |     Common::Vec3f real_error; | 
					
						
							|  |  |  |     Common::Vec3f integral_error; | 
					
						
							|  |  |  |     Common::Vec3f derivative_error; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-14 02:51:14 -04:00
										 |  |  |     Common::Quaternion<f32> quat{{0.0f, 0.0f, -1.0f}, 0.0f}; | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  |     Common::Vec3f rotations; | 
					
						
							|  |  |  |     Common::Vec3f accel; | 
					
						
							|  |  |  |     Common::Vec3f gyro; | 
					
						
							|  |  |  |     Common::Vec3f gyro_drift; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-23 20:41:59 -05:00
										 |  |  |     f32 gyro_threshold = 0.0f; | 
					
						
							| 
									
										
										
										
											2020-08-26 16:49:24 -05:00
										 |  |  |     u32 reset_counter = 0; | 
					
						
							| 
									
										
										
										
											2020-08-23 20:41:59 -05:00
										 |  |  |     bool reset_enabled = true; | 
					
						
							| 
									
										
										
										
											2020-10-03 22:22:01 -05:00
										 |  |  |     bool only_accelerometer = true; | 
					
						
							| 
									
										
										
										
											2020-08-23 19:26:47 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace InputCommon
 |