Skip to main content

A customizable Python tool for generating maps for games and simulations.

Project description

TerraForge v1.4.0 🗺️

Procedural Biome/Island & Dungeon Map Generator using Simplex Noise

TerraForge is a versatile Python toolset for procedural map generation.

It includes tools for creating noise-based biome maps and multi-level dungeon layouts with fine-grained control over terrain shaping, biome placement, and dungeon structure.


🚀 Features

🌍 Biome Generator (TerraForge)

  • Elevation, Moisture, and Temperature map generation
  • Supports single and clustered multi-island generation
  • Falloff support: Radial, Edge, or None
  • Parameters for island spread, spacing, scale, and strength
  • Biome mapping based on environmental conditions (supports both visual colors and logic-driven biome data)
  • Outputs high-resolution PNG images
  • JSON preset import/export for reuse in games

🏰 Dungeon Generator (DungeonForge)

  • Multi-level dungeon generation (3D stack of floors)
  • Procedural room placement and corridor carving
  • Up/down stairs for vertical navigation
  • Console-based movement demo included
  • Optional PNG export per dungeon level
  • Tile color customization for export
  • JSON preset import/export

📦 Requirements


📦 Installation

You can install TerraForge using pip.

pip install terraforge-core

🧪 Demos

Biome Map Generator

Run the included demo script:

python demo.py

The generated maps will be saved as biome_map, elevation_map, moisture_map, temperature_map, (noise_type)_map.

Dungeon Map Generator

Run either the included dungeon_demo script or dungeon_demo1 script.

python dungeon_demo.py

Console based demo with movement.

python dungeon_demo1.py

Generates .pngs for each dungeon level.


🚀 Usage - TerraForge (Biome Maps)

from terraforge import TerraForge

generator = TerraForge(map_size=300, image_size=(600, 600))

generator.generate(output_dir="maps")

🔁 Preset Workflow

generator.export_preset("world_preset.json")

generator.import_preset("world_preset.json")
generator.generate("maps")

🧩 Biome Schema (Presets)

Biomes are stored as a list of objects. Each biome requires:

  • color (hex string)
  • rules (dict of noise_type -> [min, max])

Optional (recommended for tools like TerraForge Studio):

  • id (unique string per biome)
  • name (display name)

Example biome:

{
  "id": "forest",
  "name": "Forest",
  "color": "#3E7C3C",
  "rules": {
    "elevation": [0.4, 0.6],
    "moisture": [0.5, 1.0]
  }
}

Notes:

  • id is optional, but if provided it must be unique within the preset.
  • Rule ranges must satisfy min <= max.

🧠 Accessing Biome Data

Each tile now stores full biome data instead of just a color.

biome = generator.get_biome(x, y)

print(biome["id"]) # logic (e.g., "forest", "ocean")
print(biome["name"]) # display name

To get the visual color of a tile:

color = generator.tile_color(x, y)

⚠️ Update (v1.4.0)

  • biome_map now stores full biome dictionaries instead of hex color strings
  • Use tile_color(x, y) to retrieve the visual color
  • Use get_biome(x, y) for biome data and game logic
  • PNG export behavior remains unchanged

🚀 Usage - DungeonForge (Dungeons)

from dungeonforge import DungeonForge

generator = DungeonForge()

dungeon_map = generator.generate()

🔁 Preset Workflow

generator.export_preset("dungeon_preset.json")

generator.import_preset("dungeon_preset.json")
generator.generate()

⚙️ Customization Options

Biome Generator

Edit the values in terraforge.py or the demo to control:

  • map_size and image_size

  • falloff type: "radial", "edge", or None

  • num_islands, island_spread, min_island_spacing

  • noise types (elevation, moisture, temperature)

  • biome_thresholds for noise types (elevation, moisture, and temperature)

Dungeon Generator

  • Map size (width, height)
  • Number of levels (z_levels)
  • Maximum rooms and room size constraints
  • Tile symbols and export colors
  • Specify which levels to export (levels=[0, 2])

Related Tools

TerraForge Studio

Screenshot (583)

A GUI tool built on top of the TerraForge library that allows you to quickly generate multi-level dungeons for games, prototypes, and tabletop use.


Related Libraries

  • CQCalendar: A lightweight, tick-based time/calendar/lunar cycle system for Python games and simulations.
  • MoonTex: A procedural moon texture generator for Python that creates stylized, noise-based moon phase images.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

terraforge_core-1.4.0.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

terraforge_core-1.4.0-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

Details for the file terraforge_core-1.4.0.tar.gz.

File metadata

  • Download URL: terraforge_core-1.4.0.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for terraforge_core-1.4.0.tar.gz
Algorithm Hash digest
SHA256 8e8cbc422bf6ee209e5d1e05066dcb91dffe971cd2b86e0a896f373ce7592f00
MD5 089023ec0395565215b9b03b466e93d8
BLAKE2b-256 4a1a26c625cbcfb133d4cfedf0f0363b679d6dae8e2fb2a223719dfb840337de

See more details on using hashes here.

File details

Details for the file terraforge_core-1.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for terraforge_core-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 179142ac4aad8b5a19fad2786f34381f67623e6ccf3184246452a1777e465fc8
MD5 cfbccd2c475ae455a6f565e6905504d9
BLAKE2b-256 dd98c36d92ec87a0ab716dc0242694ae813a90664d4ff8b5d5e231047a080fb6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page