summaryrefslogtreecommitdiff
path: root/menuitem.c
diff options
context:
space:
mode:
authorlouis <louis.braun@gmx.de>2013-03-19 18:44:43 +0100
committerlouis <louis.braun@gmx.de>2013-03-19 18:44:43 +0100
commit37d74719f45317e6f9a7c59b2aee37587411ec72 (patch)
treea95bc9260f4f292b2009c6196124a02dc343cc6e /menuitem.c
parentbe69684051e0a9dd6d92b0396990aa80220ea040 (diff)
downloadskin-nopacity-37d74719f45317e6f9a7c59b2aee37587411ec72.tar.gz
skin-nopacity-37d74719f45317e6f9a7c59b2aee37587411ec72.tar.bz2
Improved display of non selectable header lines in default menus
Diffstat (limited to 'menuitem.c')
-rw-r--r--menuitem.c36
1 files changed, 33 insertions, 3 deletions
diff --git a/menuitem.c b/menuitem.c
index ce09535..311f88f 100644
--- a/menuitem.c
+++ b/menuitem.c
@@ -1137,6 +1137,30 @@ int cNopacityDefaultMenuItem::CheckScrollable(bool hasIcon) {
return 0;
}
+bool cNopacityDefaultMenuItem::DrawHeaderElement(void) {
+ const char *c = Text + 3;
+ while (*c == '-')
+ c++;
+ if (*c == ' ' || *c == '\t') {
+ // it's a headline
+ while (*c == ' ' || *c == '\t') // find start of headline text
+ c++;
+
+ // find end of headline text
+ char *c2 = (char*)(c + strlen(c) - 1);
+ while (*c2 == '-')
+ c2--;
+ while (*c2 == ' ' || *c2 == '\t')
+ c2--;
+ *(c2 + 1) = 0;
+
+ int left = 5 + tabWidth[0];
+ pixmap->DrawText(cPoint(left, (height - font->Height()) / 2), c, Theme.Color(clrMenuFontMenuItemSep), clrTransparent, font);
+ return true;
+ }
+ return false;
+}
+
void cNopacityDefaultMenuItem::Render() {
pixmap->Fill(Theme.Color(clrMenuBorder));
int handleBgrd = (current)?handleBackgrounds[1]:handleBackgrounds[0];
@@ -1144,6 +1168,10 @@ void cNopacityDefaultMenuItem::Render() {
pixmap->DrawImage(cPoint(1, 1), handleBgrd);
if (config.roundedCorners)
DrawRoundedCorners(Theme.Color(clrMenuBorder));
+ if (!selectable && (strncmp(Text, "---", 3) == 0)) {
+ if (DrawHeaderElement())
+ return;
+ }
int colWidth = 0;
int colTextWidth = 0;
cString itemText("");
@@ -1157,11 +1185,13 @@ void cNopacityDefaultMenuItem::Render() {
colTextWidth = font->Width(*itemTabs[i]);
if (colTextWidth > colWidth) {
cTextWrapper itemTextWrapped;
- itemTextWrapped.Set(*itemTabs[i], font, colWidth - font->Width("... "));
- if (selectable)
+ if (selectable) {
+ itemTextWrapped.Set(*itemTabs[i], font, colWidth - font->Width("... "));
itemText = cString::sprintf("%s... ", itemTextWrapped.GetLine(0));
- else
+ } else {
+ itemTextWrapped.Set(*itemTabs[i], font, colWidth);
itemText = cString::sprintf("%s", itemTextWrapped.GetLine(0));
+ }
} else {
itemText = itemTabs[i];
}