Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP

PHP code for creating hex maps

branch: master

Fetching latest commit…

Cannot retrieve the latest commit at this time

README
This PHP code uses the GD functions to create hex map images (eg. for wargames).

## Features:

* Shapes: rectangule, hexagonal ('circle'), freeform ('free')
* Variable hex sizes
* shape() to calculate distance in hexes
* highlight a hex
* set a border on a hex
* color a hex
* add text to a hex
* I swear it used to allow setting a background picture, but I don't see that functionality so maybe I dreamed it or lost it when I misplaced this code for four years.

## Known Issues

The code has ugly styling (tabs, odd spacing, no optional braces) - sorry, I was young(er) and stupid(er).

There's a fair amount of temporal coupling in there - functions that you can't call before other functions, etc. I hadn't heard of the command pattern or closures yet.

There's a bug in the 'circle' shape (that the following code exercices), see http://push.cx/2010/php-hex-map-graphics for the image generated by the following code:

    <?php

    require 'class_hex_image.php';

    $radius = 3;
    $map = new Hex_image;
    $map->set_color('bg', 255, 255, 255);
    $map->set_l(20);
    $map->set_shape('circle', $radius);
    $map->start();
    for($x = 1; $x <= $map->xsize; $x++) {
        for($y = 1; $y <= $map->ysize; $y++) {
            $map->text($x, $y, 'black', $map->steps($x, $y, $radius, $radius));
            // nice for getting a feel for coordinates
            //$map->text($x, $y, 'black', "$x,$y");
        }
    }

    header('Content-Type: image.png');
    $map->finish();       // calls imagepng()

    ?>

## Future

One of the guys in #bbg on irc,freenode.net is building a browser-based game with a hex map and I remembered this code was squirreled away somewhere on my hard drive. I have no plans to fix, improve, or in any way maintain this code. I figure I may as well release it so someone can do something with it.

## License

I release this code to the public domain. You may use it for any purpose with or without attribution. It would be polite to mention my name and let me know you come up with, but it's not at all required.
Something went wrong with that request. Please try again.