2024-04-20 15:57:49 +00:00
|
|
|
/*
|
|
|
|
* Descent 3
|
|
|
|
* Copyright (C) 2024 Parallax Software
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2024-05-06 15:12:44 +00:00
|
|
|
--- HISTORICAL COMMENTS FOLLOW ---
|
|
|
|
|
2024-04-16 03:43:29 +00:00
|
|
|
* $Logfile: /DescentIII/Main/Lib/grtext.h $
|
|
|
|
* $Revision: 25 $
|
|
|
|
* $Date: 11/16/99 3:18p $
|
|
|
|
* $Author: Samir $
|
|
|
|
*
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
*
|
|
|
|
* $Log: /DescentIII/Main/Lib/grtext.h $
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 25 11/16/99 3:18p Samir
|
|
|
|
* added new data to font file and kept compatibility with D3 fonts:
|
|
|
|
* tracking value.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 24 4/17/99 6:16p Samir
|
|
|
|
* added kerning and 4444 alphaed font support.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 23 4/02/99 3:49p Kevin
|
|
|
|
* Added profanity filter code
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 22 4/01/99 5:23p Samir
|
|
|
|
* Added function to get character info.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 21 3/02/99 6:26p Samir
|
|
|
|
* added font template width and height functions.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 20 2/21/99 6:39p Samir
|
|
|
|
* added function to get ascii value of font character.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 19 1/20/99 3:43a Jeff
|
|
|
|
* added function to get clipping parameters
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 18 11/03/98 7:04p Samir
|
|
|
|
* made Grtext_spacing global so word wrapper could access it.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 17 10/22/98 2:41p Samir
|
|
|
|
* made grtext_Puts public.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 16 10/21/98 11:50p Samir
|
|
|
|
* added prototype for advanced grtext get char info function.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 15 10/16/98 1:54p Kevin
|
|
|
|
* Changes for Demo Beta 4
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 14 9/24/98 2:56p Samir
|
|
|
|
* added ability to format strings inside string.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 13 9/08/98 10:27a Samir
|
|
|
|
* added function to get text height.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 12 6/23/98 5:04p Samir
|
|
|
|
* added grtext_GetColor
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 11 4/27/98 3:46p Samir
|
|
|
|
* scaling fonts.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 10 4/18/98 2:08a Samir
|
|
|
|
* extended text buffer.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 9 2/13/98 6:37p Samir
|
|
|
|
* Fixed tabs.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 8 2/03/98 12:13p Samir
|
|
|
|
* Font shadowing support added.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 7 1/30/98 2:15p Samir
|
|
|
|
* Allow for text saturation.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 6 1/23/98 6:53p Samir
|
|
|
|
* Added grtext_PutChar.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 5 1/12/98 5:24p Samir
|
|
|
|
* Fixed font reading and created font spew test function.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 4 1/08/98 12:16p Samir
|
|
|
|
* GetLineWidth now takes a const char *
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 3 12/30/97 5:23p Samir
|
|
|
|
* More stuff.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 2 12/29/97 5:50p Samir
|
|
|
|
* Added ability to set text window.
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* 1 12/29/97 3:24p Samir
|
|
|
|
* Initial revision
|
2024-04-16 18:56:40 +00:00
|
|
|
*
|
2024-04-16 03:43:29 +00:00
|
|
|
* $NoKeywords: $
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GRTEXT_H
|
|
|
|
#define GRTEXT_H
|
|
|
|
|
|
|
|
#include "pstypes.h"
|
|
|
|
#include "ddvid.h"
|
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
#define GRTEXT_BUFLEN 16384
|
|
|
|
#define GRTEXT_FORMAT_CHAR 0x2
|
|
|
|
#define GRTEXT_FORMAT_SCALAR 4 // value mulitplied to formatting value in string.
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
#define GRTEXTFLAG_SATURATE 1
|
|
|
|
#define GRTEXTFLAG_SHADOW 2
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
struct tFontTemplate;
|
|
|
|
|
|
|
|
extern int Grtext_spacing;
|
|
|
|
|
|
|
|
// sets text clipping parameters
|
2024-04-16 18:56:40 +00:00
|
|
|
void grtext_SetParameters(int left, int top, int right, int bottom, int tabspace = 4);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// gets text clipping parameters
|
|
|
|
void grtext_GetParameters(int *left, int *top, int *right, int *bottom, int *tabspace);
|
|
|
|
|
|
|
|
// clears text buffer. doesn't render.
|
|
|
|
void grtext_Reset();
|
|
|
|
|
|
|
|
// sets the color for text
|
|
|
|
void grtext_SetColor(ddgr_color col);
|
|
|
|
|
|
|
|
// returns color set by grtext_SetColor (does not count intra-string color changes)
|
|
|
|
ddgr_color grtext_GetColor();
|
|
|
|
|
|
|
|
// sets fancy color for text
|
|
|
|
void grtext_SetFancyColor(ddgr_color col1, ddgr_color col2, ddgr_color col3, ddgr_color col4);
|
|
|
|
|
|
|
|
// sets the alpha value for text
|
2024-05-24 03:07:26 +00:00
|
|
|
void grtext_SetAlpha(uint8_t alpha);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// gets font alpha
|
2024-05-24 03:07:26 +00:00
|
|
|
uint8_t grtext_GetAlpha();
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
// toggles text saturation
|
2024-04-16 03:43:29 +00:00
|
|
|
void grtext_SetFlags(int flags);
|
|
|
|
|
|
|
|
// sets the font for text
|
|
|
|
void grtext_SetFont(int font_handle);
|
|
|
|
|
|
|
|
// sets font scale (1.0 = normal, 0.5 = 1/2, 2.0 = twice as large.
|
|
|
|
void grtext_SetFontScale(float scale);
|
|
|
|
|
|
|
|
// gets the current font
|
|
|
|
int grtext_GetFont();
|
|
|
|
|
|
|
|
// returns the height of a string in current font.
|
|
|
|
int grtext_GetTextHeight(const char *str);
|
|
|
|
#define grtext_GetHeight(_s) grtext_GetTextHeight(_s)
|
|
|
|
|
|
|
|
// returns height of text using a font template
|
|
|
|
int grtext_GetTextHeightTemplate(tFontTemplate *ft, const char *str);
|
2024-04-16 18:56:40 +00:00
|
|
|
#define grtext_GetHeightTemplate(_t, _s) grtext_GetTextHeightTemplate(_t, _s)
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// returns width of text in current font.
|
|
|
|
int grtext_GetTextLineWidth(const char *str);
|
|
|
|
#define grtext_GetLineWidth(_s) grtext_GetTextLineWidth(_s)
|
|
|
|
|
|
|
|
// returns width of text using a font template
|
|
|
|
int grtext_GetTextLineWidthTemplate(const tFontTemplate *ft, const char *str);
|
|
|
|
#define grtext_GetLineWidthTemplate(_t, _s) grtext_GetTextLineWidthTemplate(_t, _s)
|
|
|
|
|
|
|
|
// puts a formatted string in the text buffer
|
|
|
|
void grtext_Printf(int x, int y, const char *fmt, ...);
|
|
|
|
|
|
|
|
// puts a string on the buffer
|
|
|
|
void grtext_Puts(int x, int y, const char *str);
|
|
|
|
|
|
|
|
// puts a character down
|
|
|
|
void grtext_PutChar(int x, int y, int ch);
|
|
|
|
|
|
|
|
// puts a centered string in the text buffer.
|
|
|
|
void grtext_CenteredPrintf(int xoff, int y, const char *fmt, ...);
|
|
|
|
|
|
|
|
// renders all text in buffer and clears buffer. USUALLY CALL THIS TO RENDER TEXT
|
|
|
|
void grtext_Flush();
|
|
|
|
|
|
|
|
// renders all text but DOESN'T flush buffer
|
|
|
|
void grtext_Render();
|
|
|
|
|
|
|
|
// gets character information for the current string
|
|
|
|
// ch is a SINGLE CHARACTER
|
|
|
|
// col is the color of the current string as reported through formatting, or GR_NULL if no info
|
|
|
|
// x is the old x before call and the new potential adjusted x after the call.
|
|
|
|
// newline if it's a newline.
|
|
|
|
// line start x;
|
2024-05-30 07:35:17 +00:00
|
|
|
struct tGetCharInfo {
|
2024-04-16 18:56:40 +00:00
|
|
|
int sx; // this will not be modified. the initial x on the same line as the string
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
ddgr_color col; // these values will be modified
|
|
|
|
int x, w; // x of char, and width of char.
|
|
|
|
bool newline; // reached a newline?
|
|
|
|
bool font_char; // character exists in font?
|
|
|
|
char ch;
|
2024-05-30 07:35:17 +00:00
|
|
|
};
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
const char *grtext_GetChar(const char *str, tGetCharInfo *ci);
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// font functions!
|
|
|
|
|
|
|
|
// we can load a font template into this structure. call grfont_FreeTemplate(tFontTemplate) to free memory here.
|
2024-05-30 07:35:17 +00:00
|
|
|
struct tFontTemplate {
|
2024-05-24 03:16:40 +00:00
|
|
|
uint16_t min_ascii, max_ascii;
|
2024-05-24 03:07:26 +00:00
|
|
|
uint8_t *ch_widths;
|
|
|
|
uint8_t *kern_data;
|
|
|
|
uint8_t ch_height;
|
|
|
|
uint8_t ch_maxwidth; // max width of character in font.
|
2024-04-16 18:56:40 +00:00
|
|
|
bool proportional; // is this font proportional? if so use array of widths, else use maxwidth
|
|
|
|
bool uppercase; // uppercase font?
|
|
|
|
bool monochromatic; // font is monochromatic?
|
|
|
|
bool newstyle; // new style 4444 font.
|
|
|
|
bool ffi2; // new font info added.
|
|
|
|
|
|
|
|
// ffi2 style (font file info 2)
|
2024-05-24 03:05:05 +00:00
|
|
|
int8_t ch_tracking; // global tracking for font.
|
2024-05-30 07:35:17 +00:00
|
|
|
};
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// clears out font buffer.
|
|
|
|
void grfont_Reset();
|
|
|
|
|
|
|
|
// returns a handle to a loaded font.
|
2024-04-28 04:39:29 +00:00
|
|
|
int grfont_Load(const char *fname);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// frees a loaded font
|
|
|
|
void grfont_Free(int handle);
|
|
|
|
|
|
|
|
// loads a font template
|
2024-04-28 04:39:29 +00:00
|
|
|
bool grfont_LoadTemplate(const char *fname, tFontTemplate *ft);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// frees a font template
|
|
|
|
void grfont_FreeTemplate(tFontTemplate *ft);
|
|
|
|
|
|
|
|
// returns a character's width
|
|
|
|
int grfont_GetCharWidth(int font, int ch);
|
|
|
|
|
|
|
|
// returns a font's height
|
|
|
|
int grfont_GetHeight(int font);
|
|
|
|
|
|
|
|
// returns a character's width
|
|
|
|
int grfont_GetKernedSpacing(int font, int ch1, int ch2);
|
|
|
|
|
|
|
|
// returns a character's width
|
|
|
|
int grfont_GetKernedSpacingTemp(const tFontTemplate *ft, int ch1, int ch2);
|
|
|
|
|
|
|
|
// converts a key code to ascii version, and checks if in font. converts lowercase to upper if font
|
|
|
|
// doesn't have a lowercase set. useful alternative to ddio_KeyToAscii.
|
|
|
|
int grfont_KeyToAscii(int font, int key);
|
|
|
|
|
|
|
|
// returns the raw bitmap data for a character in a font, its width and height
|
|
|
|
// returned data should be in 565 hicolor format if (*mono) is false. if (*mono) is true,
|
|
|
|
// then a bitmask will be returned, and you should treat a bit as a pixel.
|
2024-05-24 03:16:40 +00:00
|
|
|
uint16_t *grfont_GetRawCharacterData(int font, int ch, int *w, int *h, bool *mono);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
2024-04-16 18:56:40 +00:00
|
|
|
// EDITING FUNCTIONS ONLY
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// sets a template to a font, be careful.
|
|
|
|
bool grfont_SetTemplate(const char *pathname, const tFontTemplate *ft);
|
|
|
|
|
|
|
|
// sets a font's template without saving...
|
2024-05-24 03:07:26 +00:00
|
|
|
bool grfont_SetKerning(int font, uint8_t *kern_data);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// sets a font's tracking
|
|
|
|
bool grfont_SetTracking(int font, int tracking);
|
|
|
|
int grfont_GetTracking(int font);
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
// Init functions -- call before anything is rendered!
|
2024-04-16 03:43:29 +00:00
|
|
|
void grtext_Init(void);
|
|
|
|
|
|
|
|
#ifndef RELEASE
|
|
|
|
void grfont_Spew(int font, int x, int y);
|
|
|
|
#endif
|
|
|
|
|
2024-05-30 07:35:17 +00:00
|
|
|
struct tFontFileInfo2 // to maintain compatibility with older fonts (64 bytes long)
|
2024-04-16 03:43:29 +00:00
|
|
|
{
|
2024-05-24 03:27:12 +00:00
|
|
|
int16_t tracking;
|
2024-04-16 18:56:40 +00:00
|
|
|
char reserved[62];
|
2024-05-30 07:35:17 +00:00
|
|
|
};
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// font data structure internal to library but available for font editors
|
2024-05-30 07:35:17 +00:00
|
|
|
struct tFontFileInfo {
|
2024-05-24 03:27:12 +00:00
|
|
|
int16_t width, height; // width of widest character and height of longest char
|
|
|
|
int16_t flags; // flags used by the character renderer
|
|
|
|
int16_t baseline; // pixels given to lowercase below script line start at baseline
|
2024-05-24 03:07:26 +00:00
|
|
|
uint8_t min_ascii; // minimum ascii value used by font
|
|
|
|
uint8_t max_ascii; // max ascii value used by the font
|
2024-05-24 03:27:12 +00:00
|
|
|
int16_t byte_width; // width of a character in the font in bytes
|
2024-05-24 03:07:26 +00:00
|
|
|
uint8_t *raw_data; // pixel, map data.
|
|
|
|
uint8_t **char_data; // pointers to each character
|
|
|
|
uint8_t *char_widths; // individual pixel widths of each character
|
|
|
|
uint8_t *kern_data; // kerning information for specific letter combos
|
2024-04-16 18:56:40 +00:00
|
|
|
|
|
|
|
// FFI2 (newstyle) data
|
|
|
|
tFontFileInfo2 ffi2;
|
|
|
|
|
|
|
|
// misc.
|
|
|
|
float brightness; // this IS NOT in the file, but a part of the baseline element. (upper 8bits)
|
2024-05-30 07:35:17 +00:00
|
|
|
};
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
#define FT_COLOR 1
|
|
|
|
#define FT_PROPORTIONAL 2
|
|
|
|
#define FT_KERNED 4
|
|
|
|
#define FT_GRADIENT 8
|
|
|
|
#define FT_FMT4444 16
|
|
|
|
#define FT_FFI2 32 // all fonts made after D3 should have this flag set.
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-26 22:22:03 +00:00
|
|
|
#endif
|