summaryrefslogtreecommitdiff
path: root/src/dialogues/ConfirmPrompt.cpp
diff options
context:
space:
mode:
authorSimon Robertshaw <simon@hardwired.org.uk>2012-06-20 18:39:33 (GMT)
committer Simon Robertshaw <simon@hardwired.org.uk>2012-06-20 18:39:33 (GMT)
commitad76b293d8fc257a7efe0cbcf6f7fb9380616030 (patch)
treed8b2bd9df0d2b5b9df7a529da44abcc3a76effdc /src/dialogues/ConfirmPrompt.cpp
parent0594aa5d07d7bf63885eee966d102e3e7354c925 (diff)
downloadpowder-ad76b293d8fc257a7efe0cbcf6f7fb9380616030.zip
powder-ad76b293d8fc257a7efe0cbcf6f7fb9380616030.tar.gz
Make Confirm dialogue less ugly
Diffstat (limited to 'src/dialogues/ConfirmPrompt.cpp')
-rw-r--r--src/dialogues/ConfirmPrompt.cpp24
1 files changed, 15 insertions, 9 deletions
diff --git a/src/dialogues/ConfirmPrompt.cpp b/src/dialogues/ConfirmPrompt.cpp
index a5f742d..6943555 100644
--- a/src/dialogues/ConfirmPrompt.cpp
+++ b/src/dialogues/ConfirmPrompt.cpp
@@ -6,24 +6,30 @@
*/
#include "ConfirmPrompt.h"
-#include "interface/Label.h"
+#include "interface/Textblock.h"
#include "interface/Button.h"
ConfirmPrompt::ConfirmPrompt(std::string title, std::string message, ConfirmDialogueCallback * callback_):
- ui::Window(ui::Point(-1, -1), ui::Point(200, 75)),
+ ui::Window(ui::Point(-1, -1), ui::Point(200, 50)),
callback(callback_)
{
- ui::Label * titleLabel = new ui::Label(ui::Point(2, 1), ui::Point(Size.X-4, 16), title);
+ int width, height;
+ ui::Label * titleLabel = new ui::Label(ui::Point(4, 5), ui::Point(Size.X-8, 15), title);
titleLabel->SetTextColour(ui::Colour(220, 220, 50));
titleLabel->Appearance.HorizontalAlign = ui::Appearance::AlignLeft;
- titleLabel->Appearance.VerticalAlign = ui::Appearance::AlignBottom;
+ titleLabel->Appearance.VerticalAlign = ui::Appearance::AlignMiddle;
AddComponent(titleLabel);
- ui::Label * messageLabel = new ui::Label(ui::Point(4, 18), ui::Point(Size.X-8, 60), message);
+
+ ui::Textblock * messageLabel = new ui::Textblock(ui::Point(4, 25), ui::Point(Size.X-8, 60), message);
+ Graphics::textsize(messageLabel->GetDisplayText().c_str(), width, height);
messageLabel->Appearance.HorizontalAlign = ui::Appearance::AlignLeft;
messageLabel->Appearance.VerticalAlign = ui::Appearance::AlignTop;
AddComponent(messageLabel);
+ Size.Y += height;
+ Position.Y = (ui::Engine::Ref().GetHeight()-Size.Y)/2;
+
class CloseAction: public ui::ButtonAction
{
public:
@@ -34,21 +40,21 @@ ConfirmPrompt::ConfirmPrompt(std::string title, std::string message, ConfirmDial
{
ui::Engine::Ref().CloseWindow();
prompt->callback->ConfirmCallback(result);
- prompt->SelfDestruct(); //TODO: Fix component disposal
+ prompt->SelfDestruct();
}
};
ui::Button * cancelButton = new ui::Button(ui::Point(0, Size.Y-16), ui::Point(Size.X-50, 16), "Cancel");
cancelButton->Appearance.HorizontalAlign = ui::Appearance::AlignLeft;
- cancelButton->Appearance.VerticalAlign = ui::Appearance::AlignBottom;
+ cancelButton->Appearance.VerticalAlign = ui::Appearance::AlignMiddle;
cancelButton->Appearance.BorderInactive = ui::Colour(200, 200, 200);
cancelButton->SetActionCallback(new CloseAction(this, ResultCancel));
AddComponent(cancelButton);
- ui::Button * okayButton = new ui::Button(ui::Point(Size.X-50, Size.Y-16), ui::Point(50, 16), "Continue");
+ ui::Button * okayButton = new ui::Button(ui::Point(Size.X-76, Size.Y-16), ui::Point(76, 16), "Continue");
okayButton->Appearance.HorizontalAlign = ui::Appearance::AlignLeft;
- okayButton->Appearance.VerticalAlign = ui::Appearance::AlignBottom;
+ okayButton->Appearance.VerticalAlign = ui::Appearance::AlignMiddle;
okayButton->Appearance.TextInactive = ui::Colour(220, 220, 50);
okayButton->SetActionCallback(new CloseAction(this, ResultOkay));
AddComponent(okayButton);