X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/567eaf951fd8192e72d9f85a896f19b97c8d6949..1ea67ee808e72ddeac7e6a01c42a015102664086:/lib/gdi/font.cpp diff --git a/lib/gdi/font.cpp b/lib/gdi/font.cpp index cc244941..1471aa5e 100644 --- a/lib/gdi/font.cpp +++ b/lib/gdi/font.cpp @@ -331,30 +331,39 @@ int eTextPara::appendGlyph(Font *current_font, FT_Face current_face, FT_UInt gly ng.bbox.setWidth( glyph->width ); ng.bbox.setHeight( glyph->height ); - xadvance+=kern; - - ng.x=cursor.x()+kern; - ng.y=cursor.y(); - ng.w=xadvance; - ng.font=current_font; - ng.glyph_index=glyphIndex; - ng.flags=flags; + xadvance += kern; + ng.bbox.setWidth(xadvance); + + ng.x = cursor.x()+kern; + ng.y = cursor.y(); + ng.w = xadvance; + ng.font = current_font; + ng.glyph_index = glyphIndex; + ng.flags = flags; glyphs.push_back(ng); - cursor+=ePoint(xadvance, 0); - previous=glyphIndex; + cursor += ePoint(xadvance, 0); + previous = glyphIndex; return 0; } void eTextPara::calc_bbox() { - boundBox.setLeft( 32000 ); - boundBox.setTop( 32000 ); - boundBox.setRight( -32000 ); // for each glyph image, compute its bounding box, translate it, - boundBox.setBottom( -32000 ); - // and grow the string bbox + if (!glyphs.size()) + { + bboxValid = 0; + boundBox = eRect(); + return; + } + + bboxValid = 1; + + glyphString::iterator i(glyphs.begin()); + + boundBox = i->bbox; + ++i; - for ( glyphString::iterator i(glyphs.begin()); i != glyphs.end(); ++i) + for (i ; i != glyphs.end(); ++i) { if ( i->flags & GS_ISSPACE ) continue; @@ -368,8 +377,6 @@ void eTextPara::calc_bbox() boundBox.setBottom( i->bbox.bottom() ); } // eDebug("boundBox left = %i, top = %i, right = %i, bottom = %i", boundBox.left(), boundBox.top(), boundBox.right(), boundBox.bottom() ); - if ( glyphs.size() ) - bboxValid=1; } void eTextPara::newLine(int flags)