summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2013-02-10 19:36:26 +0300
committerAndrei Karas <akaras@inbox.ru>2013-02-10 19:36:26 +0300
commit6781809c3ae40507d86573f06c296706eff60e9a (patch)
tree41df178b61963c54e283fff6c14ef8c6a68ee740
parentf6482585eb8d9fd514b38dd214d83acd3985dc76 (diff)
downloadmanaplus-6781809c3ae40507d86573f06c296706eff60e9a.tar.gz
manaplus-6781809c3ae40507d86573f06c296706eff60e9a.tar.bz2
manaplus-6781809c3ae40507d86573f06c296706eff60e9a.tar.xz
manaplus-6781809c3ae40507d86573f06c296706eff60e9a.zip
Add option to scrollbuttons.xml to show/hide scrollbar buttons.
New theme option: showbuttons - show or hide scrollbar buttons. Default is 1 (show).
-rw-r--r--data/themes/jewelry/scrollbuttons.xml1
-rw-r--r--src/gui/widgets/scrollarea.cpp27
2 files changed, 15 insertions, 13 deletions
diff --git a/data/themes/jewelry/scrollbuttons.xml b/data/themes/jewelry/scrollbuttons.xml
index 381f102ba..9ffd91348 100644
--- a/data/themes/jewelry/scrollbuttons.xml
+++ b/data/themes/jewelry/scrollbuttons.xml
@@ -1,6 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<skinset name="Default" image="window.png">
<widget type="Window" xpos="41" ypos="100">
+ <option name="showbuttons" value="0" />
<part type="left" xpos="0" ypos="0" width="12" height="12" />
<part type="right" xpos="0" ypos="16" width="12" height="12" />
<part type="down" xpos="0" ypos="32" width="12" height="12" />
diff --git a/src/gui/widgets/scrollarea.cpp b/src/gui/widgets/scrollarea.cpp
index cfc9a8938..4e3404aa8 100644
--- a/src/gui/widgets/scrollarea.cpp
+++ b/src/gui/widgets/scrollarea.cpp
@@ -167,7 +167,8 @@ void ScrollArea::init(std::string skinName)
rect.grid[f]->incRef();
buttons[f][i] = rect.grid[f];
}
- mShowButtons = (skin->getOption("showbuttons", 1) == 1);
+ if (i == 0)
+ mShowButtons = (skin->getOption("showbuttons", 1) == 1);
}
else
{
@@ -821,19 +822,19 @@ gcn::Rectangle ScrollArea::getVerticalBarDimension() const
if (!mVBarVisible)
return gcn::Rectangle(0, 0, 0, 0);
- const int height = mVBarVisible ? mScrollbarWidth : 0;
+ const int height = (mVBarVisible && mShowButtons) ? mScrollbarWidth : 0;
if (mHBarVisible)
{
return gcn::Rectangle(mDimension.width - mScrollbarWidth,
height,
mScrollbarWidth,
- mDimension.height - height - height - mScrollbarWidth);
+ mDimension.height - 2 * height - mScrollbarWidth);
}
return gcn::Rectangle(mDimension.width - mScrollbarWidth,
height,
mScrollbarWidth,
- mDimension.height - height - height);
+ mDimension.height - 2 * height);
}
gcn::Rectangle ScrollArea::getHorizontalBarDimension() const
@@ -841,18 +842,18 @@ gcn::Rectangle ScrollArea::getHorizontalBarDimension() const
if (!mHBarVisible)
return gcn::Rectangle(0, 0, 0, 0);
- const int width = mHBarVisible ? mScrollbarWidth : 0;
+ const int width = (mHBarVisible && mShowButtons) ? mScrollbarWidth : 0;
if (mVBarVisible)
{
return gcn::Rectangle(width,
mDimension.height - mScrollbarWidth,
- mDimension.width - width - width - mScrollbarWidth,
+ mDimension.width - 2 * width - mScrollbarWidth,
mScrollbarWidth);
}
return gcn::Rectangle(width,
mDimension.height - mScrollbarWidth,
- mDimension.width - width - width,
+ mDimension.width - 2 * width,
mScrollbarWidth);
}
@@ -863,7 +864,7 @@ gcn::Rectangle ScrollArea::getVerticalMarkerDimension()
int length, pos;
int height;
- const int h2 = mVBarVisible ? mScrollbarWidth : 0;
+ const int h2 = (mVBarVisible && mShowButtons) ? mScrollbarWidth : 0;
const gcn::Widget *content;
if (!mWidgets.empty())
content = *mWidgets.begin();
@@ -912,7 +913,7 @@ gcn::Rectangle ScrollArea::getHorizontalMarkerDimension()
int length, pos;
int width;
- const int w2 = mHBarVisible ? mScrollbarWidth : 0;
+ const int w2 = (mHBarVisible && mShowButtons) ? mScrollbarWidth : 0;
const gcn::Widget *content;
if (!mWidgets.empty())
content = *mWidgets.begin();
@@ -956,7 +957,7 @@ gcn::Rectangle ScrollArea::getHorizontalMarkerDimension()
gcn::Rectangle ScrollArea::getUpButtonDimension() const
{
- if (!mVBarVisible)
+ if (!mVBarVisible || !mShowButtons)
return gcn::Rectangle(0, 0, 0, 0);
return gcn::Rectangle(mDimension.width - mScrollbarWidth, 0,
@@ -965,7 +966,7 @@ gcn::Rectangle ScrollArea::getUpButtonDimension() const
gcn::Rectangle ScrollArea::getDownButtonDimension() const
{
- if (!mVBarVisible)
+ if (!mVBarVisible || !mShowButtons)
return gcn::Rectangle(0, 0, 0, 0);
if (mVBarVisible && mHBarVisible)
@@ -984,7 +985,7 @@ gcn::Rectangle ScrollArea::getDownButtonDimension() const
gcn::Rectangle ScrollArea::getLeftButtonDimension() const
{
- if (!mHBarVisible)
+ if (!mHBarVisible || !mShowButtons)
return gcn::Rectangle(0, 0, 0, 0);
return gcn::Rectangle(0, mDimension.height - mScrollbarWidth,
@@ -993,7 +994,7 @@ gcn::Rectangle ScrollArea::getLeftButtonDimension() const
gcn::Rectangle ScrollArea::getRightButtonDimension() const
{
- if (!mHBarVisible)
+ if (!mHBarVisible || !mShowButtons)
return gcn::Rectangle(0, 0, 0, 0);
if (mVBarVisible && mHBarVisible)