231 lines
6.2 KiB
C++
231 lines
6.2 KiB
C++
/*******************************************************************************
|
|
This file is Part of the ZEngine Library for SDL Game Development.
|
|
Copyright (C) 2002 ConceptOfZero.net
|
|
|
|
Licensed under the BSD License, see licensing.txt.
|
|
|
|
The maintainer of this library is James Turk (jturk@conceptofzero.net)
|
|
and the home of this Library is http://www.conceptofzero.net/
|
|
*******************************************************************************/
|
|
|
|
/*!
|
|
\par File Header:
|
|
File: ZE_ZFont.h <br>
|
|
Description: Header file for core ZEngine Font Object. <br>
|
|
Author(s): James Turk <br>
|
|
$Id: ZE_ZFont.h,v 1.1 2002/11/21 05:41:10 cozman Exp $<br>
|
|
|
|
\file ZE_ZFont.h
|
|
\brief Definition file for ZFont.
|
|
|
|
Definition file for ZFont, the basic Font class for ZEngine.
|
|
**/
|
|
|
|
#ifndef __ze_zfont_h__
|
|
#define __ze_zfont_h__
|
|
|
|
#include "ZE_ZObject.h"
|
|
#include "ZE_ZImage.h"
|
|
|
|
#ifdef USE_SDL_TTF
|
|
|
|
namespace ZE
|
|
{
|
|
|
|
/*!
|
|
\brief ZFont class for basic Font use.
|
|
|
|
ZFont font container class, class wraps common features of SDL_TTF. Inherited from ZObject.
|
|
**/
|
|
class ZFont : public ZObject
|
|
{
|
|
protected:
|
|
//! Class containing font and filename.
|
|
FontData rFont;
|
|
//! SDL_Color for current text color.
|
|
SDL_Color rColor;
|
|
//! SDL_Color for background color to be used in shaded draws.
|
|
SDL_Color rBGColor;
|
|
|
|
public:
|
|
|
|
///////////////////////
|
|
//Opening and Closing//
|
|
///////////////////////
|
|
|
|
/*!
|
|
\brief Default Constructor.
|
|
|
|
Default Constructor, does nothing.
|
|
**/
|
|
ZFont();
|
|
|
|
/*!
|
|
\brief Constructor that opens a font with a certain size.
|
|
|
|
Constructor simply calls ZFont::Open() with same parameters.
|
|
\param filename Font to open.
|
|
\param size Size to use for font.
|
|
**/
|
|
ZFont(string filename, int size);
|
|
|
|
/*!
|
|
\brief Destructor, frees memory.
|
|
|
|
Destructor calls ZFont::Release().
|
|
**/
|
|
~ZFont();
|
|
|
|
/*!
|
|
\brief Opens a font with a certain size.
|
|
|
|
Opens a font given a filename and a point size.
|
|
\param filename Font to open.
|
|
\param size Size to use for font.
|
|
**/
|
|
void Open(string filename, int size);
|
|
|
|
/*!
|
|
\brief Release font.
|
|
|
|
Release memory held by font.
|
|
**/
|
|
void Release();
|
|
|
|
////////////////////////
|
|
//Settings and Drawing//
|
|
////////////////////////
|
|
|
|
/*!
|
|
\brief Draws a string in a color to a ZImage.
|
|
|
|
Draw to a surface in specified color and associate that surface with a ZImage.
|
|
\param text String to write.
|
|
\param image ZImage to draw to.
|
|
**/
|
|
void DrawText(string text, ZImage &image);
|
|
|
|
/*!
|
|
\brief Draws a string with a colored background to a ZImage.
|
|
|
|
Draw to a surface a string with a background of rBGColor and lettering in the normal color and associate that surface with a ZImage.
|
|
\param text String to write.
|
|
\param image ZImage to draw to.
|
|
**/
|
|
void DrawShadedText(string text, ZImage &image);
|
|
|
|
/*!
|
|
\brief Set Text rColor.
|
|
|
|
Set rColor of Text Output.
|
|
\param r Red component of color (0-255).
|
|
\param g Green component of color (0-255).
|
|
\param b Blue component of color (0-255).
|
|
**/
|
|
void SetColor(Uint8 r, Uint8 g, Uint8 b);
|
|
|
|
/*!
|
|
\brief Set Background rColor.
|
|
|
|
Set rColor of Background for Shaded Draw.
|
|
\param r Red component of color (0-255).
|
|
\param g Green component of color (0-255).
|
|
\param b Blue component of color (0-255).
|
|
**/
|
|
void SetBGColor(Uint8 r, Uint8 g, Uint8 b);
|
|
|
|
/*!
|
|
\brief Set display format.
|
|
|
|
Set display format (bold, italic, underline).
|
|
\param bold Decides bold setting of font.
|
|
\param italic Decides italic setting of font.
|
|
\param underline Decides underline setting of font.
|
|
**/
|
|
void SetStyle(bool bold, bool italic, bool underline);
|
|
|
|
/*!
|
|
\brief Resize Font.
|
|
|
|
Release and Reopen font in new size.
|
|
\param size New size for font.
|
|
**/
|
|
void Resize(int size);
|
|
|
|
/////////////
|
|
//Accessors//
|
|
/////////////
|
|
|
|
/*!
|
|
\brief Check if file is loaded.
|
|
|
|
Check if file is loaded and pointer to data is non-NULL.
|
|
\return Loaded or Unloaded state of data.
|
|
**/
|
|
bool IsLoaded();
|
|
|
|
/*!
|
|
\brief Get Bold Setting.
|
|
|
|
Check if font output is currently bold.
|
|
\return True or False state of bold.
|
|
**/
|
|
bool IsBold();
|
|
|
|
/*!
|
|
\brief Get Italic Setting.
|
|
|
|
Check if font output is currently italic.
|
|
\return True or False state of italic.
|
|
**/
|
|
bool IsItalic();
|
|
|
|
/*!
|
|
\brief Get Underlined Setting.
|
|
|
|
Check if font output is currently underline.
|
|
\return True or False state of underline.
|
|
**/
|
|
bool IsUnderlined();
|
|
|
|
/*!
|
|
\brief Get Height of Font.
|
|
|
|
Check font height as reported by SDL_ttf.
|
|
\return Height of font.
|
|
**/
|
|
int GetHeight();
|
|
|
|
/*!
|
|
\brief Get Line Skip for Font.
|
|
|
|
Check font line skip as reported by SDL_ttf.
|
|
\return Recommended Line Skip of font.
|
|
**/
|
|
int GetLineSkip();
|
|
|
|
/*!
|
|
\brief Get String Width.
|
|
|
|
Get Width of String in Current Font in Pixels.
|
|
\param text String to get width of.
|
|
\return Width of String in Current font.
|
|
**/
|
|
int GetStringWidth(string text);
|
|
|
|
/*!
|
|
\brief Get String Height.
|
|
|
|
Get Height of String in Current Font in Pixels.
|
|
\param text String to get height of.
|
|
\return Height of String in Current font.
|
|
**/
|
|
int GetStringHeight(string text);
|
|
};
|
|
|
|
}
|
|
|
|
#endif //USE_SDL_TTF
|
|
|
|
#endif //__ze_zfont_h__
|