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
|
/*
* This file is part of NumptyPhysics
* Copyright (C) 2008 Tim Edmonds
*
* 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 3 of the
* License, or (at your option) 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.
*
*/
#ifndef FONT_H
#define FONT_H
#include "Common.h"
#include "Path.h"
#include "Array.h"
#include <string>
class Canvas;
class Font
{
public:
Font( const std::string& file, int ptsize=10 );
int height() const { return m_height; }
Vec2 metrics( const std::string& text ) const;
void drawLeft( Canvas* canvas, Vec2 pt,
const std::string& text, int colour ) const;
void drawRight( Canvas* canvas, Vec2 pt,
const std::string& text, int colour ) const;
void drawCenter( Canvas* canvas, Vec2 pt,
const std::string& text, int colour ) const;
void drawWrap( Canvas* canvas, Rect area,
const std::string& text, int colour ) const;
static const Font* titleFont();
static const Font* headingFont();
static const Font* blurbFont();
private:
typedef void* State;
State m_state;
int m_height;
};
#endif //FONT_H
|