diff options
author | Max Horn | 2009-12-15 08:19:59 +0000 |
---|---|---|
committer | Max Horn | 2009-12-15 08:19:59 +0000 |
commit | 6c98169dc3ab302a6fa1feecc6b053b515174e7d (patch) | |
tree | dbedc98371c95b34f781ec7eda115764264d0bb7 | |
parent | 605037342be6c8dc40bd9c1380fd93727f3d3de3 (diff) | |
download | scummvm-rg350-6c98169dc3ab302a6fa1feecc6b053b515174e7d.tar.gz scummvm-rg350-6c98169dc3ab302a6fa1feecc6b053b515174e7d.tar.bz2 scummvm-rg350-6c98169dc3ab302a6fa1feecc6b053b515174e7d.zip |
GUI: Shorten button labels if too long, and improve the shortening logic
svn-id: r46381
-rw-r--r-- | graphics/font.cpp | 28 | ||||
-rw-r--r-- | gui/ThemeEngine.cpp | 2 |
2 files changed, 20 insertions, 10 deletions
diff --git a/graphics/font.cpp b/graphics/font.cpp index 4d322be081..ad478440a9 100644 --- a/graphics/font.cpp +++ b/graphics/font.cpp @@ -782,20 +782,31 @@ int Font::getStringWidth(const Common::String &str) const { return space; } -void Font::drawString(Surface *dst, const Common::String &s, int x, int y, int w, uint32 color, TextAlign align, int deltax, bool useEllipsis) const { +void Font::drawString(Surface *dst, const Common::String &sOld, int x, int y, int w, uint32 color, TextAlign align, int deltax, bool useEllipsis) const { assert(dst != 0); const int leftX = x, rightX = x + w; uint i; + Common::String s = sOld; int width = getStringWidth(s); Common::String str; + if (useEllipsis && width > w && s.hasSuffix("...")) { + // String is too wide. Check whether it ends in an ellipsis + // ("..."). If so, remove that and try again! + s.deleteLastChar(); + s.deleteLastChar(); + s.deleteLastChar(); + width = getStringWidth(s); + } + if (useEllipsis && width > w) { - // String is too wide. So we shorten it "intellegently", by replacing - // parts of it by an ellipsis ("..."). There are three possibilities - // for this: replace the start, the end, or the middle of the string. - // What is best really depends on the context; but unless we want to - // make this configurable, replacing the middle probably is a good - // compromise. + // String is too wide. So we shorten it "intelligently" by + // replacing parts of the string by an ellipsis. There are + // three possibilities for this: replace the start, the end, or + // the middle of the string. What is best really depends on the + // context; but unless we want to make this configurable, + // replacing the middle seems to be a good compromise. + const int ellipsisWidth = getStringWidth("..."); // SLOW algorithm to remove enough of the middle. But it is good enough @@ -816,7 +827,7 @@ void Font::drawString(Surface *dst, const Common::String &s, int x, int y, int w // The original string is width wide. Of those we already skipped past // w2 pixels, which means (width - w2) remain. - // The new str is (w2+ellipsisWidth) wide, so we can accomodate about + // The new str is (w2+ellipsisWidth) wide, so we can accommodate about // (w - (w2+ellipsisWidth)) more pixels. // Thus we skip ((width - w2) - (w - (w2+ellipsisWidth))) = // (width + ellipsisWidth - w) @@ -831,7 +842,6 @@ void Font::drawString(Surface *dst, const Common::String &s, int x, int y, int w } width = getStringWidth(str); - } else { str = s; } diff --git a/gui/ThemeEngine.cpp b/gui/ThemeEngine.cpp index 6d477fb4b3..a08e019668 100644 --- a/gui/ThemeEngine.cpp +++ b/gui/ThemeEngine.cpp @@ -850,7 +850,7 @@ void ThemeEngine::drawButton(const Common::Rect &r, const Common::String &str, W dd = kDDButtonDisabled; queueDD(dd, r, 0, hints & WIDGET_CLEARBG); - queueDDText(getTextData(dd), getTextColor(dd), r, str, false, false, _widgets[dd]->_textAlignH, _widgets[dd]->_textAlignV); + queueDDText(getTextData(dd), getTextColor(dd), r, str, false, true, _widgets[dd]->_textAlignH, _widgets[dd]->_textAlignV); } void ThemeEngine::drawLineSeparator(const Common::Rect &r, WidgetStateInfo state) { |