Loot UI is now mostly formed, just need to get loot into it and make it work.
This commit is contained in:
		
							parent
							
								
									8545b8cf1d
								
							
						
					
					
						commit
						dfc6aa08e9
					
				
					 12 changed files with 38 additions and 146 deletions
				
			
		
							
								
								
									
										15
									
								
								color.hpp
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								color.hpp
									
										
									
									
									
								
							|  | @ -1,15 +0,0 @@ | |||
| #pragma once | ||||
| #include <SFML/Graphics/Color.hpp> | ||||
| 
 | ||||
| namespace ColorValue { | ||||
|   constexpr const sf::Color BLACK{0, 0, 0}; | ||||
|   constexpr const sf::Color DARK_DARK{10, 10, 10}; | ||||
|   constexpr const sf::Color DARK_MID{30, 30, 30}; | ||||
|   constexpr const sf::Color DARK_LIGHT{60, 60, 60}; | ||||
|   constexpr const sf::Color MID{100, 100, 100}; | ||||
|   constexpr const sf::Color LIGHT_DARK{150, 150, 150}; | ||||
|   constexpr const sf::Color LIGHT_MID{200, 200, 200}; | ||||
|   constexpr const sf::Color LIGHT_LIGHT{230, 230, 230}; | ||||
|   constexpr const sf::Color WHITE{255, 255, 255}; | ||||
|   constexpr const sf::Color TRANSPARENT = sf::Color::Transparent; | ||||
| } | ||||
|  | @ -1,7 +1,6 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <string> | ||||
| #include "color.hpp" | ||||
| #include <array> | ||||
| 
 | ||||
| constexpr const int INV_SLOTS=20; | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ namespace Events { | |||
|     START, COMBAT, LOOT, DEATH, STAIRS_UP, STAIRS_DOWN, TRAP, | ||||
|     COMBAT_START, NO_NEIGHBORS, HP_STATUS, | ||||
|     ATTACK, BLOCK, EVADE, NEW_RITUAL, | ||||
|     UPDATE_SPRITE, ENEMY_SPAWN, NOOP | ||||
|     UPDATE_SPRITE, ENEMY_SPAWN, NOOP, LOOT_CLOSE | ||||
|   }; | ||||
| 
 | ||||
