aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMax Horn2009-12-15 08:19:59 +0000
committerMax Horn2009-12-15 08:19:59 +0000
commit6c98169dc3ab302a6fa1feecc6b053b515174e7d (patch)
treedbedc98371c95b34f781ec7eda115764264d0bb7
parent605037342be6c8dc40bd9c1380fd93727f3d3de3 (diff)
downloadscummvm-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.cpp28
-rw-r--r--gui/ThemeEngine.cpp2
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) {