10#ifndef __PARAGRAPHLAYOUT_H
12#define __PARAGRAPHLAYOUT_H
24#if ! UCONFIG_NO_BREAK_ITERATION
26#include "layout/LETypes.h"
27#include "layout/LEFontInstance.h"
28#include "layout/LayoutEngine.h"
167 static const char fgClassID;
182 inline Line &operator=(
const Line & ) {
return *
this; }
184 void computeMetrics();
239 inline le_int32 getGlyphCount()
const;
251 inline const LEGlyphID *getGlyphs()
const;
266 inline const float *getPositions()
const;
278 inline const le_int32 *getGlyphToCharMap()
const;
330 static const char fgClassID;
338 const float *fPositions;
507 inline void reflow();
509#ifndef U_HIDE_INTERNAL_API
562 static const char fgClassID;
580 ParagraphLayout(
const ParagraphLayout & ) : UObject( ){}
581 inline ParagraphLayout &operator=(
const ParagraphLayout & ) {
return *
this; }
583 void computeLevels(
UBiDiLevel paragraphLevel);
585 Line *computeVisualRuns();
586 void appendRun(Line *line, le_int32 run, le_int32 firstChar, le_int32 lastChar);
588 void computeScripts();
590 void computeLocales();
592 void computeSubFonts(
const FontRuns *fontRuns, LEErrorCode &status);
594 void computeMetrics();
596 le_int32 getLanguageCode(
const Locale *locale);
598 le_int32 getCharRun(le_int32 charIndex);
602 le_int32 previousBreak(le_int32 charIndex);
605 const LEUnicode *fChars;
608 const FontRuns *fFontRuns;
609 const ValueRuns *fLevelRuns;
610 const ValueRuns *fScriptRuns;
611 const LocaleRuns *fLocaleRuns;
614 le_bool fClientLevels;
615 le_bool fClientScripts;
616 le_bool fClientLocales;
624 le_int32 *fGlyphToCharMap;
625 le_int32 *fCharToMinGlyphMap;
626 le_int32 *fCharToMaxGlyphMap;
628 le_int32 fGlyphCount;
633 le_int32 *fStyleRunLimits;
634 le_int32 *fStyleIndices;
635 StyleRunInfo *fStyleRunInfo;
636 le_int32 fStyleRunCount;
638 BreakIterator *fBreakIterator;
642 le_int32 fFirstVisualRun;
643 le_int32 fLastVisualRun;
644 float fVisualRunLastX;
645 float fVisualRunLastY;
658inline void ParagraphLayout::reflow()
663inline ParagraphLayout::Line::Line()
664 :
UObject(), fAscent(0), fDescent(0), fLeading(0), fRunCount(0), fRunCapacity(0), fRuns(
nullptr)
669inline ParagraphLayout::Line::Line(
const Line & )
670 : UObject(), fAscent(0), fDescent(0), fLeading(0), fRunCount(0), fRunCapacity(0), fRuns(nullptr)
707 return fGlyphToCharMap;
712 return fFont->getAscent();
717 return fFont->getDescent();
722 return fFont->getLeading();
725inline ParagraphLayout::VisualRun::VisualRun()
731inline ParagraphLayout::VisualRun::VisualRun(
const VisualRun &)
737inline ParagraphLayout::VisualRun::VisualRun(
const LEFontInstance *font,
UBiDiDirection direction, le_int32 glyphCount,
738 const LEGlyphID glyphs[],
const float positions[],
const le_int32 glyphToCharMap[])
739 : fFont(font), fDirection(direction), fGlyphCount(glyphCount),
740 fGlyphs(glyphs), fPositions(positions), fGlyphToCharMap(glyphToCharMap)
C++ API: base class for building classes which represent data that is associated with runs of text.
The FontRuns class associates pointers to LEFontInstance objects with runs of text.
"Smart pointer" base class; do not use directly: use LocalPointer etc.
The LocaleRuns class associates pointers to Locale objects with runs of text.
A Locale object represents a specific geographical, political, or cultural region.
This class represents a single line of text in a ParagraphLayout.
UClassID getDynamicClassID() const override
ICU "poor man's RTTI", returns a UClassID for the actual class.
~Line()
The constructor is private since these objects can only be created by ParagraphLayout.
const VisualRun * getVisualRun(le_int32 runIndex) const
Get a ParagraphLayout::VisualRun object for a given visual run in the line.
le_int32 countRuns() const
Count the number of visual runs in the line.
static UClassID getStaticClassID()
ICU "poor man's RTTI", returns a UClassID for this class.
le_int32 getWidth() const
Get the width of the line.
le_int32 getLeading() const
Get the leading of the line.
le_int32 getDescent() const
Get the descent of the line.
le_int32 getAscent() const
Get the ascent of the line.
This object represents a single visual run in a line of text in a paragraph.
static UClassID getStaticClassID()
ICU "poor man's RTTI", returns a UClassID for this class.
const LEFontInstance * getFont() const
Get the LEFontInstance object which represents the font of the visual run.
const le_int32 * getGlyphToCharMap() const
Get the glyph-to-character map for this visual run.
le_int32 getAscent() const
A convenience method which returns the ascent value for the font associated with this run.
UBiDiDirection getDirection() const
Get the direction of the visual run.
le_int32 getDescent() const
A convenience method which returns the descent value for the font associated with this run.
le_int32 getLeading() const
A convenience method which returns the leading value for the font associated with this run.
const LEGlyphID * getGlyphs() const
Get the glyphs in the visual run.
le_int32 getGlyphCount() const
Get the number of glyphs in the visual run.
const float * getPositions() const
Get the (x, y) positions of the glyphs in the visual run.
UClassID getDynamicClassID() const override
ICU "poor man's RTTI", returns a UClassID for the actual class.
le_bool isDone() const
Convenience method for determining if paragraph layout processing is complete ( i....
virtual le_int32 getAscent() const
Return the max ascent value for all the fonts in the paragraph.
virtual le_int32 getDescent() const
Return the max descent value for all the fonts in the paragraph.
static UClassID getStaticClassID()
ICU "poor man's RTTI", returns a UClassID for this class.
~ParagraphLayout()
The destructor.
virtual le_int32 getLeading() const
Return the max leading value for all the fonts in the paragraph.
UClassID getDynamicClassID() const override
ICU "poor man's RTTI", returns a UClassID for the actual class.
static le_bool isComplex(const LEUnicode chars[], le_int32 count)
Examine the given text and determine if it contains characters in any script which requires complex p...
ParagraphLayout(const LEUnicode chars[], le_int32 count, const FontRuns *fontRuns, const ValueRuns *levelRuns, const ValueRuns *scriptRuns, const LocaleRuns *localeRuns, UBiDiLevel paragraphLevel, le_bool vertical, LEErrorCode &status)
Construct a ParagraphLayout object for a styled paragraph.
Line * nextLine(float width)
Return a ParagraphLayout::Line object which represents next line in the paragraph.
UObject is the common ICU "boilerplate" class.
The ValueRuns class associates integer values with runs of text.
UBiDiDirection
UBiDiDirection values indicate the text direction.
@ UBIDI_LTR
Left-to-right text.
U_CAPI UBiDiDirection ubidi_getDirection(const UBiDi *pBiDi)
Get the directionality of the text.
uint8_t UBiDiLevel
UBiDiLevel is the type of the level values in this Bidi implementation.
U_CAPI UBiDiLevel ubidi_getParaLevel(const UBiDi *pBiDi)
Get the paragraph level of the text.
void * UClassID
UClassID is used to identify classes without using the compiler's RTTI.
C API: Unicode Script Information.
UScriptCode
Constants for ISO 15924 script codes.
#define U_LAYOUTEX_API
Set to export library symbols from inside the layout extensions library, and to import them from outs...