Mostly cleaned up world get to handle more rooms and paths, but rando_rect needs to be actually random.
This commit is contained in:
		
							parent
							
								
									c19c53b15b
								
							
						
					
					
						commit
						e9277bf052
					
				
					 11 changed files with 257 additions and 39 deletions
				
			
		|  | @ -13,9 +13,11 @@ TEST_CASE("lighting a map works", "[lighting]") { | |||
|   Map map(20,23); | ||||
|   WorldBuilder builder(map); | ||||
|   builder.generate_map(); | ||||
|   Point light1, light2; | ||||
| 
 | ||||
|   REQUIRE(map.place_entity(0, light1)); | ||||
|   REQUIRE(map.place_entity(1, light1)); | ||||
| 
 | ||||
|   Point light1 = map.place_entity(0); | ||||
|   Point light2 = map.place_entity(1); | ||||
|   LightSource source1{6, 1.0}; | ||||
|   LightSource source2{4,3}; | ||||
| 
 | ||||
|  |  | |||
|  | @ -30,6 +30,31 @@ TEST_CASE("camera control", "[map]") { | |||
|   REQUIRE(translation.y == 2); | ||||
| } | ||||
| 
 | ||||
| TEST_CASE("map placement test", "[map:placement]") { | ||||
|   for(int i = 0; i < 50; i++) { | ||||
|     size_t width = Random::uniform<size_t>(9, 21); | ||||
|     size_t height = Random::uniform<size_t>(13, 25); | ||||
|     Map map(width, height); | ||||
|     WorldBuilder builder(map); | ||||
|     builder.generate_rooms(); | ||||
|     map.invert_space(); | ||||
| 
 | ||||
|     for(size_t rnum = 0; rnum < map.room_count(); rnum++) { | ||||
|       Room &room = map.room(rnum); | ||||
|       Point pos; | ||||
| 
 | ||||
|       REQUIRE(map.place_entity(rnum, pos)); | ||||
|       // matrix::dump("ROOM PLACEMENT TEST", map.walls(), pos.x, pos.y);
 | ||||
| 
 | ||||
|       REQUIRE(!map.iswall(pos.x, pos.y)); | ||||
|       REQUIRE(pos.x >= room.x); | ||||
|       REQUIRE(pos.y >= room.y); | ||||
|       REQUIRE(pos.x <= room.x + room.width); | ||||
|       REQUIRE(pos.y <= room.y + room.height); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| TEST_CASE("dijkstra algo test", "[map]") { | ||||
|   json data = load_test_data("./tests/dijkstra.json"); | ||||
| 
 | ||||
|  |  | |||
|  | @ -194,7 +194,8 @@ TEST_CASE("prototype flood algorithm", "[matrix:flood]") { | |||
| 
 | ||||
|     if(map.room_count() < 2) continue; | ||||
| 
 | ||||
|     Point start = map.place_entity(map.room_count() / 2); | ||||
|     Point start; | ||||
|     REQUIRE(map.place_entity(map.room_count() / 2, start)); | ||||
|     map.set_target(start); | ||||
|     map.make_paths(); | ||||
|     Matrix result = map.paths(); | ||||
|  | @ -286,7 +287,8 @@ TEST_CASE("viewport iterator", "[matrix:viewport]") { | |||
| 
 | ||||
|   size_t view_width = width/2; | ||||
|   size_t view_height = height/2; | ||||
|   Point player = map.place_entity(1); | ||||
|   Point player; | ||||
|   REQUIRE(map.place_entity(1, player)); | ||||
|   Point start = map.center_camera(player, view_width, view_height); | ||||
| 
 | ||||
|   size_t end_x = std::min(view_width, map.width() - start.x); | ||||
|  | @ -300,3 +302,71 @@ TEST_CASE("viewport iterator", "[matrix:viewport]") { | |||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| TEST_CASE("random rectangle", "[matrix:rando_rect]") { | ||||
|   for(int i = 0; i < 10; i++) { | ||||
|     size_t width = Random::uniform<size_t>(9, 21); | ||||
|     size_t height = Random::uniform<size_t>(13, 25); | ||||
|     Map map(width, height); | ||||
|     WorldBuilder builder(map); | ||||
|     builder.generate_rooms(); | ||||
|     map.invert_space(); | ||||
|     auto wall_copy = map.walls(); | ||||
| 
 | ||||
|     for(size_t rnum = 0; rnum < map.room_count(); rnum++) { | ||||
|       Room &room = map.room(rnum); | ||||
|       Point pos; | ||||
| 
 | ||||
|       for(matrix::rando_rect it{map.walls(), room.x, room.y, room.width, room.height}; it.next();) | ||||
|       { | ||||
|         if(map.iswall(it.x, it.y)) { | ||||
|           matrix::dump("BAD RECTANGLE SPOT", map.walls(), it.x, it.y); | ||||
|         } | ||||
| 
 | ||||
|         REQUIRE(!map.iswall(it.x, it.y)); | ||||
|         REQUIRE(size_t(it.x) >= room.x); | ||||
|         REQUIRE(size_t(it.y) >= room.y); | ||||
|         REQUIRE(size_t(it.x) <= room.x + room.width); | ||||
|         REQUIRE(size_t(it.y) <= room.y + room.height); | ||||
| 
 | ||||
|         wall_copy[it.y][it.x] = wall_copy[it.y][it.x] + 5; | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     matrix::dump("WALLS FILLED", wall_copy); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| TEST_CASE("standard rectangle", "[matrix:rectangle]") { | ||||
|   for(int i = 0; i < 20; i++) { | ||||
|     size_t width = Random::uniform<size_t>(9, 21); | ||||
|     size_t height = Random::uniform<size_t>(13, 25); | ||||
|     Map map(width, height); | ||||
|     WorldBuilder builder(map); | ||||
|     builder.generate_rooms(); | ||||
|     map.invert_space(); | ||||
|     auto wall_copy = map.walls(); | ||||
| 
 | ||||
|     for(size_t rnum = 0; rnum < map.room_count(); rnum++) { | ||||
|       Room &room = map.room(rnum); | ||||
|       Point pos; | ||||
| 
 | ||||
|       for(matrix::rectangle it{map.walls(), room.x, room.y, room.width, room.height}; it.next();) | ||||
|       { | ||||
|         if(map.iswall(it.x, it.y)) { | ||||
|           matrix::dump("BAD RECTANGLE SPOT", map.walls(), it.x, it.y); | ||||
|         } | ||||
| 
 | ||||
|         REQUIRE(!map.iswall(it.x, it.y)); | ||||
|         REQUIRE(size_t(it.x) >= room.x); | ||||
|         REQUIRE(size_t(it.y) >= room.y); | ||||
|         REQUIRE(size_t(it.x) <= room.x + room.width); | ||||
|         REQUIRE(size_t(it.y) <= room.y + room.height); | ||||
| 
 | ||||
|         wall_copy[it.y][it.x] = wall_copy[it.y][it.x] + 5; | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     matrix::dump("WALLS FILLED", wall_copy); | ||||
|   } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw