⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ftface.h

📁 ftgl-2.1.2 夸平台的opengl显示字体
💻 H
字号:
#ifndef     __FTFace__#define     __FTFace__#include <ft2build.h>#include FT_FREETYPE_H#include FT_GLYPH_H#include "FTGL.h"#include "FTPoint.h"#include "FTSize.h"/** * FTFace class provides an abstraction layer for the Freetype Face. * * @see "Freetype 2 Documentation" * */class FTGL_EXPORT FTFace{    public:        /**         * Opens and reads a face file. Error is set.         *         * @param fontFilePath  font file path.         */        FTFace( const char* fontFilePath);        /**         * Read face data from an in-memory buffer. Error is set.         *         * @param pBufferBytes  the in-memory buffer         * @param bufferSizeInBytes  the length of the buffer in bytes         */        FTFace( const unsigned char *pBufferBytes, size_t bufferSizeInBytes );        /**         * Destructor         *         * Disposes of the current Freetype Face.         */        virtual ~FTFace();        /**         * Attach auxilliary file to font (e.g., font metrics).         *         * @param fontFilePath  auxilliary font file path.         * @return          <code>true</code> if file has opened         *                  successfully.         */        bool Attach( const char* fontFilePath);        /**         * Attach auxilliary data to font (e.g., font metrics) from memory         *         * @param pBufferBytes  the in-memory buffer         * @param bufferSizeInBytes  the length of the buffer in bytes         * @return          <code>true</code> if file has opened         *                  successfully.         */        bool Attach( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);        /**         * Get the freetype face object..         *         * @return pointer to an FT_Face.         */        FT_Face* Face() const { return ftFace;}                /**         * Sets the char size for the current face.         *         * This doesn't guarantee that the size was set correctly. Clients         * should check errors.         *         * @param size      the face size in points (1/72 inch)         * @param res       the resolution of the target device.         * @return          <code>FTSize</code> object         */        const FTSize& Size( const unsigned int size, const unsigned int res);        /**         * Get the number of character maps in this face.         *         * @return character map count.         */        unsigned int CharMapCount();        /**         * Get a list of character maps in this face.         *         * @return pointer to the first encoding.         */        FT_Encoding* CharMapList();                /**         * Gets the kerning vector between two glyphs         */        FTPoint KernAdvance( unsigned int index1, unsigned int index2);        /**         * Loads and creates a Freetype glyph.         */        FT_GlyphSlot Glyph( unsigned int index, FT_Int load_flags);        /**         * Gets the number of glyphs in the current face.         */        unsigned int GlyphCount() const { return numGlyphs;}        /**         * Queries for errors.         *         * @return  The current error code.         */        FT_Error Error() const { return err; }            private:        /**         * The Freetype face         */        FT_Face* ftFace;        /**         * The size object associated with this face         */        FTSize  charSize;                /**         * The number of glyphs in this face         */        int numGlyphs;                FT_Encoding* fontEncodingList;        /**         * This face has kerning tables         */         bool hasKerningTable;        /**         * Current error code. Zero means no error.         */        FT_Error err;};#endif  //  __FTFace__

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -