Skip to content
Map generator for games. Generates island maps with a focus on mountains, rivers, coastlines.
Branch: master
Clone or download
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
graph
prototypes
third-party Add as3corelib submodule Jan 8, 2014
.gitignore Added third-party libraries to the repository and added some document… Apr 30, 2012
.gitmodules Add 2048x2048 PNG export Nov 17, 2013
LICENSE Add a LICENSE file to clarify that the code is under the MIT open sou… Mar 14, 2012
Lava.as Rename voronoi_set.as to Map.as to better reflect its role as the cor… Sep 4, 2010
Map.as Merge branch 'master' of github.com:amitp/mapgen2 Feb 4, 2015
NoisyEdges.as Rename Center.edges to borders and Corner.edges to protrudes, to matc… Sep 4, 2010
README.md Add “no maintenance intended” badge Aug 24, 2017
Roads.as Rename Center.edges to borders and Corner.edges to protrudes, to matc… Sep 4, 2010
RoadsSpanningTree.as Different algorithm for road building: build a variant of a minimal s… Sep 25, 2011
Watersheds.as Add per-polygon watershed calculation, and render that instead of per… Sep 22, 2010
mapgen2.as Fix misleading comment about 3d rendering Sep 6, 2014

README.md

No Maintenance Intended

After working on a Perlin-noise-based map generator I had wanted something with islands and rivers and volcanoes and lava. However, I had a lot of trouble getting that map generator to generate any more than what it did at first. This project was my exploration of several different techniques for map generation.

The goal is to make continent/island style maps (surrounded by water) that can be used by a variety of games. I had originally intended to write a reusable C++ library but ended up writing the code in Actionscript.

The most important features I want are nice island/continent coastlines, mountains, and rivers. Non goals include impassable areas (except for the ocean), maze-like structures, or realistic height maps. The high level approach is to

  1. Make a coastline.
  2. Set elevation to distance from coastline. Mountains are farthest from the coast.
  3. Create rivers in valleys, flowing down to the coast.

The implementation generates a vector map with roughly 1,000 polygons, instead of a tile/grid map with roughly 1,000,000 tiles. In games the polygons can be used for distinct areas with their own story and personality, places for towns and resources, quest locations, conquerable territory, etc. Polygon boundaries are used for rivers. Polygon-to-polygon routes are used for roads. Forests, oceans, rivers, swamps, etc. can be named. Polygons are rendered into a bitmap to produce the tile map, but the underlying polygon structure is still available.

The full process is described here.

History

  • I started out with C++ code that used mountains, soil erosion, water flow, water erosion, water evaporation, volanoes, lava flow, and other physical processes to sculpt terrain expressed in a 2d array of tiles. However as described in this blog post I decided to abandon this approach.

  • Since my initial approach failed, I wrote several small prototypes to figure out how to make rivers, coastlines, and mountains. These are the key features I want to support. I will then figure out how to combine them into a map.

  • The voronoi_set.as prototype worked well and I continued adding to it (instead of converting to C++). It supports terrain types: ocean, land, beach, lake, forest, swamp, desert, ice, rocky, grassland, savannah. It has rivers and roads. I decided not to convert it to C++ for now. Instead, I've refactored it into the core map generation (Map.as), display and GUI (mapgen2.as), graph representation (graph/*.as), decorative elements (Roads.as, Lava.as), and noisy edge generation (NoisyEdges.as).

Requirements

These third-party requirements have been added to the third-party directory:

Make sure you run git submodule update --init to check out the third-party libraries.

Compiling

To compile mapgen2.as to mapgen2.swf, use the following command:

mxmlc -source-path+=third-party/PM_PRNG -source-path+=third-party/as3delaunay/src -source-path+=third-party/as3corelib/src mapgen2.as
You can’t perform that action at this time.