PHP 8.2.31
Preview: ScriptCompositeFontInstance.h Size: 6.15 KB
//proc/thread-self/root/opt/alt/libicu65/usr/share/doc/alt-libicu65-devel/samples/layout/ScriptCompositeFontInstance.h

/*
 * %W% %E%
 *
 * © 2016 and later: Unicode, Inc. and others.
 * License & terms of use: http://www.unicode.org/copyright.html#License
 *
 * (C) Copyright IBM Corp. 1998-2011 - All Rights Reserved
 *
 */

#ifndef __SCRIPTCOMPOSITEFONTINSTANCE_H
#define __SCRIPTCOMPOSITEFONTINSTANCE_H

#include "layout/LETypes.h"
#include "layout/LEFontInstance.h"

#include "FontMap.h"

// U_NAMESPACE_BEGIN

class ScriptCompositeFontInstance : public LEFontInstance
{
public:

    ScriptCompositeFontInstance(FontMap *fontMap);

    virtual ~ScriptCompositeFontInstance();

      /**
     * Get a physical font which can render the given text. For composite fonts,
     * if there is no single physical font which can render all of the text,
     * return a physical font which can render an initial substring of the text,
     * and set the <code>offset</code> parameter to the end of that substring.
     *
     * Internally, the LayoutEngine works with runs of text all in the same
     * font and script, so it is best to call this method with text which is
     * in a single script, passing the script code in as a hint. If you don't
     * know the script of the text, you can use zero, which is the script code
     * for characters used in more than one script.
     *
     * The default implementation of this method is intended for instances of
     * <code>LEFontInstance</code> which represent a physical font. It returns
     * <code>this</code> and indicates that the entire string can be rendered.
     *
     * This method will return a valid <code>LEFontInstance</code> unless you
     * have passed illegal parameters, or an internal error has been encountered. 
     * For composite fonts, it may return the warning <code>LE_NO_SUBFONT_WARNING</code>
     * to indicate that the returned font may not be able to render all of
     * the text. Whenever a valid font is returned, the <code>offset</code> parameter
     * will be advanced by at least one.
     *
     * Subclasses which implement composite fonts must override this method.
     * Where it makes sense, they should use the script code as a hint to render
     * characters from the COMMON script in the font which is used for the given
     * script. For example, if the input text is a series of Arabic words separated
     * by spaces, and the script code passed in is <code>arabScriptCode</code> you
     * should return the font used for Arabic characters for all of the input text,
     * including the spaces. If, on the other hand, the input text contains characters
     * which cannot be rendered by the font used for Arabic characters, but which can
     * be rendered by another font, you should return that font for those characters.
     *
     * @param chars   - the array of Unicode characters.
     * @param offset  - a pointer to the starting offset in the text. On exit this
     *                  will be set the the limit offset of the text which can be
     *                  rendered using the returned font.
     * @param limit   - the limit offset for the input text.
     * @param script  - the script hint.
     * @param success - set to an error code if the arguments are illegal, or no font
     *                  can be returned for some reason. May also be set to
     *                  <code>LE_NO_SUBFONT_WARNING</code> if the subfont which
     *                  was returned cannot render all of the text.
     *
     * @return an <code>LEFontInstance</code> for the sub font which can render the characters, or
     *         <code>NULL</code> if there is an error.
     *
     * @see LEScripts.h
     */
    virtual const LEFontInstance *getSubFont(const LEUnicode chars[], le_int32 *offset, le_int32 limit, le_int32 script, LEErrorCode &success) const;

    /**
     * This method maps a single character to a glyph index, using the
     * font's charcter to glyph map.
     *
     * @param ch - the character
     *
     * @return the glyph index
     */
    virtual LEGlyphID mapCharToGlyph(LEUnicode32 ch) const;

    virtual const void *getFontTable(LETag tableTag) const;

    virtual le_int32 getUnitsPerEM() const;

    virtual le_int32 getAscent() const;

    virtual le_int32 getDescent() const;

    virtual le_int32 getLeading() const;

    virtual void getGlyphAdvance(LEGlyphID glyph, LEPoint &advance) const;

    virtual le_bool getGlyphPoint(LEGlyphID glyph, le_int32 pointNumber, LEPoint &point) const;

    float getXPixelsPerEm() const;

    float getYPixelsPerEm() const;

    float getScaleFactorX() const;

    float getScaleFactorY() const;

    /**
     * ICU "poor man's RTTI", returns a UClassID for the actual class.
     */
    virtual inline UClassID getDynamicClassID() const { return getStaticClassID(); }

    /**
     * ICU "poor man's RTTI", returns a UClassID for this class.
     */
    static inline UClassID getStaticClassID() { return (UClassID)&fgClassID; }

protected:
    FontMap *fFontMap;

private:

    /**
     * The address of this static class variable serves as this class's ID
     * for ICU "poor man's RTTI".
     */
    static const char fgClassID;
};

inline const void *ScriptCompositeFontInstance::getFontTable(LETag /*tableTag*/) const
{
    return NULL;
}

// Can't get units per EM without knowing which sub-font, so
// return a value that will make units == points
inline le_int32 ScriptCompositeFontInstance::getUnitsPerEM() const
{
    return 1;
}

inline le_int32 ScriptCompositeFontInstance::getAscent() const
{
    return fFontMap->getAscent();
}

inline le_int32 ScriptCompositeFontInstance::getDescent() const
{
    return fFontMap->getDescent();
}

inline le_int32 ScriptCompositeFontInstance::getLeading() const
{
    return fFontMap->getLeading();
}

inline float ScriptCompositeFontInstance::getXPixelsPerEm() const
{
    return fFontMap->getPointSize();
}

inline float ScriptCompositeFontInstance::getYPixelsPerEm() const
{
    return fFontMap->getPointSize();
}

// Can't get a scale factor without knowing the sub-font, so
// return 1.0.
inline float ScriptCompositeFontInstance::getScaleFactorX() const
{
    return 1.0;
}

// Can't get a scale factor without knowing the sub-font, so
// return 1.0
inline float ScriptCompositeFontInstance::getScaleFactorY() const
{
    return 1.0;
}

// U_NAMESPACE_END
#endif

Directory Contents

Dirs: 0 × Files: 56

Name Size Perms Modified Actions
646 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
8.45 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
9.82 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
5.30 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
2.06 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
7.34 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
426 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
392 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.84 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
2.37 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.06 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
9.60 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
3.60 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.32 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.23 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.67 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
983 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
862 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
949 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
5.43 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
3.79 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.39 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.21 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.64 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
986 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.05 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
961 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
8.50 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
370 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
890 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
9.80 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.17 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
12.92 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
3.06 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
3.37 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
2.92 KB lrw-r--r-- 2026-06-02 15:59:40
Edit Download
2.92 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
7.58 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
2.18 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
9.27 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
940 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
7.32 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.09 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
907 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
712 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
528 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
1.66 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
3.20 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
6.15 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
4.90 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
892 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
519 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
509 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
422 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download
4.10 KB lrw-r--r-- 2019-10-03 11:16:41
Edit Download
999 B lrw-r--r-- 2019-10-03 11:16:41
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).