|   struct Combat { | ||||
|  |  | |||
|  | @ -1,6 +1,5 @@ | |||
| #include "gui/combat_ui.hpp" | ||||
| #include "constants.hpp" | ||||
| #include "color.hpp" | ||||
| #include "rituals.hpp" | ||||
| #include <fmt/xchar.h> | ||||
| #include "guecstra.hpp" | ||||
|  | @ -37,7 +36,8 @@ namespace gui { | |||
|   } | ||||
| 
 | ||||
|   void CombatUI::init() { | ||||
|     $gui.set<Background>($gui.MAIN, {$gui.$parser, ColorValue::DARK_MID}); | ||||
|     using guecs::THEME; | ||||
|     $gui.set<Background>($gui.MAIN, {$gui.$parser, THEME.DARK_MID}); | ||||
|     auto& the_belt = $level.world->get_the<ritual::Belt>(); | ||||
| 
 | ||||
|     for(int slot = 0; slot < the_belt.max_slots; slot++) { | ||||
|  |  | |||
|  | @ -1,6 +1,5 @@ | |||
| #include "gui/debug_ui.hpp" | ||||
| #include "constants.hpp" | ||||
| #include "color.hpp" | ||||
| #include "events.hpp" | ||||
| #include <optional> | ||||
| #include <fmt/core.h> | ||||
|  |  | |||
|  | @ -420,6 +420,10 @@ namespace gui { | |||
|         case eGUI::NO_NEIGHBORS: | ||||
|           event(Event::STOP_COMBAT); | ||||
|           break; | ||||
|         case eGUI::LOOT_CLOSE: | ||||
|           // BUG: need to resolve GUI events vs. FSM events better
 | ||||
|           event(Event::LOOT_OPEN); | ||||
|           break; | ||||
|         case eGUI::LOOT: { | ||||
|             // auto &item = std::any_cast<InventoryItem&>(data);
 | ||||
|             // $status_ui.log(fmt::format("You picked up a {}.",
 | ||||
|  |  | |||
|  | @ -1,6 +1,5 @@ | |||
| #include "gui/loot_ui.hpp" | ||||
| #include "constants.hpp" | ||||
| #include "color.hpp" | ||||
| #include <fmt/xchar.h> | ||||
| #include "guecstra.hpp" | ||||
| 
 | ||||
|  | @ -14,25 +13,40 @@ namespace gui { | |||
|         RAY_VIEW_Y+RAY_VIEW_HEIGHT/2-200, 400, 400); | ||||
| 
 | ||||
|     $gui.layout( | ||||
|         "[button_0 | button_1|button_2 | button_3]" | ||||
|         "[button_4 | button_5|button_6 | button_7]" | ||||
|         "[button_8 | button_9|button_10 | button_11]" | ||||
|         "[button_12 | button_13|button_14 | button_15]" | ||||
|         "[item_0 | item_1|item_2 | item_3]" | ||||
|         "[item_4 | item_5|item_6 | item_7]" | ||||
|         "[item_8 | item_9|item_10 | item_11]" | ||||
|         "[button_12|button_13|button_14|button_15]" | ||||
|         "[_ | *%(200)close|_ | _]" | ||||
|         ); | ||||
|   } | ||||
| 
 | ||||
|   void LootUI::init() { | ||||
|     $gui.set<Background>($gui.MAIN, {$gui.$parser, ColorValue::DARK_MID}); | ||||
|     for(auto [name, cell] : $gui.cells()) { | ||||
|       auto id = $gui.entity(name); | ||||
|       $gui.set<guecs::Rectangle>(id, {}); | ||||
|       if(id < 4) { | ||||
|     using guecs::THEME; | ||||
|     auto bg_color = THEME.DARK_LIGHT; | ||||
|     bg_color.a = 140; | ||||
|     $gui.set<Background>($gui.MAIN, {$gui.$parser, bg_color}); | ||||
| 
 | ||||
|     // fill in 4 slots for prototype
 | ||||
|     for(int i = 0; i < 4; i++) { | ||||
|       auto id = $gui.entity("item_", i); | ||||
| 
 | ||||
|       $gui.set<guecs::Rectangle>(id, {THEME.PADDING, | ||||
|           THEME.TRANSPARENT, THEME.LIGHT_MID }); | ||||
| 
 | ||||
|       $gui.set<guecs::Effect>(id, {0.4f, "ui_shader"}); | ||||
|       $gui.set<guecs::Clickable>(id, { | ||||
|             [=](auto, auto) { fmt::println("clicked {}", name); } | ||||
|           [=](auto, auto) { fmt::println("clicked button_{}", i); } | ||||
|       }); | ||||
|       $gui.set<guecs::Sprite>(id, {"broken_yoyo-64"}); | ||||
|     } | ||||
|     } | ||||
| 
 | ||||
|     auto close = $gui.entity("close"); | ||||
|     $gui.set<guecs::Rectangle>(close, {}); | ||||
|     $gui.set<guecs::Label>(close, {L"CLOSE"}); | ||||
|     $gui.set<guecs::Clickable>(close, | ||||
|         guecs::make_action(*$level.world, Events::GUI::LOOT_CLOSE)); | ||||
| 
 | ||||
|     $gui.init(); | ||||
|   } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,6 +1,5 @@ | |||
| #include "gui/overlay_ui.hpp" | ||||
| #include "constants.hpp" | ||||
| #include "color.hpp" | ||||
| #include "events.hpp" | ||||
| #include <optional> | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,7 +1,6 @@ | |||
| #include "gui/status_ui.hpp" | ||||
| #include "components.hpp" | ||||
| #include "inventory.hpp" | ||||
| #include "color.hpp" | ||||
| #include <guecs/ui.hpp> | ||||
| #include "rand.hpp" | ||||
| #include <fmt/xchar.h> | ||||
|  |  | |||
							
								
								
									
										55
									
								
								lel.hpp
									
										
									
									
									
								
							
							
						
						
									
										55
									
								
								lel.hpp
									
										
									
									
									
								
							|  | @ -1,55 +0,0 @@ | |||
| #pragma once | ||||
| #include <string> | ||||
| #include <unordered_map> | ||||
| #include <functional> | ||||
| #include <optional> | ||||
| #include <vector> | ||||
| 
 | ||||
| namespace lel { | ||||
| 
 | ||||
|   struct Cell { | ||||
|     int x = 0; | ||||
|     int y = 0; | ||||
|     int w = 0; | ||||
|     int h = 0; | ||||
|     int mid_x = 0; | ||||
|     int mid_y = 0; | ||||
|     int max_w = 0; | ||||
|     int max_h = 0; | ||||
|     int col = 0; | ||||
|     int row = 0; | ||||
|     bool right = false; | ||||
|     bool bottom = false; | ||||
|     bool expand = false; | ||||
|     bool center = false; | ||||
|     bool percent = false; | ||||
| 
 | ||||
|     Cell(int col, int row) : col(col), row(row) {} | ||||
|     Cell() {} | ||||
|   }; | ||||
| 
 | ||||
|   using Row = std::vector<std::string>; | ||||
|   using CellMap = std::unordered_map<std::string, Cell>; | ||||
| 
 | ||||
|   struct Parser { | ||||
|     int grid_x = 0; | ||||
|     int grid_y = 0; | ||||
|     int grid_w = 0; | ||||
|     int grid_h = 0; | ||||
|     Cell cur; | ||||
|     std::vector<Row> grid; | ||||
|     CellMap cells; | ||||
| 
 | ||||
|     Parser(int x, int y, int width, int height); | ||||
|     Parser(); | ||||
| 
 | ||||
|     void position(int x, int y, int width, int height); | ||||
|     void id(std::string name); | ||||
|     void reset(); | ||||
|     bool parse(std::string input); | ||||
|     void finalize(); | ||||
|     std::optional<std::string> hit(int x, int y); | ||||
|   }; | ||||
| 
 | ||||
|   Cell center(int width, int height, Cell &parent); | ||||
| } | ||||
|  | @ -139,7 +139,6 @@ executable('runtests', sources + [ | |||
|   'tests/easings.cpp', | ||||
|   'tests/fsm.cpp', | ||||
|   'tests/inventory.cpp', | ||||
|   'tests/lel.cpp', | ||||
|   'tests/levelmanager.cpp', | ||||
|   'tests/lighting.cpp', | ||||
|   'tests/map.cpp', | ||||
|  | @ -167,7 +166,8 @@ executable('zedcaster', | |||
|   dependencies: dependencies) | ||||
| 
 | ||||
| executable('fragviewer', | ||||
|   sources + [ 'tools/fragviewer.cpp' ], | ||||
|   [ 'textures.cpp', 'config.cpp', | ||||
|     'dbc.cpp', 'tools/fragviewer.cpp' ], | ||||
|   cpp_args: cpp_args, | ||||
|   link_args: link_args, | ||||
|   override_options: exe_defaults, | ||||
|  |  | |||
|  | @ -1,52 +0,0 @@ | |||
| #include "lel.hpp" | ||||
| #include <catch2/catch_test_macros.hpp> | ||||
| #include <fmt/core.h> | ||||
| #include <string> | ||||
| 
 | ||||
| TEST_CASE("test basic ops", "[lel]") { | ||||
|   lel::Parser parser(0, 0, 500, 500); | ||||
| 
 | ||||
|   bool good = parser.parse( | ||||
|      "[ label_1         | label3      | test1]" | ||||
|      "[ *(300,300)text1 | %(150)people | ^test2]" | ||||
|      "[ >label2         | _           | .test3]" | ||||
|      "[ =message        | buttons     | test4]"); | ||||
| 
 | ||||
|   REQUIRE(good); | ||||
| 
 | ||||
|   for(size_t rowcount = 0; rowcount < parser.grid.size(); rowcount++) { | ||||
|     auto& row = parser.grid[rowcount]; | ||||
| 
 | ||||
|     for(size_t colcount = 0; colcount < row.size(); colcount++) { | ||||
|       auto &name = row[colcount]; | ||||
|       if(name == "_") { | ||||
|         REQUIRE(!parser.cells.contains(name)); | ||||
|       } else { | ||||
|         auto &cell = parser.cells.at(name); | ||||
|         REQUIRE(cell.row == int(rowcount)); | ||||
|         REQUIRE(cell.col == int(colcount)); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   REQUIRE(parser.cells.size() == 11); | ||||
|   REQUIRE(parser.cells.at("label2").right == true); | ||||
|   REQUIRE(parser.cells.at("text1").expand == true); | ||||
|   REQUIRE(parser.cells.at("text1").w == 300); | ||||
|   REQUIRE(parser.cells.at("text1").h == 300); | ||||
|   REQUIRE(parser.cells.at("people").expand == false); | ||||
|   REQUIRE(parser.cells.at("message").expand == false); | ||||
|   REQUIRE(parser.cells.at("message").center == true); | ||||
| 
 | ||||
|   for(auto& [name, cell] : parser.cells) { | ||||
|     REQUIRE(cell.w > 0); | ||||
|     REQUIRE(cell.h > 0); | ||||
|   } | ||||
| 
 | ||||
|   auto hit = parser.hit(10, 10); | ||||
|   REQUIRE(*hit == "label_1"); | ||||
| 
 | ||||
|   auto nohit = parser.hit(1000, 1000); | ||||
|   REQUIRE(!nohit); | ||||
|   REQUIRE(nohit == std::nullopt); | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw