X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Flayouts%2Flayout-parameters.h;h=b3aeaadf79e8eac2dd6b608db03ba28b903a8095;hp=7f3e16924731874e7596456622e1943a61d1bdef;hb=528aa3699cd51dab5115bca1aaebb65d4bc67c15;hpb=e70f617e67183aae0301f1d6c71930cd98f9870e diff --git a/dali-toolkit/internal/text/layouts/layout-parameters.h b/dali-toolkit/internal/text/layouts/layout-parameters.h old mode 100644 new mode 100755 index 7f3e169..b3aeaad --- a/dali-toolkit/internal/text/layouts/layout-parameters.h +++ b/dali-toolkit/internal/text/layouts/layout-parameters.h @@ -24,6 +24,7 @@ // INTERNAL INCLUDES #include #include +#include namespace Dali { @@ -48,77 +49,32 @@ struct Parameters * Constructor with the needed parameters to layout the text. * * @param[in] boundingBox The size of the box containing the text. - * @param[in] textBuffer The text buffer. - * @param[in] lineBreakInfoBuffer The line break info. - * @param[in] wordBreakInfoBuffer The word break info. - * @param[in] characterDirectionBuffer Vector with the direction of each character. - * @param[in] glyphsBuffer Vector with glyphs. - * @param[in] glyphsToCharactersBuffer Vector with indices pointing the first character of each glyph. - * @param[in] charactersPerGlyphBuffer Vector with the number of characters that forms each glyph. - * @param[in] charactersToGlyphsBuffer Vector with indices pointing the first glyph of each character. - * @param[in] glyphsPerCharacterBuffer Vector with the number of glyphs shaped from the character. - * @param[in] totalNumberOfGlyphs The number of glyphs. - * @param[in] horizontalAlignment The horizontal alignment. - * @param[in] lineWrapMode The text wrap mode. + * @param[in,out] textModel The text's model. */ Parameters( const Vector2& boundingBox, - const Character* const textBuffer, - const LineBreakInfo* const lineBreakInfoBuffer, - const WordBreakInfo* const wordBreakInfoBuffer, - const CharacterDirection* const characterDirectionBuffer, - const GlyphInfo* const glyphsBuffer, - const CharacterIndex* const glyphsToCharactersBuffer, - const Length* const charactersPerGlyphBuffer, - const GlyphIndex* const charactersToGlyphsBuffer, - const Length* const glyphsPerCharacterBuffer, - Length totalNumberOfGlyphs, - Text::HorizontalAlignment::Type horizontalAlignment, - Text::LineWrap::Mode lineWrapMode, - float outlineWidth ) - : boundingBox( boundingBox ), - textBuffer( textBuffer ), - lineBreakInfoBuffer( lineBreakInfoBuffer ), - wordBreakInfoBuffer( wordBreakInfoBuffer ), - characterDirectionBuffer( characterDirectionBuffer ), - glyphsBuffer( glyphsBuffer ), - glyphsToCharactersBuffer( glyphsToCharactersBuffer ), - charactersPerGlyphBuffer( charactersPerGlyphBuffer ), - charactersToGlyphsBuffer( charactersToGlyphsBuffer ), - glyphsPerCharacterBuffer( glyphsPerCharacterBuffer ), - lineBidirectionalInfoRunsBuffer( NULL ), - numberOfBidirectionalInfoRuns( 0u ), - startGlyphIndex( 0u ), - numberOfGlyphs( 0u ), - totalNumberOfGlyphs( totalNumberOfGlyphs ), - horizontalAlignment( horizontalAlignment ), - startLineIndex( 0u ), - estimatedNumberOfLines( 0u ), - lineWrapMode( lineWrapMode ), - isLastNewParagraph( false ), - outlineWidth( outlineWidth ) + ModelPtr textModel ) + : boundingBox{ boundingBox }, + textModel{ textModel }, + lineBidirectionalInfoRunsBuffer{ nullptr }, + numberOfBidirectionalInfoRuns{ 0u }, + startGlyphIndex{ 0u }, + numberOfGlyphs{ 0u }, + startLineIndex{ 0u }, + estimatedNumberOfLines{ 0u }, + interGlyphExtraAdvance{ 0.f }, + isLastNewParagraph{ false } {} Vector2 boundingBox; ///< The size of the box containing the text. - const Character* const textBuffer; ///< The text buffer. - const LineBreakInfo* const lineBreakInfoBuffer; ///< The line break info. - const WordBreakInfo* const wordBreakInfoBuffer; ///< The word break info. - const CharacterDirection* const characterDirectionBuffer; ///< Vector with the direction of each character. - const GlyphInfo* const glyphsBuffer; ///< Vector with glyphs. - const CharacterIndex* const glyphsToCharactersBuffer; ///< Vector with indices pointing the first character of each glyph. - const Length* const charactersPerGlyphBuffer; ///< Vector with the number of characters that forms each glyph. - const GlyphIndex* const charactersToGlyphsBuffer; ///< Vector with indices pointing the first glyph of each character. - const Length* const glyphsPerCharacterBuffer; ///< Vector with the number of glyphs shaped from the character. + ModelPtr textModel; BidirectionalLineInfoRun* lineBidirectionalInfoRunsBuffer; ///< Bidirectional conversion tables per line. Length numberOfBidirectionalInfoRuns; ///< The number of lines with bidirectional info. GlyphIndex startGlyphIndex; ///< Index to the first glyph to layout. Length numberOfGlyphs; ///< The number of glyphs to layout. - Length totalNumberOfGlyphs; ///< The number of glyphs. - HorizontalAlignment::Type horizontalAlignment; ///< The horizontal alignment. LineIndex startLineIndex; ///< The line index where to insert the new lines. Length estimatedNumberOfLines; ///< The estimated number of lines. - Text::LineWrap::Mode lineWrapMode; ///< The line wrap mode for moving to next line. - bool isLastNewParagraph; ///< Whether the last character is a new paragraph character. - float outlineWidth; ///< The outline width. + float interGlyphExtraAdvance; ///< Extra advance added to each glyph. + bool isLastNewParagraph:1; ///< Whether the last character is a new paragraph character. }; } // namespace Layout