-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathHexTile.h
52 lines (43 loc) · 1.41 KB
/
HexTile.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
* Copyright 2009-2012 Scott McCreary
* Copyright 2014-2016 Puck Meerburg
* Based on BeVexed by DarkWyrm Copyright 2007-2009
*
* Distributed under terms of the MIT License.
*
*/
#ifndef HEXTILE_H
#define HEXTILE_H
#include <Archivable.h>
#include <stdio.h>
class HexTile : public BArchivable
{
public:
// Archiving stuff!
HexTile(BMessage *from);
static BArchivable *Instantiate(BMessage *from);
virtual status_t Archive(BMessage *into, bool deep = true);
// Normal stuff!
HexTile(void);
HexTile(const uint8 &tl, const uint8 &t, const uint8 &tr,
const uint8 &bl, const uint8 &b, const uint8 &br);
HexTile(const HexTile &t);
HexTile &operator=(const HexTile &t);
void SetValues( const uint8 &tl, const uint8 &t, const uint8 &tr,
const uint8 &bl, const uint8 &b, const uint8 &br);
bool IsEmpty(void) const { return (topleft<0 || top<0 || topright<0 || bottomleft<0 || bottom<0 || bottomright<0); }
void MakeEmpty(void) { topleft=top=topright=bottomleft=bottom=bottomright=-1; }
void PrintToStream(void) { printf("<tile id = %d, gridid = %d, tl = %d, t = %d, tr = %d, bl = %d, b = %d, br = %d>\n",
id, gridid, topleft, top, topright, bottomleft, bottom, bottomright);
}
int8 topleft;
int8 top;
int8 topright;
int8 bottomleft;
int8 bottom;
int8 bottomright;
uint16 id;
uint16 gridid;
HexTile *toplefttile,*toptile,*toprighttile,*bottomlefttile,*bottomtile,*bottomrighttile;
};
#endif