simple_map.rs 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. use super::{MapBuilder, Map, Rect, apply_room_to_map,
  2. apply_horizontal_tunnel, apply_vertical_tunnel, TileType,
  3. Position, spawner};
  4. use rltk::RandomNumberGenerator;
  5. use specs::prelude::*;
  6. use generator::{Generator, Gn};
  7. pub struct SimpleMapBuilder {
  8. map : Map,
  9. starting_position : Position,
  10. depth: i32,
  11. rooms: Vec<Rect>
  12. }
  13. impl MapBuilder for SimpleMapBuilder {
  14. fn get_map(&self) -> Map {
  15. self.map.clone()
  16. }
  17. fn get_starting_position(&self) -> Position {
  18. self.starting_position.clone()
  19. }
  20. fn build_map(&mut self) -> Generator<(), Map> {
  21. Gn::new_scoped(move |mut s| {
  22. println!("Running build map");
  23. self.rooms_and_corridors(&mut s);
  24. done!();
  25. })
  26. }
  27. fn spawn_entities(&mut self, ecs : &mut World) {
  28. for room in self.rooms.iter().skip(1) {
  29. spawner::spawn_room(ecs, room, self.depth);
  30. }
  31. }
  32. }
  33. impl SimpleMapBuilder {
  34. pub fn new(new_depth : i32) -> SimpleMapBuilder {
  35. SimpleMapBuilder{
  36. map : Map::new(new_depth),
  37. starting_position : Position{ x: 0, y : 0 },
  38. depth : new_depth,
  39. rooms: Vec::new()
  40. }
  41. }
  42. fn rooms_and_corridors(&mut self, scope: &mut generator::Scope<(), Map>) {
  43. const MAX_ROOMS : i32 = 30;
  44. const MIN_SIZE : i32 = 6;
  45. const MAX_SIZE : i32 = 10;
  46. let mut rng = RandomNumberGenerator::new();
  47. for _i in 0..MAX_ROOMS {
  48. let w = rng.range(MIN_SIZE, MAX_SIZE);
  49. let h = rng.range(MIN_SIZE, MAX_SIZE);
  50. let x = rng.roll_dice(1, self.map.width - w - 1) - 1;
  51. let y = rng.roll_dice(1, self.map.height - h - 1) - 1;
  52. let new_room = Rect::new(x, y, w, h);
  53. let mut ok = true;
  54. for other_room in self.rooms.iter() {
  55. if new_room.intersect(other_room) { ok = false }
  56. }
  57. if ok {
  58. apply_room_to_map(&mut self.map, &new_room);
  59. scope.yield_(self.map.clone());
  60. if !self.rooms.is_empty() {
  61. let (new_x, new_y) = new_room.center();
  62. let (prev_x, prev_y) = self.rooms[self.rooms.len()-1].center();
  63. if rng.range(0,1) == 1 {
  64. apply_horizontal_tunnel(&mut self.map, prev_x, new_x, prev_y);
  65. apply_vertical_tunnel(&mut self.map, prev_y, new_y, new_x);
  66. } else {
  67. apply_vertical_tunnel(&mut self.map, prev_y, new_y, prev_x);
  68. apply_horizontal_tunnel(&mut self.map, prev_x, new_x, new_y);
  69. }
  70. }
  71. self.rooms.push(new_room);
  72. scope.yield_(self.map.clone());
  73. }
  74. }
  75. let stairs_position = self.rooms[self.rooms.len()-1].center();
  76. let stairs_idx = self.map.xy_idx(stairs_position.0, stairs_position.1);
  77. self.map.tiles[stairs_idx] = TileType::DownStairs;
  78. let start_pos = self.rooms[0].center();
  79. self.starting_position = Position{ x: start_pos.0, y: start_pos.1 };
  80. }
  81. }