summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/glfont.cc48
1 files changed, 40 insertions, 8 deletions
diff --git a/lib/glfont.cc b/lib/glfont.cc
index 91d70ba..3d254d3 100644
--- a/lib/glfont.cc
+++ b/lib/glfont.cc
@@ -19,8 +19,10 @@ off|siz|description
2 | 1 | Flags
3 | 1 | maxX (maximum width)
4 | 1 | maxY (maximum height)
- 5 | X | char entries
-5+X| Y | char map
+ 5 | 1 | base (bottom line from top)
+ 6 | 1 | inter (size of the interline)
+ 7 | X | char entries
+7+X| Y | char map
X = (maxX * maxY + 1) * nbentries
Y = nbentries * 4
@@ -76,12 +78,12 @@ nbT = number of textures
mogltk::font::font(Handle * ffont) : textcolor(255, 255, 255, 255) {
int i;
- ffont->SetZ();
-
ffont->read(&nbentries, 2);
ffont->read(&flags, 1);
ffont->read(&maxX, 1);
ffont->read(&maxY, 1);
+ ffont->read(&base, 1);
+ ffont->read(&inter, 1);
nbcU = 256 / maxX;
nbcV = 256 / maxY;
@@ -133,9 +135,9 @@ mogltk::font::font(Handle * ffont) : textcolor(255, 255, 255, 255) {
}
}
}
- if ((curU += maxX) >= 256) {
+ if (((curU += maxX) + maxX) >= 256) {
curU = 0;
- if ((curV += maxY) >= 256) {
+ if (((curV += maxY) + maxY) >= 256) {
curV = 0;
if ((curT + 1) != nbT)
curtex = (Uint8 *) fonttex[++curT]->GetSurface()->pixels;
@@ -168,6 +170,17 @@ void mogltk::font::drawentry(Uint16 entry, int x, int y, Color c) {
mogltk::glbase::Enter2DMode();
}
+ if (shadow) {
+ int os = shadow;
+ shadow = 0;
+
+ drawentry(entry, x + os, y + os, BLACK);
+
+ shadow = os;
+ }
+
+ y -= base;
+
Bind(entry / nbcT);
c.Bind();
trueentry = entry % nbcT;
@@ -202,9 +215,21 @@ void mogltk::font::putentry(Uint16 entry, Color c) {
cx += sizes[entry];
}
+void mogltk::font::putchar(char ch, Color c) {
+ Uint16 * p;
+ int i;
+
+ for (i = 0, p = corresp; i < nbentries; i++, p++) {
+ if (*(p++) == ch) {
+ putentry(*p, c);
+ return;
+ }
+ }
+}
+
void mogltk::font::newline(void) {
cx = ox;
- cy += maxY;
+ cy += inter;
}
int mogltk::font::printf(const String & m, ...) {
@@ -218,7 +243,11 @@ int mogltk::font::printf(const String & m, ...) {
va_end(ap);
for (p = buffer; *p; p++) {
- putentry(*p, textcolor);
+ if (*p == '\n') {
+ newline();
+ } else {
+ putchar(*p, textcolor);
+ }
}
return r;
@@ -228,3 +257,6 @@ void mogltk::font::setcolor(Color c) {
textcolor = c;
}
+void mogltk::font::setshadow(int s) {
+ shadow = s;
+}