This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/ftfont/FTF_Api.h

159 lines
3.6 KiB
C++
Raw Normal View History

/**
* $Id$
*
* ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
*
* 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 2
* of the License, or (at your option) any later version. The Blender
* Foundation also sells licenses for use in proprietary software under
* the Blender License. See http://www.blender.org/BL/ for information
* about this.
*
* 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, write to the Free Software Foundation,
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
* All rights reserved.
*
* The Original Code is: all of this file.
*
* Contributor(s): none yet.
*
* ***** END GPL/BL DUAL LICENSE BLOCK *****
*/
#ifndef _FTF_API_H
#define _FTF_API_H
#define FTF_EXPORT
#ifdef __cplusplus
extern "C" {
#endif
#include <stdio.h>
#include "FTF_Settings.h"
/**
* Set Font Size
* @param int size
*/
FTF_EXPORT void FTF_SetSize(int size);
/**
* Get Font Size
* @return Font size
*/
FTF_EXPORT int FTF_GetSize(void);
/**
* Ascender
* @return Ascend size
*/
FTF_EXPORT int FTF_Ascender(void);
/**
* Descender
* @return Descend size
*/
FTF_EXPORT int FTF_Descender(void);
/**
* String Translation and Code Conversion
* @param str source string
* @param ustr distnation string
* @param flag mode flag
*/
FTF_EXPORT void FTF_TransConvString(char* str, char* ustr, unsigned int flag);
/**
* Draw a character at the current raster position.
* @param c the character to draw
* @param mode flag to forward to FTF_TransConvString()
* @return Width drawing
*/
//FTF_EXPORT float FTF_DrawCharacter(char c, unsigned int flag);
/**
* Draws a string at the current raster postion.
* @param str The string to draw
* @param mode flag to forward to FTF_TransConvString()
* @return Width drawing
*/
FTF_EXPORT float FTF_DrawString(char* str, unsigned int flag, int select);
/**
* Draws a string at the current raster postion with rgb coloring.
* @param str The string to draw
* @param rgb Floats to manipulate the the glyph pixmap coloring.
* @param mode flag to forward to FTF_TransConvString()
* @return Width drawing
*/
FTF_EXPORT float FTF_DrawStringRGB(char* str, unsigned int flag, float r, float g, float b);
/**
* Get a character width
* @param mode flag to forward to FTF_TransConvString()
*/
FTF_EXPORT float FTF_GetCharacterWidth(char c, unsigned int flag);
/**
* Get a string width
* @param mode flag to forward to FTF_TransConvString()
*/
FTF_EXPORT float FTF_GetStringWidth(char* str, unsigned int flag);
/**
* Get Bounding Box
* @param llx
* @param lly
* @param llz
* @param urx
* @param ury
* @param urz
* @param mode flag to forward to FTF_TransConvString()
* not test yet.
*/
FTF_EXPORT void FTF_GetBoundingBox(char* str, float*llx, float *lly, float *llz, float *urx, float *ury, float *urz, unsigned int flag);
/**
* Following stuff added by phase
*/
/**
* SetFont
* @param str
* @param size
*/
FTF_EXPORT int FTF_SetFont(char* str, int size);
/**
* SetLanguage
* @param str
* not test yet.
*/
FTF_EXPORT void FTF_SetLanguage(char* str);
/**
* SetLanguage
* @param str
* not tested yet.
*/
FTF_EXPORT void FTF_SetEncoding(char* str);
#ifdef __cplusplus
}
#endif
#endif /* __FTF_API_H */