summaryrefslogtreecommitdiff
path: root/src/gui/setup_video.cpp
diff options
context:
space:
mode:
authorBjørn Lindeijer <bjorn@lindeijer.nl>2009-01-18 23:29:48 +0100
committerIra Rice <irarice@gmail.com>2009-01-18 16:09:53 -0700
commit640b37b66712d22afd5c453f6aebc4abf7dcd442 (patch)
treea2c00b2ace9c8e146ef3433916da449d396e34b0 /src/gui/setup_video.cpp
parent7b38f31192be70463cfa1fa6f0ffe13181fc26a9 (diff)
downloadmana-640b37b66712d22afd5c453f6aebc4abf7dcd442.tar.gz
mana-640b37b66712d22afd5c453f6aebc4abf7dcd442.tar.bz2
mana-640b37b66712d22afd5c453f6aebc4abf7dcd442.tar.xz
mana-640b37b66712d22afd5c453f6aebc4abf7dcd442.zip
Fixed layout of video setup page when translated
Introduced a LayoutHelper class which can be used for any non-Window container where you want to use a layout to place child widgets.
Diffstat (limited to 'src/gui/setup_video.cpp')
-rw-r--r--src/gui/setup_video.cpp104
1 files changed, 43 insertions, 61 deletions
diff --git a/src/gui/setup_video.cpp b/src/gui/setup_video.cpp
index 78e26e5e..30441bb8 100644
--- a/src/gui/setup_video.cpp
+++ b/src/gui/setup_video.cpp
@@ -36,6 +36,8 @@
#include "slider.h"
#include "textfield.h"
+#include "widgets/layouthelper.h"
+
#include "../configuration.h"
#include "../graphics.h"
#include "../localplayer.h"
@@ -136,37 +138,28 @@ Setup_Video::Setup_Video():
mParticleDetailField(new gcn::Label(""))
{
setOpaque(false);
- setDimension(gcn::Rectangle(0, 0, 290, 255));
ScrollArea *scrollArea = new ScrollArea(mModeList);
+ scrollArea->setHorizontalScrollPolicy(gcn::ScrollArea::SHOW_NEVER);
+
gcn::Label *alphaLabel = new gcn::Label(_("Gui opacity"));
+ gcn::Label *scrollRadiusLabel = new gcn::Label(_("Scroll radius"));
+ gcn::Label *scrollLazinessLabel = new gcn::Label(_("Scroll laziness"));
+ gcn::Label *overlayDetailLabel = new gcn::Label(_("Ambient FX"));
+ gcn::Label *particleDetailLabel = new gcn::Label(_("Particle Detail"));
mModeList->setEnabled(true);
#ifndef USE_OPENGL
mOpenGLCheckBox->setEnabled(false);
#endif
- mModeList->setDimension(gcn::Rectangle(0, 0, 60, 70));
- scrollArea->setDimension(gcn::Rectangle(10, 10, 90, 70));
- mFsCheckBox->setPosition(110, 10);
- mNameCheckBox->setPosition(195, 10);
- mOpenGLCheckBox->setPosition(110, 30);
- mParticleEffectsCheckBox->setPosition(180, 30);
- mCustomCursorCheckBox->setPosition(110, 50);
- mSpeechBubbleCheckBox->setPosition(110, 70);
- mAlphaSlider->setDimension(gcn::Rectangle(10, 100, 75, 10));
- alphaLabel->setPosition(20 + mAlphaSlider->getWidth(),
- mAlphaSlider->getY());
- mFpsCheckBox->setPosition(90, 120);
- mFpsSlider->setDimension(gcn::Rectangle(10, 120, 75, 10));
- mFpsField->setPosition(100 + mFpsCheckBox->getWidth(), 100);
- mFpsField->setWidth(30);
-
mModeList->setSelected(-1);
mAlphaSlider->setValue(mOpacity);
+ mAlphaSlider->setWidth(90);
mFpsField->setText(toString(mFps));
mFpsField->setEnabled(mFps > 0);
+ mFpsField->setWidth(30);
mFpsSlider->setValue(mFps);
mFpsSlider->setEnabled(mFps > 0);
mFpsCheckBox->setSelected(mFps > 0);
@@ -206,27 +199,12 @@ Setup_Video::Setup_Video():
mParticleDetailSlider->addActionListener(this);
mParticleDetailField->addKeyListener(this);
- mScrollRadiusSlider->setDimension(gcn::Rectangle(10, 140, 75, 10));
- gcn::Label *scrollRadiusLabel = new gcn::Label(_("Scroll radius"));
- scrollRadiusLabel->setPosition(90, 140);
- mScrollRadiusField->setPosition(mFpsField->getX(), 140);
- mScrollRadiusField->setWidth(30);
mScrollRadiusField->setText(toString(mOriginalScrollRadius));
mScrollRadiusSlider->setValue(mOriginalScrollRadius);
- mScrollLazinessSlider->setDimension(gcn::Rectangle(10, 160, 75, 10));
- gcn::Label *scrollLazinessLabel = new gcn::Label(_("Scroll laziness"));
- scrollLazinessLabel->setPosition(90, 160);
- mScrollLazinessField->setPosition(mFpsField->getX(), 160);
- mScrollLazinessField->setWidth(30);
mScrollLazinessField->setText(toString(mOriginalScrollLaziness));
mScrollLazinessSlider->setValue(mOriginalScrollLaziness);
- mOverlayDetailSlider->setDimension(gcn::Rectangle(10, 180, 75, 10));
- gcn::Label *overlayDetailLabel = new gcn::Label(_("Ambient FX"));
- overlayDetailLabel->setPosition(90, 180);
- mOverlayDetailField->setPosition(180, 180);
- mOverlayDetailField->setWidth(30);
switch (mOverlayDetail)
{
case 0:
@@ -241,11 +219,6 @@ Setup_Video::Setup_Video():
}
mOverlayDetailSlider->setValue(mOverlayDetail);
- mParticleDetailSlider->setDimension(gcn::Rectangle(10, 200, 75, 10));
- gcn::Label *particleDetailLabel = new gcn::Label(_("Particle Detail"));
- particleDetailLabel->setPosition(90, 200);
- mParticleDetailField->setPosition(180, 200);
- mParticleDetailField->setWidth(60);
switch (mParticleDetail)
{
case 0:
@@ -263,30 +236,39 @@ Setup_Video::Setup_Video():
}
mParticleDetailSlider->setValue(mParticleDetail);
- add(scrollArea);
- add(mFsCheckBox);
- add(mOpenGLCheckBox);
- add(mCustomCursorCheckBox);
- add(mParticleEffectsCheckBox);
- add(mSpeechBubbleCheckBox);
- add(mNameCheckBox);
- add(mAlphaSlider);
- add(alphaLabel);
- add(mFpsCheckBox);
- add(mFpsSlider);
- add(mFpsField);
- add(mScrollRadiusSlider);
- add(scrollRadiusLabel);
- add(mScrollRadiusField);
- add(mScrollLazinessSlider);
- add(scrollLazinessLabel);
- add(mScrollLazinessField);
- add(mOverlayDetailSlider);
- add(overlayDetailLabel);
- add(mOverlayDetailField);
- add(mParticleDetailSlider);
- add(particleDetailLabel);
- add(mParticleDetailField);
+ // Do the layout
+ LayoutHelper h(this);
+ ContainerPlacer place = h.getPlacer(0, 0);
+
+ place(0, 0, scrollArea, 1, 5).setPadding(2);
+ place(1, 0, mFsCheckBox, 3);
+ place(2, 0, mNameCheckBox, 3);
+ place(1, 1, mOpenGLCheckBox, 3);
+ place(2, 1, mParticleEffectsCheckBox, 3);
+ place(1, 2, mCustomCursorCheckBox, 3);
+ place(1, 3, mSpeechBubbleCheckBox, 3);
+
+ place(0, 5, mAlphaSlider);
+ place(0, 6, mFpsSlider);
+ place(0, 7, mScrollRadiusSlider);
+ place(0, 8, mScrollLazinessSlider);
+ place(0, 9, mOverlayDetailSlider);
+ place(0, 10, mParticleDetailSlider);
+
+ place(1, 5, alphaLabel, 2);
+ place(1, 6, mFpsCheckBox).setPadding(3);
+ place(1, 7, scrollRadiusLabel);
+ place(1, 8, scrollLazinessLabel);
+ place(1, 9, overlayDetailLabel);
+ place(1, 10, particleDetailLabel);
+
+ place(2, 6, mFpsField).setPadding(1);
+ place(2, 7, mScrollRadiusField).setPadding(1);
+ place(2, 8, mScrollLazinessField).setPadding(1);
+ place(2, 9, mOverlayDetailField, 2).setPadding(2);
+ place(2, 10, mParticleDetailField, 2).setPadding(2);
+
+ setDimension(gcn::Rectangle(0, 0, 295, 255));
}
Setup_Video::~Setup_Video()