Simple fix, and honestly I should eliminate this whole thing and use one unified event system. Closes #1.
This commit is contained in:
		
							parent
							
								
									af3568154a
								
							
						
					
					
						commit
						265e53e05a
					
				
					 2 changed files with 11 additions and 12 deletions
				
			
		
							
								
								
									
										20
									
								
								gui/fsm.cpp
									
										
									
									
									
								
							
							
						
						
									
										20
									
								
								gui/fsm.cpp
									
										
									
									
									
								
							|  | @ -198,6 +198,14 @@ namespace gui { | ||||||
|       case MOUSE_MOVE: |       case MOUSE_MOVE: | ||||||
|         mouse_action(true); |         mouse_action(true); | ||||||
|         break; |         break; | ||||||
|  |       case AIM_CLICK: { | ||||||
|  |           auto aimed_at = $main_ui.camera_aim(); | ||||||
|  | 
 | ||||||
|  |           if(aimed_at) { | ||||||
|  |             // this will then send LOOT_ITEM if it's valid
 | ||||||
|  |             System::pickup($level, aimed_at); | ||||||
|  |           } | ||||||
|  |         } break; | ||||||
|       default: |       default: | ||||||
|         break; // ignore everything else
 |         break; // ignore everything else
 | ||||||
|     } |     } | ||||||
|  | @ -465,17 +473,9 @@ namespace gui { | ||||||
|         case eGUI::INV_SELECT: |         case eGUI::INV_SELECT: | ||||||
|           event(Event::INV_SELECT, data); |           event(Event::INV_SELECT, data); | ||||||
|           break; |           break; | ||||||
|         case eGUI::AIM_CLICK: { |         case eGUI::AIM_CLICK: | ||||||
|             auto aimed_at = $main_ui.camera_aim(); |  | ||||||
| 
 |  | ||||||
|             if(aimed_at && !in_state(State::LOOTING)) { |  | ||||||
|               // aimed at something and not looting so it's a pickup
 |  | ||||||
|               System::pickup($level, aimed_at); |  | ||||||
|             } else { |  | ||||||
|               // otherwise just repeat the event and let the FSM deal
 |  | ||||||
|           event(Event::AIM_CLICK); |           event(Event::AIM_CLICK); | ||||||
|             } |           break; | ||||||
|           } break; |  | ||||||
|         case eGUI::LOOT_ITEM: { |         case eGUI::LOOT_ITEM: { | ||||||
|           dbc::check(world.has<components::InventoryItem>(entity), |           dbc::check(world.has<components::InventoryItem>(entity), | ||||||
|               "INVALID LOOT_ITEM, that entity has no InventoryItem"); |               "INVALID LOOT_ITEM, that entity has no InventoryItem"); | ||||||
|  |  | ||||||
|  | @ -103,7 +103,6 @@ namespace gui { | ||||||
|     $rayview.update_level($level); |     $rayview.update_level($level); | ||||||
|     $rayview.position_camera(player.x + 0.5, player.y + 0.5); |     $rayview.position_camera(player.x + 0.5, player.y + 0.5); | ||||||
| 
 | 
 | ||||||
|     // BUG #57: I think this is in the wrong direction?
 |  | ||||||
|     player_position.aiming_at = $rayview.aiming_at; |     player_position.aiming_at = $rayview.aiming_at; | ||||||
| 
 | 
 | ||||||
|     $compass_dir = 0; |     $compass_dir = 0; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw