Skip to content

sixand/roguelike-dungeon-generator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 

Repository files navigation

roguelike-dungeon-generator

An algorithm that generates a level for roguelike games.

There's also a C# port.

Outline

  1. Divide the map into a grid of evenly sized cells.
  2. Pick a random cell as the current cell and mark it as connected.
  3. While the current cell has unconnected neighbor cells: 3. Connect to one of them. 3. Make that cell the current cell.
  4. While there are unconnected cells: 4. Pick a random connected cell with unconnected neighbors and connect to one of them.
  5. Pick zero or more pairs of adjacent cells that are not connected and connect them.
  6. Within each cell, create a room of random shape.
  7. For each connection between two cells: 7. Create a random corridor between the rooms in each cell.
  8. Place staircases in the cell picked in step 2 and the lest cell visited in step 3ii.

Example output

		 ######                    ############# ######
######## #....#         ########   #...........###....#########
#......###....###########......#   #...##.......##............#
#..............##......##......#####...##.............###.....#
#......##......##......................##......###....# #.....#
#......###.....##......##......##########......# #....# ####.##
#......# #.....##......#########        #......# #....#   #..#
####.### #####.#####.###                ######## ###### ###.##
  #..#       #.#####.## ######          #####           #...##
 ##.####   ###.##.....# #....#          #...#         ###....#
 #.....#   #..........# #....############...#      ####......#
 #.....#   #...##.....# #..............#....#      #....#....#
 #.....#   #...##.....# ###.######..........#      #...##....#
 #.....#   #...##.....#   #.#    #.....####.#      #...##....#
 #.....#   ############   #.#    #.....#  #.#    ###...##....#
 #####.#                  #.###  #######  #.#    #...######.##
   ###.# ######         ###...##        ###.##   #.###   ##.###
   #...# #....#  ########......#        #....#  ##.##### #....#
   #...###....#  #.....##......##########....#  #......# #....#
  ##...##.....#  #.....##......##......##....#  #......# #....#
  #...........####.............##......##....#  #......###....#
  #....###.............##......##......##....#  #.............#
  #.#### #....####.....##......##............#  ##########....#
  #.#    ####.#  ##################.##########           ##.###
  #.#    ####.## ######           #.####                  #.#
  #.#    #.<...# #....##########  #....#                  #.####
###.##   #.....###.............#  #....######### ######   #....#
#....#   #.....##.....##.......#  #............# #....#   ##...#
#....#####.....##.....##.......#  #....###.....# #....######...#
#..............##.######.......#  #....# #.>...# #.............#
##.#######.....##.#    #.......#  ###### ####### #....######...#
 #..#    ########.#    #####.###                 ##.###    ##.##
 ##.####        #.######   #.#   #######         ##.##     ##..#
 #.....# ########......#####.#   #.....#         #...#     #...#
 #.....###.............##....#   #.....#         #...#     #...#
 #..............#......##....#####.....######### #...#     #...#
 #########.....##......##......................###...#     #####
		 #.....##......##...#############............#
		 ########......######           #......###...#
				########                ######## #####

Credits

Created as I reworded this algorithm (link is now broken, can't find a mirror) to make it easier to follow.

About

An algorithm that generates a level for roguelike games.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%