From 06ace6f3b67757e09dde16da0f28c0169ed6bc0e Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Sun, 10 May 2015 16:16:40 +0300 Subject: Improve performance in button drawing. --- src/gui/widgets/button.cpp | 23 +++++++++++++++-------- src/gui/widgets/button.h | 2 +- 2 files changed, 16 insertions(+), 9 deletions(-) (limited to 'src') diff --git a/src/gui/widgets/button.cpp b/src/gui/widgets/button.cpp index 6fe3e9bc2..3d05584d9 100644 --- a/src/gui/widgets/button.cpp +++ b/src/gui/widgets/button.cpp @@ -119,7 +119,7 @@ Button::Button(const Widget2 *const widget) : mImageSet(nullptr), mAlignment(Graphics::CENTER), mClickCount(0), - mSpacing(4), + mSpacing(), mTag(0), mMode(0), mXOffset(0), @@ -160,7 +160,7 @@ Button::Button(const Widget2 *const widget, mImageSet(nullptr), mAlignment(Graphics::CENTER), mClickCount(0), - mSpacing(4), + mSpacing(), mTag(0), mMode(0), mXOffset(0), @@ -207,7 +207,7 @@ Button::Button(const Widget2 *const widget, mImageSet(nullptr), mAlignment(Graphics::CENTER), mClickCount(0), - mSpacing(4), + mSpacing(), mTag(0), mMode(0), mXOffset(0), @@ -254,7 +254,7 @@ Button::Button(const Widget2 *const widget, mImageSet(nullptr), mAlignment(Graphics::CENTER), mClickCount(0), - mSpacing(4), + mSpacing(), mTag(0), mMode(0), mXOffset(0), @@ -301,7 +301,7 @@ Button::Button(const Widget2 *const widget, mImageSet(nullptr), mAlignment(Graphics::CENTER), mClickCount(0), - mSpacing(4), + mSpacing(), mTag(0), mMode(0), mXOffset(0), @@ -339,7 +339,14 @@ void Button::init() if (theme) { for (int mode = 0; mode < BUTTON_COUNT; mode ++) - button[mode] = theme->load(data[mode], "button.xml"); + { + Skin *const skin = theme->load(data[mode], "button.xml"); + if (skin) + { + button[mode] = skin; + mSpacing[mode] = skin->getOption("spacing"); + } + } } updateAlpha(); @@ -487,7 +494,7 @@ void Button::draw(Graphics *graphics) } const int padding = skin->getPadding(); - const int spacing = skin->getOption("spacing"); + const int spacing = mSpacing[mode]; switch (mode) { @@ -653,7 +660,7 @@ void Button::adjustSize() if (mImages) { - const int spacing = skin->getOption("spacing"); + const int spacing = mSpacing[BUTTON_STANDARD]; const int width = font->getWidth(mCaption); if (width) setWidth(width + mImageWidth + spacing + 2 * padding); diff --git a/src/gui/widgets/button.h b/src/gui/widgets/button.h index 9c9dce3cc..e568f8131 100644 --- a/src/gui/widgets/button.h +++ b/src/gui/widgets/button.h @@ -295,7 +295,7 @@ class Button final : public Widget, /** * Holds the spacing between the border and the caption. */ - unsigned int mSpacing; + int mSpacing[BUTTON_COUNT]; int mTag; int mMode; -- cgit v1.2.3-70-g09d2