Fixed the problem where the only way to complete a grab/drop operation was to capture the MOUSE_CLICK directly. Solution was to move the mouse processing out of DNDLoot and only handle the MOUSE_MOVE/DRAG.
This commit is contained in:
		
							parent
							
								
									6a72d1160f
								
							
						
					
					
						commit
						f559b5a39d
					
				
					 6 changed files with 32 additions and 43 deletions
				
			
		|  | @ -48,10 +48,6 @@ namespace gui { | ||||||
|         $grab_source = start_grab($status_ui.$gui, data); |         $grab_source = start_grab($status_ui.$gui, data); | ||||||
|         if($grab_source) state(DNDState::INV_GRAB); |         if($grab_source) state(DNDState::INV_GRAB); | ||||||
|         break; |         break; | ||||||
|       case MOUSE_DRAG_START: |  | ||||||
|       case MOUSE_CLICK: |  | ||||||
|         mouse_action(false); |  | ||||||
|         break; |  | ||||||
|       default: |       default: | ||||||
|         state(DNDState::LOOTING); |         state(DNDState::LOOTING); | ||||||
|     } |     } | ||||||
|  | @ -108,8 +104,8 @@ namespace gui { | ||||||
|     (void)data; |     (void)data; | ||||||
| 
 | 
 | ||||||
|     switch(ev) { |     switch(ev) { | ||||||
|       case MOUSE_CLICK: |       case AIM_CLICK: { | ||||||
|       case MOUSE_DROP: { |         fmt::println("IN INV_PICKUP AIM CLICK!"); | ||||||
|         auto& grab = $status_ui.$gui.get<guecs::GrabSource>(*$grab_source); |         auto& grab = $status_ui.$gui.get<guecs::GrabSource>(*$grab_source); | ||||||
|         grab.commit(); |         grab.commit(); | ||||||
|         bool dropped = $status_ui.drop_item(grab.world_entity); |         bool dropped = $status_ui.drop_item(grab.world_entity); | ||||||
|  | @ -132,7 +128,6 @@ namespace gui { | ||||||
|         } |         } | ||||||
|         break; |         break; | ||||||
|       case LOOT_ITEM: |       case LOOT_ITEM: | ||||||
|         dbc::log("PUT IT BACK!"); |  | ||||||
|         break; |         break; | ||||||
|       default: |       default: | ||||||
|          handle_mouse(ev, $loot_ui.$gui); |          handle_mouse(ev, $loot_ui.$gui); | ||||||
|  | @ -183,37 +178,17 @@ namespace gui { | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   sf::Vector2f DNDLoot::mouse_position() { |  | ||||||
|     return $window.mapPixelToCoords($router.position); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   void DNDLoot::mouse_action(bool hover) { |  | ||||||
|     sf::Vector2f pos = mouse_position(); |  | ||||||
|     $status_ui.mouse(pos.x, pos.y, hover); |  | ||||||
|     if($loot_ui.active) $loot_ui.mouse(pos.x, pos.y, hover); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   void DNDLoot::handle_mouse(Event ev, guecs::UI& gui) { |   void DNDLoot::handle_mouse(Event ev, guecs::UI& gui) { | ||||||
|     using enum Event; |     using enum Event; | ||||||
| 
 | 
 | ||||||
|     switch(ev) { |     switch(ev) { | ||||||
|       case MOUSE_CLICK: |  | ||||||
|         mouse_action(false); |  | ||||||
|         break; |  | ||||||
|       case MOUSE_DRAG: |       case MOUSE_DRAG: | ||||||
|       case MOUSE_MOVE: { |       case MOUSE_MOVE: { | ||||||
|            if($grab_source) { |            if($grab_source) { | ||||||
|              auto& source = gui.get<guecs::GrabSource>(*$grab_source); |              auto& source = gui.get<guecs::GrabSource>(*$grab_source); | ||||||
|              source.move($window.mapPixelToCoords($router.position)); |              source.move($window.mapPixelToCoords($router.position)); | ||||||
|            } |            } | ||||||
|            mouse_action(true); |  | ||||||
|          } break; |          } break; | ||||||
|       case MOUSE_DRAG_START: |  | ||||||
|            mouse_action(false); |  | ||||||
|          break; |  | ||||||
|       case MOUSE_DROP: |  | ||||||
|          mouse_action(false); |  | ||||||
|          break; |  | ||||||
|       default: |       default: | ||||||
|          break; // ignored
 |          break; // ignored
 | ||||||
|     } |     } | ||||||
|  | @ -234,8 +209,6 @@ namespace gui { | ||||||
|   void DNDLoot::render() { |   void DNDLoot::render() { | ||||||
|     if($grab_source && $grab_sprite) { |     if($grab_source && $grab_sprite) { | ||||||
|       $window.draw(*$grab_sprite); |       $window.draw(*$grab_sprite); | ||||||
|     } else { |  | ||||||
|       dbc::log("nothing to render!"); |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -40,7 +40,6 @@ namespace gui { | ||||||
|       void INV_PICKUP(Event ev, std::any data); |       void INV_PICKUP(Event ev, std::any data); | ||||||
| 
 | 
 | ||||||
|       void handle_mouse(Event ev, guecs::UI& gui); |       void handle_mouse(Event ev, guecs::UI& gui); | ||||||
|       void mouse_action(bool hover); |  | ||||||
|       void render(); |       void render(); | ||||||
|       void open(); |       void open(); | ||||||
|       void close(); |       void close(); | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								gui/fsm.cpp
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								gui/fsm.cpp
									
										
									
									
									
								
							|  | @ -93,7 +93,6 @@ namespace gui { | ||||||
|         state(State::IN_COMBAT); |         state(State::IN_COMBAT); | ||||||
|        } break; |        } break; | ||||||
|       case STOP_COMBAT: |       case STOP_COMBAT: | ||||||
|         dbc::log("Exiting ATTACKING STATE"); |  | ||||||
|         state(State::IDLE); |         state(State::IDLE); | ||||||
|         break; |         break; | ||||||
|       case ATTACK: |       case ATTACK: | ||||||
|  | @ -118,10 +117,20 @@ namespace gui { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   void FSM::LOOTING(Event ev, std::any data) { |   void FSM::LOOTING(Event ev, std::any data) { | ||||||
|  |     using enum Event; | ||||||
|  | 
 | ||||||
|  |     switch(ev) { | ||||||
|  |       case MOUSE_DRAG_START: | ||||||
|  |       case MOUSE_CLICK: | ||||||
|  |       case MOUSE_DROP: | ||||||
|  |         mouse_action(false); | ||||||
|  |         break; | ||||||
|  |       default: | ||||||
|         if(!$dnd_loot.event(ev, data)) { |         if(!$dnd_loot.event(ev, data)) { | ||||||
|           state(State::IDLE); |           state(State::IDLE); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   void FSM::IDLE(Event ev, std::any data) { |   void FSM::IDLE(Event ev, std::any data) { | ||||||
|     using enum Event; |     using enum Event; | ||||||
|  | @ -278,6 +287,7 @@ namespace gui { | ||||||
|     if($debug_ui.active) $debug_ui.mouse(pos.x, pos.y, hover); |     if($debug_ui.active) $debug_ui.mouse(pos.x, pos.y, hover); | ||||||
|     $combat_ui.mouse(pos.x, pos.y, hover); |     $combat_ui.mouse(pos.x, pos.y, hover); | ||||||
|     $status_ui.mouse(pos.x, pos.y, hover); |     $status_ui.mouse(pos.x, pos.y, hover); | ||||||
|  | 
 | ||||||
|     if($loot_ui.active) { |     if($loot_ui.active) { | ||||||
|       $loot_ui.mouse(pos.x, pos.y, hover); |       $loot_ui.mouse(pos.x, pos.y, hover); | ||||||
|     } else { |     } else { | ||||||
|  | @ -459,7 +469,8 @@ namespace gui { | ||||||
|             fmt::println("clicked on a thing: {}", aimed_at); |             fmt::println("clicked on a thing: {}", aimed_at); | ||||||
|             System::pickup($level, aimed_at); |             System::pickup($level, aimed_at); | ||||||
|           } else { |           } else { | ||||||
|             dbc::log("there's no thing there!"); |             fmt::println("SENDING AIM_CLICK"); | ||||||
|  |             event(Event::AIM_CLICK); | ||||||
|           } |           } | ||||||
|           break; |           break; | ||||||
|         case eGUI::LOOT_ITEM: { |         case eGUI::LOOT_ITEM: { | ||||||
|  |  | ||||||
|  | @ -26,6 +26,7 @@ namespace gui { | ||||||
|     MOUSE_DRAG=21, |     MOUSE_DRAG=21, | ||||||
|     MOUSE_DRAG_START=22, |     MOUSE_DRAG_START=22, | ||||||
|     MOUSE_DROP=23, |     MOUSE_DROP=23, | ||||||
|     KEY_PRESS=24 |     KEY_PRESS=24, | ||||||
|  |     AIM_CLICK=25 | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -16,17 +16,23 @@ namespace gui { | ||||||
|         ); |         ); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   void OverlayUI::init() { |   inline void make_clickable_area(GameLevel& level, guecs::UI &gui, const std::string &name) { | ||||||
|     $gui.init(); |     auto area = gui.entity(name); | ||||||
|     auto bottom = $gui.entity("bottom"); | 
 | ||||||
|     $gui.set<Clickable>(bottom, { |     gui.set<Clickable>(area, { | ||||||
|       [&](auto ent, auto data) { |       [&](auto ent, auto data) { | ||||||
|           $level.world->send<Events::GUI>( |         level.world->send<Events::GUI>(Events::GUI::AIM_CLICK, ent, data); | ||||||
|               Events::GUI::AIM_CLICK, ent, data); |  | ||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |   void OverlayUI::init() { | ||||||
|  |     $gui.init(); | ||||||
|  |     make_clickable_area($level, $gui, "top"); | ||||||
|  |     make_clickable_area($level, $gui, "middle"); | ||||||
|  |     make_clickable_area($level, $gui, "bottom"); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|   void OverlayUI::render(sf::RenderWindow& window) { |   void OverlayUI::render(sf::RenderWindow& window) { | ||||||
|     $gui.render(window); |     $gui.render(window); | ||||||
|     // $gui.debug_layout(window);
 |     // $gui.debug_layout(window);
 | ||||||
|  |  | ||||||
|  | @ -111,7 +111,6 @@ void System::init_positions(World &world, SpatialMap &collider) { | ||||||
|           collider.insert(pos.location, ent); |           collider.insert(pos.location, ent); | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         fmt::println("System::init_positions for ent={}", ent); |  | ||||||
|         dbc::check(!inv.has(ent), |         dbc::check(!inv.has(ent), | ||||||
|             fmt::format("!!! Entity {} is in player inventory and _also_ has a position in the world.", ent)); |             fmt::format("!!! Entity {} is in player inventory and _also_ has a position in the world.", ent)); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw