diff options
author | Guillaume Melquiond <guillaume.melquiond@gmail.com> | 2007-10-20 11:29:18 +0000 |
---|---|---|
committer | Guillaume Melquiond <guillaume.melquiond@gmail.com> | 2007-10-20 11:29:18 +0000 |
commit | 59472ef68fdef3f7e8858a81a46e28c127119c58 (patch) | |
tree | 75b5f5e658fa1b05487463f0449440524ed76256 /src/gui/window.cpp | |
parent | 41cf359468d6379bc0e033bee9ac148d1b9255dd (diff) | |
download | mana-59472ef68fdef3f7e8858a81a46e28c127119c58.tar.gz mana-59472ef68fdef3f7e8858a81a46e28c127119c58.tar.bz2 mana-59472ef68fdef3f7e8858a81a46e28c127119c58.tar.xz mana-59472ef68fdef3f7e8858a81a46e28c127119c58.zip |
Added a layout handler for automatically positioning widgets in a window. Fixed layout of login dialog box when native language is not English.
Diffstat (limited to 'src/gui/window.cpp')
-rw-r--r-- | src/gui/window.cpp | 65 |
1 files changed, 39 insertions, 26 deletions
diff --git a/src/gui/window.cpp b/src/gui/window.cpp index 17447009..b5ac79b5 100644 --- a/src/gui/window.cpp +++ b/src/gui/window.cpp @@ -30,6 +30,7 @@ #include "gccontainer.h" #include "windowcontainer.h" +#include "widgets/layout.h" #include "widgets/resizegrip.h" #include "../configlistener.h" @@ -61,6 +62,7 @@ Window::Window(const std::string& caption, bool modal, Window *parent): gcn::Window(caption), mGrip(0), mParent(parent), + mLayout(NULL), mModal(modal), mResizable(false), mCloseButton(false), @@ -105,11 +107,6 @@ Window::Window(const std::string& caption, bool modal, Window *parent): setPadding(3); setTitleBarHeight(20); - // Add chrome - mChrome = new GCContainer(); - mChrome->setOpaque(false); - gcn::Window::add(mChrome); - // Add this window to the window container windowContainer->add(this); @@ -141,6 +138,15 @@ Window::~Window() } } + delete mLayout; + + while (!mWidgets.empty()) + { + gcn::Widget *w = mWidgets.front(); + remove(w); + delete(w); + } + instances--; if (instances == 0) @@ -161,9 +167,6 @@ Window::~Window() delete border.grid[8]; closeImage->decRef(); } - - delete mChrome; - delete mGrip; } void Window::setWindowContainer(WindowContainer *wc) @@ -198,13 +201,11 @@ void Window::draw(gcn::Graphics *graphics) void Window::setContentWidth(int width) { - mChrome->setWidth(width); setWidth(width + 2 * getPadding()); } void Window::setContentHeight(int height) { - mChrome->setHeight(height); setHeight(height + getPadding() + getTitleBarHeight()); } @@ -304,6 +305,7 @@ void Window::setMaxHeight(unsigned int height) void Window::setResizable(bool r) { + if (mResizable == r) return; mResizable = r; if (mResizable) @@ -311,10 +313,11 @@ void Window::setResizable(bool r) mGrip = new ResizeGrip(); mGrip->setX(getWidth() - mGrip->getWidth() - getChildrenArea().x); mGrip->setY(getHeight() - mGrip->getHeight() - getChildrenArea().y); - gcn::Window::add(mGrip); + add(mGrip); } else { + remove(mGrip); delete mGrip; mGrip = 0; } @@ -357,16 +360,6 @@ void Window::scheduleDelete() windowContainer->scheduleDelete(this); } -void Window::add(gcn::Widget *w, bool delChild) -{ - mChrome->add(w, delChild); -} - -void Window::add(gcn::Widget *w, int x, int y, bool delChild) -{ - mChrome->add(w, x, y, delChild); -} - void Window::mousePressed(gcn::MouseEvent &event) { // Let Guichan move window to top and figure out title bar drag @@ -519,8 +512,6 @@ void Window::mouseDragged(gcn::MouseEvent &event) // Set the new window and content dimensions setDimension(newDim); - const gcn::Rectangle area = getChildrenArea(); - mChrome->setSize(area.width, area.height); updateContentSize(); } } @@ -536,9 +527,6 @@ void Window::loadWindowState(std::string const &name) { setSize((int) config.getValue(name + "WinWidth", getWidth()), (int) config.getValue(name + "WinHeight", getHeight())); - - const gcn::Rectangle area = getChildrenArea(); - mChrome->setSize(area.width, area.height); } } @@ -607,3 +595,28 @@ void Window::fireWindowEvent(const WindowEvent &event) break; } } + +Layout &Window::getLayout() +{ + if (!mLayout) mLayout = new Layout; + return *mLayout; +} + +void Window::forgetLayout() +{ + delete mLayout; + mLayout = 0; +} + +Cell &Window::place(int x, int y, gcn::Widget *wg, int w, int h) +{ + add(wg); + return getLayout().place(wg, x, y, w, h); +} + +void Window::reflowLayout() +{ + if (!mLayout) return; + mLayout->reflow(); + resizeToContent(); +} |