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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
|
/*
* Configurable text colors
* Copyright (C) 2008 Douglas Boffey <dougaboffey@netscape.net>
*
* This file is part of The Mana World.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef COLOR_H
#define COLOR_H
#include <string>
#include <vector>
#include <guichan/listmodel.hpp>
class Color : public gcn::ListModel
{
public:
/**
* Constructor
*/
Color();
/**
* Destructor
*/
~Color();
/**
* Define the color replacement for a character
*
* @param c charater to be replaced
* @param rgb color to replace character
*/
void setColor(char c, int rgb);
/**
* Define the color replacement for a character
*
* @param c character to be replaced
* @param r red component
* @param g green component
* @param b blue component
*/
void setColor(char c, int r, int g, int b)
{
setColor(c, (r << 16) | (g << 8) | b);
}
/**
* Return the color associated with a character, if exists
*
* @param c character requested
* @param valid indicate whether character is known
*/
int getColor(char c, bool &valid) const;
/**
* Return the number of colors known
*/
int getNumberOfElements() { return mColVector.size(); }
/**
* Return the name of the ith color
*
* @param i index of color interested in
*/
std::string getElementAt(int i);
/**
* Get the color for the element at index i in the current color
* model
*/
int getColorAt(int i);
/**
* Get the character used by the color for the element at index i in
* the current color model
*/
char getColorCharAt(int i);
/**
* Set the color for the element at index i
*/
void setColorAt(int i, int rgb);
/**
* Commit the colors
*/
void commit();
/**
* Rollback the colors
*/
void rollback();
private:
struct ColorElem
{
ColorElem(char c, int rgb, const std::string &text) :
ch(c), rgb(rgb), text(text) {}
char ch;
int rgb;
int committedRgb;
std::string text;
};
typedef std::vector<ColorElem> ColVector;
ColVector mColVector;
/**
* Initialise color
*
* @param c character that needs initialising
* @param rgb default color if not found in config
* @param text identifier of color
*/
void addColor(char c, int rgb, const std::string &text);
};
extern Color *textColor;
#endif
|