Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mikamai/hexagonal.js
Hexagon and Hexagonal Map library in JS
https://github.com/mikamai/hexagonal.js
Last synced: 22 days ago
JSON representation
Hexagon and Hexagonal Map library in JS
- Host: GitHub
- URL: https://github.com/mikamai/hexagonal.js
- Owner: mikamai
- Created: 2014-07-30T12:44:47.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2014-08-01T08:58:38.000Z (over 10 years ago)
- Last Synced: 2023-04-13T13:08:48.964Z (over 1 year ago)
- Language: JavaScript
- Size: 324 KB
- Stars: 11
- Watchers: 10
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Hexagonal Map for JS
Hexagon and Hexagonal Maps management library written in Javascript.
- [Post on the dev blog about Hexagonal.js](http://dev.mikamai.com/post/93312455794/web-procedural-map-generation-part-3)
- [Demos](http://mikamai.github.io/hexagonal.js/demo.html)## API
### The Hexagon object
An hexagon can be inscribed in a circle, so you can create one passing the
circumference radius and, optionally, the circumference center:```javascript
// Regular hexagon inscribed in a circle with center in 5,5 and a radius of 10
hexagon = Hexagonal.Hexagon.byRadius 10, center: { x: 5, y: 5 }
```You can create an hexagon with a given size:
```javascript
// Regular hexagon with a height of 10 and width of 10 * sqrt(3)/2
hexagon = Hexagonal.Hexagon.bySize { height: 10 }
// Hexagon with a width of 10 and a height of 5
hexagon = Hexagonal.Hexagon.bySize { width: 10, height: 5 }
```Both the methods above will create the vertices collections.
But if you want you can create an hexagon passing your custom vertices:```javascript
// A weird hexagonal polygon
vertices = (new Hexagonal.Vertex(i*5, i*10) for i in [0...6])
hexagon = Hexagonal.Hexagon.byVertices vertices
```To each of the methods described above you can pass additional options to customize the hexagon:
- `flatTopped` (default: `false`) By default the hexagon is treated as _pointly topped_. If you want to have a _flat topped_ hexagon, set this value to `true`.
- `position` (default: `new Hexagonal.Point(0, 0)`) Set this if you want to place the hexagon in a specific position### Hexagonal Map
```javascript
// map of 10x10 composed by regular hexagons with a width of 10
new Hexagonal.Map({cols: 10, rows: 10, hexagon: { width: 10 }})
// map of 10x10 composed by hexagons with a size of 2x3
new Hexagonal.Map({cols: 10, rows: 10, hexagon: { width: 2, height: 3 }})
// map of 10x10 composed by regular hexagons inscribed in a circumference with
// a radius of 10
new Hexagonal.Map({cols: 10, rows: 10, hexagon: { radius: 10 }})
// map of 10x10 with a total width of 500. The total width will be divided by
// cols to obtain each hexagon width
new Hexagonal.Map({cols: 10, rows: 10, width: 500})
// map of 10x10 with a total width of 500 and a total height of 500. The total
// width and height will be divided by cols and rows to obtain each hexagon size
new Hexagonal.Map({cols: 10, rows: 10, width: 500, height: 500})
```In addition you can use the following options when building a new map:
- `flatTopped` (default: false) By default the map will be composed by _pointly topped_ hexagons. Set it to true if you want to use _flat topped_ hexagons.
- `offsetLayout` (default: 'odd') Set it to 'even' you want to change the layout (shifting even rows/cols instead of odd rows/cols).Once you have the map, you can choose which Cursor you want to use to navigate it:
#### Offset Cursor
```javascript
map = new Hexagonal.Map({rows: 5, cols: 5, hexagon: { radius: 5 }})
cursor = new Hexagonal.Cursors.Offset(map, 0, 0) // offset cursor, set in 0,0 (first hexagon)
cursor.moveTo(2, 2) // move to the center and returns the current hexagon
cursor.hexagon // => returns the current hexagon
```#### Axial Cursor
```javascript
map = new Hexagonal.Map({rows: 5, cols: 5, hexagon: { radius: 5 }})
cursor = new Hexagonal.Cursors.Axial(map, 0, 0) // offset cursor, set in 0,0 (map center)
cursor.moveTo(2, 2) // move to the last hexagon of the map and returns the current hexagon
cursor.hexagon // => returns the current hexagon
```Cursors can be easily converted back and forth passing the current cursor to the new one's constructor:
```javascript
map = new Hexagonal.Map({rows: 5, cols: 5, hexagon: { radius: 5 }})
offset = new Hexagonal.Cursors.Offset(map, 0, 0)
axial = new Hexagonal.Cursors.Axial(offset)
```### Precision
To arginate floating point rounding errors each calculation in Hexagonal will be
rounded to 1 decimal digit. If you want to change it, you can set how many decimal
digits to use:```javascript
Hexagonal.precision() // => 1
Hexagonal.Util.round(3.123) // => 3.1
Hexagonal.precision(2)
Hexagonal.Util.round(3.12) // => 3.12
Hexagonal.precision(null) // => disable rounding
```## Tests
Use grunt to run tests and compile into javascript. Running grunt will:
1. compile [src/hexagonal/index.coffee](src/hexagonal/index.coffee) into `build/hexagonal.js` (via browserify)
2. compile `specs/**/*_spec.coffee` into `build/specs.js` and `specs/spec_helper.coffee` into `build/spec_helper.js`
3. run the test suite using jasmine + phantomjs
4. clean `build/specs.js` and `build/spec_helper.js`