2005-06-29 04:30:40 +00:00
|
|
|
//This file is part of Photon (http://photon.sourceforge.net)
|
|
|
|
//Copyright (C) 2004-2005 James Turk
|
|
|
|
//
|
|
|
|
// Author:
|
|
|
|
// James Turk (jpt2433@rit.edu)
|
|
|
|
//
|
|
|
|
// Version:
|
2005-11-13 07:59:48 +00:00
|
|
|
// $Id: Font.hpp,v 1.9 2005/11/13 07:59:49 cozman Exp $
|
2005-06-29 04:30:40 +00:00
|
|
|
|
|
|
|
#ifndef PHOTON_VIDEO_FONT_HPP
|
|
|
|
#define PHOTON_VIDEO_FONT_HPP
|
|
|
|
|
|
|
|
#include "video/FontResourceManager.hpp"
|
|
|
|
#include "ResourceManaged.hpp"
|
2005-07-17 07:14:09 +00:00
|
|
|
#include "video/Color.hpp"
|
2005-06-29 04:30:40 +00:00
|
|
|
|
|
|
|
namespace photon
|
|
|
|
{
|
|
|
|
namespace video
|
|
|
|
{
|
|
|
|
|
2005-07-03 05:20:49 +00:00
|
|
|
class StreamFlusher { };
|
|
|
|
std::ostream& operator<<(std::ostream& os, const StreamFlusher& rhs);
|
|
|
|
|
2005-06-29 04:30:40 +00:00
|
|
|
// Class: Font
|
2005-11-13 07:59:48 +00:00
|
|
|
// Simple wrapper object around a TrueType font that can be drawn to textures
|
|
|
|
// and rendered via OpenGL.
|
2005-06-29 04:30:40 +00:00
|
|
|
//
|
|
|
|
// Since Font is a child of <ResourceManaged>, all memory management is
|
|
|
|
// taken care of.
|
2005-11-13 07:59:48 +00:00
|
|
|
//
|
|
|
|
// Font is a resource managed class, and therefore all resources should
|
|
|
|
// be registered using <Font::addResource> and then loaded by their assigned
|
|
|
|
// name via <Font::open> or the appropriate constructor.
|
2005-06-29 04:30:40 +00:00
|
|
|
//
|
|
|
|
// Operators:
|
|
|
|
// - Font = Font
|
|
|
|
// - bool : True if font is loaded, false if not.
|
2005-07-18 07:19:48 +00:00
|
|
|
class Font : public ResourceManaged<FontResourceManager>
|
2005-06-29 04:30:40 +00:00
|
|
|
{
|
|
|
|
// Group: (Con/De)structors
|
|
|
|
public:
|
|
|
|
// Function: Font
|
|
|
|
// Default constructor, initalizes internal state of Font.
|
|
|
|
Font();
|
|
|
|
|
|
|
|
// Function: Font
|
|
|
|
// Copy constructor, copies another Font.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// rhs - Font to construct copy of.
|
|
|
|
Font(const Font &rhs);
|
|
|
|
|
|
|
|
// Function: Font
|
|
|
|
// Initializing constructor, loads Font via call to <open>.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// name - Name of the Font <Resource> to open.
|
|
|
|
//
|
|
|
|
// See Also:
|
|
|
|
// <open>
|
|
|
|
Font(const std::string& name);
|
|
|
|
|
|
|
|
// Group: General
|
|
|
|
public:
|
|
|
|
|
|
|
|
// Function: open
|
|
|
|
// Opens an TrueType font.
|
|
|
|
//
|
2005-07-03 05:20:49 +00:00
|
|
|
// Loading is done via FreeType.
|
2005-06-29 04:30:40 +00:00
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// name - Name of the Font <Resource> to open.
|
|
|
|
void open(const std::string& name);
|
2005-07-03 05:20:49 +00:00
|
|
|
|
2005-07-18 05:14:18 +00:00
|
|
|
// Function: isValid
|
|
|
|
// Determine status of Font.
|
|
|
|
//
|
|
|
|
// Returns:
|
|
|
|
// True if font is loaded, false if font is not loaded/initialized.
|
2005-07-03 05:20:49 +00:00
|
|
|
bool isValid() const;
|
2005-06-29 04:30:40 +00:00
|
|
|
|
|
|
|
Font& operator=(const Font &rhs);
|
|
|
|
operator bool() const;
|
|
|
|
|
2005-07-17 07:14:09 +00:00
|
|
|
// Group: Coloring
|
|
|
|
public:
|
|
|
|
// Function: setColor
|
|
|
|
// Set draw color of the font.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// color - <Color> to shade font glyphs when drawn.
|
|
|
|
void setColor(const Color& color);
|
|
|
|
|
|
|
|
// Function: getColor
|
|
|
|
// Get draw color of the font.
|
|
|
|
//
|
|
|
|
// Returns:
|
|
|
|
// Currently set <Color> to shade font glyphs when drawn.
|
|
|
|
Color getColor() const;
|
|
|
|
|
2005-07-03 05:20:49 +00:00
|
|
|
// Group: Drawing
|
|
|
|
public:
|
2005-10-15 04:56:37 +00:00
|
|
|
|
|
|
|
// Function: drawText
|
|
|
|
// Draw text to screen at a specific position, using an printf-style
|
|
|
|
// format string.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// x - X position to start drawing text at
|
|
|
|
// y - Y position to start drawing text at.
|
|
|
|
// str - printf-style format string
|
|
|
|
// ... - optional variable arguments referenced in str
|
2005-07-18 07:19:48 +00:00
|
|
|
void drawText(scalar x, scalar y, const char *str, ...) const;
|
2005-10-15 04:56:37 +00:00
|
|
|
|
|
|
|
// Function: drawText
|
|
|
|
// Draw text to screen at a specific position.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// x - X position to start drawing text at
|
|
|
|
// y - Y position to start drawing text at.
|
|
|
|
// str - Text to draw at specified posiiton.
|
2005-07-18 07:19:48 +00:00
|
|
|
void drawText(scalar x, scalar y, const std::string& str) const;
|
2005-07-03 05:20:49 +00:00
|
|
|
|
2005-10-15 04:56:37 +00:00
|
|
|
// Function: beginDraw
|
|
|
|
// Begin drawing of text using C++ style output streams.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// x - X position to start drawing text at
|
|
|
|
// y - Y position to start drawing text at.
|
|
|
|
//
|
|
|
|
// Returns:
|
2005-11-13 07:59:48 +00:00
|
|
|
// std::ostream reference, anything written to the stream before
|
2005-10-15 04:56:37 +00:00
|
|
|
// <endDraw> will be drawn starting at the specified position.
|
2005-07-18 07:19:48 +00:00
|
|
|
std::ostream& beginDraw(scalar x, scalar y);
|
2005-10-15 04:56:37 +00:00
|
|
|
|
|
|
|
// Function: endDraw
|
|
|
|
// End drawing of text started with <beginDraw>.
|
|
|
|
// Should be passed to the open beginDraw stream, flushing and writing the
|
|
|
|
// stream to the display.
|
2005-07-03 05:20:49 +00:00
|
|
|
StreamFlusher endDraw();
|
|
|
|
|
|
|
|
// Group: Font Metrics
|
2005-06-29 04:30:40 +00:00
|
|
|
public:
|
2005-10-15 04:56:37 +00:00
|
|
|
|
|
|
|
// Function: calcStringWidth
|
|
|
|
// Calculate the width of a string when drawn in the current font.
|
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// str - String to calculate the width of.
|
|
|
|
//
|
|
|
|
// Returns:
|
|
|
|
// Width of string (in pixels) when drawn in current font.
|
2005-07-18 07:19:48 +00:00
|
|
|
uint calcStringWidth(const std::string& str) const;
|
2005-10-15 04:56:37 +00:00
|
|
|
|
|
|
|
// Function: getHeight
|
|
|
|
// Get height of the font, which is essentially equal to the height of the
|
|
|
|
// tallest character plus a font-specified spacing.
|
|
|
|
//
|
|
|
|
// Returns:
|
|
|
|
// Height of the loaded font.
|
2005-07-18 07:19:48 +00:00
|
|
|
uint getHeight() const;
|
2005-06-29 04:30:40 +00:00
|
|
|
|
2005-07-04 03:06:48 +00:00
|
|
|
// Group: Resource Creation
|
|
|
|
public:
|
|
|
|
// Function: addResource
|
|
|
|
// Define a new named resource.
|
2005-11-13 07:59:48 +00:00
|
|
|
// (Ex. Font::addResource("sans","freesans.ttf") would
|
|
|
|
// make it so that any attempts to load "sans" would load the font
|
|
|
|
// freesans.ttf)
|
2005-07-04 03:06:48 +00:00
|
|
|
//
|
|
|
|
// Parameters:
|
|
|
|
// name - Name to give to resource.
|
|
|
|
// path - Path of resource data file.
|
|
|
|
static void addResource(const std::string& name, const std::string& path,
|
|
|
|
uint size);
|
|
|
|
|
|
|
|
// Function: addResource
|
|
|
|
// Define a new unaliased resource. (name == path).
|
2005-11-13 07:59:48 +00:00
|
|
|
// (Ex. Font::addResource("freesans.ttf") is essentially the same as
|
|
|
|
// Font::addResource("freesans.ttf","freesans.ttf")
|
2005-07-04 03:06:48 +00:00
|
|
|
//
|
2005-11-13 07:59:48 +00:00
|
|
|
// Parameters:
|
2005-07-04 03:06:48 +00:00
|
|
|
// path - Path of resource data file.
|
|
|
|
static void addResource(const std::string& path, uint size);
|
|
|
|
|
2005-06-29 04:30:40 +00:00
|
|
|
private:
|
2005-07-03 05:20:49 +00:00
|
|
|
// font data
|
|
|
|
uint texID_;
|
|
|
|
uint listBase_;
|
|
|
|
std::vector<ubyte> widths_;
|
|
|
|
ubyte height_;
|
|
|
|
// stream drawing stuff
|
|
|
|
std::ostringstream ss_;
|
2005-07-18 07:19:48 +00:00
|
|
|
scalar drawX_;
|
|
|
|
scalar drawY_;
|
2005-07-17 07:14:09 +00:00
|
|
|
// color
|
|
|
|
Color color_;
|
2005-06-29 04:30:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif //PHOTON_VIDEO_FONT_HPP
|