forked from eden-emu/eden
		
	Enable mouse toggle buttons
This commit is contained in:
		
							parent
							
								
									0b24257e2c
								
							
						
					
					
						commit
						9c42c9e164
					
				
					 5 changed files with 65 additions and 11 deletions
				
			
		|  | @ -157,6 +157,42 @@ void Mouse::EndConfiguration() { | |||
|     configuring = false; | ||||
| } | ||||
| 
 | ||||
| bool Mouse::ToggleButton(std::size_t button_) { | ||||
|     if (button_ >= mouse_info.size()) { | ||||
|         return false; | ||||
|     } | ||||
|     const auto button = 1U << button_; | ||||
|     const bool button_state = (toggle_buttons & button) != 0; | ||||
|     const bool button_lock = (lock_buttons & button) != 0; | ||||
| 
 | ||||
|     if (button_lock) { | ||||
|         return button_state; | ||||
|     } | ||||
| 
 | ||||
|     lock_buttons |= static_cast<u16>(button); | ||||
| 
 | ||||
|     if (button_state) { | ||||
|         toggle_buttons &= static_cast<u16>(0xFF - button); | ||||
|     } else { | ||||
|         toggle_buttons |= static_cast<u16>(button); | ||||
|     } | ||||
| 
 | ||||
|     return !button_state; | ||||
| } | ||||
| 
 | ||||
| bool Mouse::UnlockButton(std::size_t button_) { | ||||
|     if (button_ >= mouse_info.size()) { | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|     const auto button = 1U << button_; | ||||
|     const bool button_state = (toggle_buttons & button) != 0; | ||||
| 
 | ||||
|     lock_buttons &= static_cast<u16>(0xFF - button); | ||||
| 
 | ||||
|     return button_state; | ||||
| } | ||||
| 
 | ||||
| Common::SPSCQueue<MouseStatus>& Mouse::GetMouseQueue() { | ||||
|     return mouse_queue; | ||||
| } | ||||
|  |  | |||
|  | @ -67,6 +67,9 @@ public: | |||
|      */ | ||||
|     void ReleaseButton(int button_); | ||||
| 
 | ||||
|     [[nodiscard]] bool ToggleButton(std::size_t button_); | ||||
|     [[nodiscard]] bool UnlockButton(std::size_t button_); | ||||
| 
 | ||||
|     [[nodiscard]] Common::SPSCQueue<MouseStatus>& GetMouseQueue(); | ||||
|     [[nodiscard]] const Common::SPSCQueue<MouseStatus>& GetMouseQueue() const; | ||||
| 
 | ||||
|  | @ -92,6 +95,8 @@ private: | |||
|     }; | ||||
| 
 | ||||
|     u16 buttons{}; | ||||
|     u16 toggle_buttons{}; | ||||
|     u16 lock_buttons{}; | ||||
|     std::thread update_thread; | ||||
|     MouseButton last_button{MouseButton::Undefined}; | ||||
|     std::array<MouseInfo, 5> mouse_info; | ||||
|  |  | |||
|  | @ -14,16 +14,25 @@ namespace InputCommon { | |||
| 
 | ||||
| class MouseButton final : public Input::ButtonDevice { | ||||
| public: | ||||
|     explicit MouseButton(u32 button_, const MouseInput::Mouse* mouse_input_) | ||||
|         : button(button_), mouse_input(mouse_input_) {} | ||||
|     explicit MouseButton(u32 button_, bool toggle_, MouseInput::Mouse* mouse_input_) | ||||
|         : button(button_), toggle(toggle_), mouse_input(mouse_input_) {} | ||||
| 
 | ||||
|     bool GetStatus() const override { | ||||
|         return mouse_input->GetMouseState(button).pressed; | ||||
|         const bool button_state = mouse_input->GetMouseState(button).pressed; | ||||
|         if (!toggle) { | ||||
|             return button_state; | ||||
|         } | ||||
| 
 | ||||
|         if (button_state) { | ||||
|             return mouse_input->ToggleButton(button); | ||||
|         } | ||||
|         return mouse_input->UnlockButton(button); | ||||
|     } | ||||
| 
 | ||||
| private: | ||||
|     const u32 button; | ||||
|     const MouseInput::Mouse* mouse_input; | ||||
|     const bool toggle; | ||||
|     MouseInput::Mouse* mouse_input; | ||||
| }; | ||||
| 
 | ||||
| MouseButtonFactory::MouseButtonFactory(std::shared_ptr<MouseInput::Mouse> mouse_input_) | ||||
|  | @ -32,8 +41,9 @@ MouseButtonFactory::MouseButtonFactory(std::shared_ptr<MouseInput::Mouse> mouse_ | |||
| std::unique_ptr<Input::ButtonDevice> MouseButtonFactory::Create( | ||||
|     const Common::ParamPackage& params) { | ||||
|     const auto button_id = params.Get("button", 0); | ||||
|     const auto toggle = params.Get("toggle", false); | ||||
| 
 | ||||
|     return std::make_unique<MouseButton>(button_id, mouse_input.get()); | ||||
|     return std::make_unique<MouseButton>(button_id, toggle, mouse_input.get()); | ||||
| } | ||||
| 
 | ||||
| Common::ParamPackage MouseButtonFactory::GetNextInput() const { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 german77
						german77