summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorBjørn Lindeijer <bjorn@lindeijer.nl>2005-05-19 11:43:41 +0000
committerBjørn Lindeijer <bjorn@lindeijer.nl>2005-05-19 11:43:41 +0000
commitd42e9ea834a07c6f60dd5248db6520d1ff423ac4 (patch)
tree7de19d851aecae83bc8467d70c9a718ebff98205 /src/gui
parent32ca8ca9551070ba1086cd5b6c973620052061ed (diff)
downloadmana-d42e9ea834a07c6f60dd5248db6520d1ff423ac4.tar.gz
mana-d42e9ea834a07c6f60dd5248db6520d1ff423ac4.tar.bz2
mana-d42e9ea834a07c6f60dd5248db6520d1ff423ac4.tar.xz
mana-d42e9ea834a07c6f60dd5248db6520d1ff423ac4.zip
Made item amount window a modal dialog and removed support for old map format.
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/inventory.cpp64
-rw-r--r--src/gui/inventory.h5
-rw-r--r--src/gui/item_amount.cpp71
-rw-r--r--src/gui/item_amount.h15
-rw-r--r--src/gui/newskill.cpp8
-rw-r--r--src/gui/ok_dialog.cpp6
-rw-r--r--src/gui/requesttrade.cpp4
-rw-r--r--src/gui/trade.cpp83
-rw-r--r--src/gui/trade.h24
-rw-r--r--src/gui/window.cpp7
-rw-r--r--src/gui/window.h17
11 files changed, 143 insertions, 161 deletions
diff --git a/src/gui/inventory.cpp b/src/gui/inventory.cpp
index bb8b7bf5..4a1c0ca3 100644
--- a/src/gui/inventory.cpp
+++ b/src/gui/inventory.cpp
@@ -41,8 +41,6 @@ InventoryWindow::InventoryWindow():
dropButton = new Button("Drop");
items = new ItemContainer();
- items->setPosition(2, 2);
-
invenScroll = new ScrollArea(items);
invenScroll->setPosition(8, 8);
@@ -54,7 +52,6 @@ InventoryWindow::InventoryWindow():
itemNameLabel = new gcn::Label("Name:");
itemDescriptionLabel = new gcn::Label("Description:");
-
add(useButton);
add(dropButton);
add(invenScroll);
@@ -67,47 +64,46 @@ InventoryWindow::InventoryWindow():
updateWidgets();
useButton->setSize(48, useButton->getHeight());
-
}
InventoryWindow::~InventoryWindow()
{
delete useButton;
delete dropButton;
+ delete invenScroll;
+ delete items;
delete itemNameLabel;
delete itemDescriptionLabel;
}
-void InventoryWindow::draw(gcn::Graphics *graphics)
+int InventoryWindow::addItem(int index, int id, int quantity, bool equipment)
{
- // Draw window graphics
- Window::draw(graphics);
-}
-
-
-int InventoryWindow::addItem(int index, int id, int quantity, bool equipment) {
items->addItem(index, id, quantity, equipment);
return 0;
}
-int InventoryWindow::removeItem(int id) {
+int InventoryWindow::removeItem(int id)
+{
items->removeItem(id);
return 0;
}
-int InventoryWindow::changeQuantity(int index, int quantity) {
+int InventoryWindow::changeQuantity(int index, int quantity)
+{
//items[index].quantity = quantity;
items->changeQuantity(index, quantity);
return 0;
}
-int InventoryWindow::increaseQuantity(int index, int quantity) {
+int InventoryWindow::increaseQuantity(int index, int quantity)
+{
//items[index].quantity += quantity;
items->increaseQuantity(index, quantity);
return 0;
}
-int InventoryWindow::useItem(int index, int id) {
+int InventoryWindow::useItem(int index, int id)
+{
WFIFOW(0) = net_w_value(0x00a7);
WFIFOW(2) = net_w_value(index);
WFIFOL(4) = net_l_value(id);
@@ -117,7 +113,8 @@ int InventoryWindow::useItem(int index, int id) {
return 0;
}
-int InventoryWindow::dropItem(int index, int quantity) {
+int InventoryWindow::dropItem(int index, int quantity)
+{
// TODO: Fix wrong coordinates of drops, serverside?
WFIFOW(0) = net_w_value(0x00a2);
WFIFOW(2) = net_w_value(index);
@@ -127,7 +124,8 @@ int InventoryWindow::dropItem(int index, int quantity) {
return 0;
}
-void InventoryWindow::equipItem(int index) {
+void InventoryWindow::equipItem(int index)
+{
WFIFOW(0) = net_w_value(0x00a9);
WFIFOW(2) = net_w_value(index);
WFIFOW(4) = net_w_value(0);
@@ -135,7 +133,8 @@ void InventoryWindow::equipItem(int index) {
while ((out_size > 0)) flush();
}
-void InventoryWindow::unequipItem(int index) {
+void InventoryWindow::unequipItem(int index)
+{
WFIFOW(0) = net_w_value(0x00ab);
WFIFOW(2) = net_w_value(index);
WFIFOSET(4);
@@ -144,25 +143,26 @@ void InventoryWindow::unequipItem(int index) {
void InventoryWindow::action(const std::string &eventId)
{
- //if(selectedItem >= 0 && selectedItem <= INVENTORY_SIZE) {
- if (items->getIndex() != -1) {
+ int selectedItem = items->getIndex();
+
+ if (selectedItem != -1) {
if (eventId == "use") {
- if(items->isEquipment(items->getIndex())) {
- if(items->isEquipped(items->getIndex())) {
- unequipItem(items->getIndex());
+ if(items->isEquipment(selectedItem)) {
+ if(items->isEquipped(selectedItem)) {
+ unequipItem(selectedItem);
}
else {
- equipItem(items->getIndex());
+ equipItem(selectedItem);
}
}
else {
- useItem(items->getIndex(), items->getId());
- }
+ useItem(selectedItem, items->getId());
+ }
}
- else if (eventId == "drop") {
- itemAmountWindow->setUsage(AMOUNT_ITEM_DROP);
- itemAmountWindow->setVisible(true);
- itemAmountWindow->requestMoveToTop();
+ else if (eventId == "drop")
+ {
+ // Choose amount of items to drop
+ new ItemAmountWindow(AMOUNT_ITEM_DROP, this);
}
updateUseButton();
@@ -172,7 +172,7 @@ void InventoryWindow::action(const std::string &eventId)
void InventoryWindow::mouseClick(int x, int y, int button, int count)
{
Window::mouseClick(x, y, button, count);
-
+
updateUseButton();
if (items->getIndex() != -1)
@@ -227,6 +227,6 @@ void InventoryWindow::updateUseButton()
else {
useButton ->setCaption("Use");
}
-
+
useButton->setEnabled(items->getIndex() != -1);
}
diff --git a/src/gui/inventory.h b/src/gui/inventory.h
index 177b5662..43a23ede 100644
--- a/src/gui/inventory.h
+++ b/src/gui/inventory.h
@@ -50,11 +50,6 @@ class InventoryWindow : public Window, gcn::ActionListener {
~InventoryWindow();
/**
- * Draws the inventory window.
- */
- void draw(gcn::Graphics *graphics);
-
- /**
* Add an item the inventory.
*/
int addItem(int index, int id, int quantity, bool equipment);
diff --git a/src/gui/item_amount.cpp b/src/gui/item_amount.cpp
index 8cd51b10..a2aabfb4 100644
--- a/src/gui/item_amount.cpp
+++ b/src/gui/item_amount.cpp
@@ -26,8 +26,8 @@
#include "../engine.h"
#include "../main.h"
-ItemAmountWindow::ItemAmountWindow():
- Window("Select amount of items to drop.")
+ItemAmountWindow::ItemAmountWindow(int usage, Window *parent):
+ Window("Select amount of items to drop.", true, parent)
{
// New labels
itemAmountLabel = new gcn::Label("1");
@@ -37,20 +37,20 @@ ItemAmountWindow::ItemAmountWindow():
itemAmountPlusButton = new Button("+");
itemAmountOkButton = new Button("Okay");
itemAmountCancelButton = new Button("Cancel");
-
+
// Set button events Id
itemAmountMinusButton->setEventId("Minus");
itemAmountPlusButton->setEventId("Plus");
itemAmountOkButton->setEventId("Drop");
itemAmountCancelButton->setEventId("Cancel");
-
+
// Set position
itemAmountLabel->setPosition(35, 10);
itemAmountPlusButton->setPosition(60, 5);
itemAmountMinusButton->setPosition(10, 5);
itemAmountOkButton->setPosition(10, 40);
itemAmountCancelButton->setPosition(60, 40);
-
+
// Assemble
add(itemAmountLabel);
add(itemAmountPlusButton);
@@ -62,28 +62,9 @@ ItemAmountWindow::ItemAmountWindow():
itemAmountMinusButton->addActionListener(this);
itemAmountOkButton->addActionListener(this);
itemAmountCancelButton->addActionListener(this);
-
- resetAmount();
-
- setContentSize(200, 80);
- setLocationRelativeTo(getParent());
-}
-ItemAmountWindow::~ItemAmountWindow() {
- delete itemAmountLabel;
- delete itemAmountPlusButton;
- delete itemAmountMinusButton;
- delete itemAmountOkButton;
- delete itemAmountCancelButton;
-}
-
-void ItemAmountWindow::resetAmount() {
- amount = 1;
- itemAmountLabel->setCaption("1");
-}
-
-void ItemAmountWindow::setUsage(int usage) {
resetAmount();
+
switch (usage) {
case AMOUNT_TRADE_ADD:
setCaption("Select amount of items to trade.");
@@ -94,28 +75,45 @@ void ItemAmountWindow::setUsage(int usage) {
itemAmountOkButton->setEventId("Drop");
break;
default:
-
break;
}
+
+ setContentSize(200, 80);
+ setLocationRelativeTo(getParentWindow());
+}
+
+ItemAmountWindow::~ItemAmountWindow()
+{
+ delete itemAmountLabel;
+ delete itemAmountPlusButton;
+ delete itemAmountMinusButton;
+ delete itemAmountOkButton;
+ delete itemAmountCancelButton;
+}
+
+void ItemAmountWindow::resetAmount()
+{
+ amount = 1;
+ itemAmountLabel->setCaption("1");
}
void ItemAmountWindow::action(const std::string& eventId)
{
if (eventId == "Cancel")
{
- resetAmount();
- setVisible(false);
- } else if (eventId == "Drop")
+ scheduleDelete();
+ }
+ else if (eventId == "Drop")
{
inventoryWindow->dropItem(inventoryWindow->items->getIndex(), amount);
- resetAmount();
- setVisible(false);
- } else if (eventId == "AddTrade")
+ scheduleDelete();
+ }
+ else if (eventId == "AddTrade")
{
tradeWindow->tradeItem(inventoryWindow->items->getIndex(), amount);
- resetAmount();
- setVisible(false);
- } else if (eventId == "Plus")
+ scheduleDelete();
+ }
+ else if (eventId == "Plus")
{
if (amount < inventoryWindow->items->getQuantity())
{
@@ -125,7 +123,8 @@ void ItemAmountWindow::action(const std::string& eventId)
itemAmountLabel->setCaption(tmpplus);
itemAmountLabel->adjustSize();
}
- } else if (eventId == "Minus")
+ }
+ else if (eventId == "Minus")
{
if (amount > 1)
{
diff --git a/src/gui/item_amount.h b/src/gui/item_amount.h
index 4b889b86..d01f2006 100644
--- a/src/gui/item_amount.h
+++ b/src/gui/item_amount.h
@@ -42,7 +42,7 @@ class ItemAmountWindow : public Window, public gcn::ActionListener
/**
* Constructor.
*/
- ItemAmountWindow();
+ ItemAmountWindow(int usage, Window *parent);
/**
* Destructor.
@@ -55,11 +55,6 @@ class ItemAmountWindow : public Window, public gcn::ActionListener
void action(const std::string& eventId);
/**
- * Has to be called before setVisible(true).
- */
- void ItemAmountWindow::setUsage(int usage);
-
- /**
* Sets default amount value.
*/
void resetAmount();
@@ -68,13 +63,13 @@ class ItemAmountWindow : public Window, public gcn::ActionListener
int amount; /**< Amount of items to be dropped. */
gcn::Label *itemAmountLabel; /**< Item amount caption. */
- /**
+ /**
* Item Amount buttons.
*/
gcn::Button *itemAmountPlusButton;
- gcn::Button *itemAmountMinusButton;
- gcn::Button *itemAmountOkButton;
- gcn::Button *itemAmountCancelButton;
+ gcn::Button *itemAmountMinusButton;
+ gcn::Button *itemAmountOkButton;
+ gcn::Button *itemAmountCancelButton;
};
#endif /* _TMW_ITEM_AMOUNT_WINDOW_H */
diff --git a/src/gui/newskill.cpp b/src/gui/newskill.cpp
index b826d753..5849e020 100644
--- a/src/gui/newskill.cpp
+++ b/src/gui/newskill.cpp
@@ -70,7 +70,7 @@ char *skill_name[] = {
NewSkillDialog::NewSkillDialog():
Window("Skills")
{
- startPoint = 0;
+ startPoint = 0;
for ( int i = 0; i < N_SKILL_CAT_SIZE; i++)
{
skillLabel[i] = new gcn::Label("Empty ");
@@ -88,7 +88,7 @@ NewSkillDialog::NewSkillDialog():
playerSkill[i].exp = 0;
}
resetNSD();
-
+
// create controls
catButton[0] = new Button("Weapons");
catButton[1] = new Button("Magic");
@@ -102,7 +102,7 @@ NewSkillDialog::NewSkillDialog():
closeButton = new Button("Close");
// captions
-
+
// events
catButton[0]->setEventId("g1");
catButton[1]->setEventId("g2");
@@ -169,7 +169,7 @@ NewSkillDialog::NewSkillDialog():
NewSkillDialog::~NewSkillDialog()
{
for (int i = 0; i < N_SKILL_CAT_SIZE; i++)
- {
+ {
delete skillbar[i];
delete skillLabel[i];
delete skillLevel[i];
diff --git a/src/gui/ok_dialog.cpp b/src/gui/ok_dialog.cpp
index e7ff1449..8b7ef6d4 100644
--- a/src/gui/ok_dialog.cpp
+++ b/src/gui/ok_dialog.cpp
@@ -56,15 +56,15 @@ void OkDialog::init(const std::string &msg, gcn::ActionListener *listener)
(w - okButton->getWidth()) / 2,
h - 5 - okButton->getHeight());
- okButton->setEventId("ok");
+ okButton->setEventId("ok");
okButton->addActionListener(this);
if (listener) {
okButton->addActionListener(listener);
}
-
+
add(userLabel);
add(okButton);
-
+
setLocationRelativeTo(getParent());
okButton->requestFocus();
}
diff --git a/src/gui/requesttrade.cpp b/src/gui/requesttrade.cpp
index 431f6922..9cbdf7b2 100644
--- a/src/gui/requesttrade.cpp
+++ b/src/gui/requesttrade.cpp
@@ -35,7 +35,7 @@ RequestTradeDialog::RequestTradeDialog():
cancelButton = new Button("Cancel");
setContentSize(260, 75);
-
+
nameLabel[0]->setPosition(5, 30);
nameLabel[1]->setPosition(5, 40);
cancelButton->setPosition(
@@ -44,7 +44,7 @@ RequestTradeDialog::RequestTradeDialog():
acceptButton->setPosition(
cancelButton->getX() - 5 - acceptButton->getWidth(),
cancelButton->getY());
-
+
acceptButton->setEventId("accept");
cancelButton->setEventId("cancel");
diff --git a/src/gui/trade.cpp b/src/gui/trade.cpp
index ee947e4f..bcc5f8ce 100644
--- a/src/gui/trade.cpp
+++ b/src/gui/trade.cpp
@@ -37,39 +37,39 @@ TradeWindow::TradeWindow():
Window("Trade: You")
{
setContentSize(322, 150);
-
+
addButton = new Button("Add");
okButton = new Button("Ok");
cancelButton = new Button("Cancel");
tradeButton = new Button("Trade");
-
+
myItems = new ItemContainer();
myItems->setPosition(2, 2);
-
+
myScroll = new ScrollArea(myItems);
myScroll->setPosition(8, 8);
-
+
partnerItems = new ItemContainer();
partnerItems->setPosition(2, 58);
partnerScroll = new ScrollArea(partnerItems);
partnerScroll->setPosition(8, 64);
-
+
addButton->setEventId("add");
okButton->setEventId("ok");
cancelButton->setEventId("cancel");
tradeButton->setEventId("trade");
-
+
addButton->addActionListener(this);
okButton->addActionListener(this);
cancelButton->addActionListener(this);
tradeButton->addActionListener(this);
tradeButton->setEnabled(false);
-
+
itemNameLabel = new gcn::Label("Name:");
itemDescriptionLabel = new gcn::Label("Description:");
-
+
add(myScroll);
add(partnerScroll);
add(addButton);
@@ -78,12 +78,12 @@ TradeWindow::TradeWindow():
add(tradeButton);
add(itemNameLabel);
add(itemDescriptionLabel);
-
+
addButton->setPosition(8, getHeight() - 24);
okButton->setPosition(48 + 16, getHeight() - 24);
tradeButton->setPosition(getWidth() - 92, getHeight() - 24);
cancelButton->setPosition(getWidth() - 52, getHeight() - 24);
-
+
myItems->setSize(getWidth() - 24 - 12 - 1,
(INVENTORY_SIZE * 24) / (getWidth() / 24) - 1);
myScroll->setSize(getWidth() - 16, (getHeight() - 76) / 2);
@@ -91,7 +91,7 @@ TradeWindow::TradeWindow():
partnerItems->setSize(getWidth() - 24 - 12 - 1,
(INVENTORY_SIZE * 24) / (getWidth() / 24) - 1);
partnerScroll->setSize(getWidth() - 16, (getHeight() - 76) / 2);
-
+
itemNameLabel->setPosition(8,
partnerScroll->getY() + partnerScroll->getHeight() + 4);
itemDescriptionLabel->setPosition(8,
@@ -106,19 +106,17 @@ TradeWindow::~TradeWindow()
delete okButton;
delete cancelButton;
delete tradeButton;
+ delete myItems;
+ delete myScroll;
+ delete partnerItems;
+ delete partnerScroll;
delete itemNameLabel;
delete itemDescriptionLabel;
}
-void TradeWindow::draw(gcn::Graphics *graphics)
-{
- // Draw window graphics
- Window::draw(graphics);
-}
-
-
void TradeWindow::addItem(int index, int id, bool own, int quantity,
- bool equipment) {
+ bool equipment)
+{
if (own) {
myItems->addItem(index, id, quantity, equipment);
} else {
@@ -126,7 +124,8 @@ void TradeWindow::addItem(int index, int id, bool own, int quantity,
}
}
-void TradeWindow::removeItem(int id, bool own) {
+void TradeWindow::removeItem(int id, bool own)
+{
if (own) {
myItems->removeItem(id);
} else {
@@ -134,7 +133,8 @@ void TradeWindow::removeItem(int id, bool own) {
}
}
-void TradeWindow::changeQuantity(int index, bool own, int quantity) {
+void TradeWindow::changeQuantity(int index, bool own, int quantity)
+{
if (own) {
myItems->changeQuantity(index, quantity);
} else {
@@ -142,7 +142,8 @@ void TradeWindow::changeQuantity(int index, bool own, int quantity) {
}
}
-void TradeWindow::increaseQuantity(int index, bool own, int quantity) {
+void TradeWindow::increaseQuantity(int index, bool own, int quantity)
+{
if (own) {
myItems->increaseQuantity(index, quantity);
} else {
@@ -150,7 +151,8 @@ void TradeWindow::increaseQuantity(int index, bool own, int quantity) {
}
}
-void TradeWindow::reset() {
+void TradeWindow::reset()
+{
myItems->resetItems();
partnerItems->resetItems();
tradeButton->setEnabled(false);
@@ -159,11 +161,13 @@ void TradeWindow::reset() {
ok_me = false;
}
-void TradeWindow::setTradeButton(bool enabled) {
+void TradeWindow::setTradeButton(bool enabled)
+{
tradeButton->setEnabled(enabled);
}
-void TradeWindow::receivedOk(bool own) {
+void TradeWindow::receivedOk(bool own)
+{
if (own) {
ok_me = true;
if (ok_other) {
@@ -198,7 +202,7 @@ void TradeWindow::mouseClick(int x, int y, int button, int count)
{
Window::mouseClick(x, y, button, count);
-
+
// myItems selected
if (x >= myScroll->getX() + 3
&& x <= myScroll->getX() + myScroll->getWidth() - 10
@@ -208,7 +212,7 @@ void TradeWindow::mouseClick(int x, int y, int button, int count)
if (myItems->getIndex() != -1)
{
partnerItems->selectNone();
-
+
// Show Name and Description
std::string SomeText;
SomeText = "Name: " +
@@ -221,15 +225,16 @@ void TradeWindow::mouseClick(int x, int y, int button, int count)
itemDescriptionLabel->adjustSize();
}
// partnerItems selected
- } else if (x >= partnerScroll->getX() + 3
+ }
+ else if (x >= partnerScroll->getX() + 3
&& x <= partnerScroll->getX() + partnerScroll->getWidth() - 20
&& y >= partnerScroll->getY() + 16
&& y <= partnerScroll->getY() + partnerScroll->getHeight() + 15)
{
if (partnerItems->getIndex() != -1)
- {
+ {
myItems->selectNone();
-
+
// Show Name and Description
std::string SomeText;
SomeText = "Name: " +
@@ -246,7 +251,6 @@ void TradeWindow::mouseClick(int x, int y, int button, int count)
void TradeWindow::action(const std::string &eventId)
{
-
if (eventId == "add") {
if (inventoryWindow->items->getIndex() >= 0 &&
inventoryWindow->items->getIndex() <= INVENTORY_SIZE) {
@@ -255,21 +259,26 @@ void TradeWindow::action(const std::string &eventId)
tradeItem(inventoryWindow->items->getIndex(), 1);
}
else {
- itemAmountWindow->setUsage(AMOUNT_TRADE_ADD);
- itemAmountWindow->setVisible(true);
- itemAmountWindow->requestMoveToTop();
+ // Choose amount of items to trade
+ new ItemAmountWindow(AMOUNT_TRADE_ADD, this);
}
}
}
- } else if (eventId == "cancel") {
+ }
+ else if (eventId == "cancel")
+ {
WFIFOW(0) = net_w_value(0x00ed);
WFIFOSET(2);
while ((out_size > 0)) flush();
- } else if (eventId == "ok") {
+ }
+ else if (eventId == "ok")
+ {
WFIFOW(0) = net_w_value(0x00eb);
WFIFOSET(2);
while ((out_size > 0)) flush();
- } else if (eventId == "trade") {
+ }
+ else if (eventId == "trade")
+ {
WFIFOW(0) = net_w_value(0x00ef);
WFIFOSET(2);
while ((out_size > 0)) flush();
diff --git a/src/gui/trade.h b/src/gui/trade.h
index 09e56d06..90c688c3 100644
--- a/src/gui/trade.h
+++ b/src/gui/trade.h
@@ -22,7 +22,7 @@
*/
#ifndef _TMW_TRADE_H
-#define _TMW_TRADE_H
+#define _TMW_TRADE_H
#include "../log.h"
#include "../net/network.h"
@@ -37,7 +37,8 @@
*
* \ingroup Interface
*/
-class TradeWindow : public Window, gcn::ActionListener {
+class TradeWindow : public Window, gcn::ActionListener
+{
public:
/**
* Constructor.
@@ -50,11 +51,6 @@ class TradeWindow : public Window, gcn::ActionListener {
~TradeWindow();
/**
- * Draws the trade window.
- */
- void draw(gcn::Graphics *graphics);
-
- /**
* Add an item the trade window.
*/
void addItem(int index, int id, bool own, int quantity, bool equipment);
@@ -78,35 +74,35 @@ class TradeWindow : public Window, gcn::ActionListener {
* Increase quantity of an item.
*/
void increaseQuantity(int index, bool own, int quantity);
-
+
/**
* Set trade Button disabled
*/
void setTradeButton(bool enabled);
-
+
/**
* Player received ok message from server
*/
void receivedOk(bool own);
-
+
/**
* Send trade packet.
*/
void TradeWindow::tradeItem(int index, int quantity);
-
+
/**
* Called on mouse click.
*/
void mouseClick(int x, int y, int button, int count);
-
+
/**
* Called when receiving actions from the widgets.
*/
void action(const std::string& eventId);
-
+
ItemContainer *myItems;
ItemContainer *partnerItems;
-
+
private:
gcn::Label *itemNameLabel;
gcn::Label *itemDescriptionLabel;
diff --git a/src/gui/window.cpp b/src/gui/window.cpp
index 54bce746..1245c977 100644
--- a/src/gui/window.cpp
+++ b/src/gui/window.cpp
@@ -122,8 +122,7 @@ Window::~Window()
if (prevModal)
{
- gcn::FocusHandler *focusHandler = _getFocusHandler();
- focusHandler->requestModalFocus(prevModal);
+ prevModal->requestModalFocus();
}
}
@@ -221,9 +220,9 @@ Window *Window::getParentWindow()
return parent;
}
-bool Window::isModal()
+void Window::scheduleDelete()
{
- return modal;
+ windowContainer->scheduleDelete(this);
}
void Window::add(gcn::Widget *w)
diff --git a/src/gui/window.h b/src/gui/window.h
index d0112e97..c9fa1f12 100644
--- a/src/gui/window.h
+++ b/src/gui/window.h
@@ -127,7 +127,6 @@ class Window : public gcn::Window, public ConfigListener
*/
void setMaxHeight(unsigned int height);
-
/**
* Returns the parent window.
*
@@ -136,10 +135,10 @@ class Window : public gcn::Window, public ConfigListener
Window *getParentWindow();
/**
- * Returns whether this window is modal. This doesn't necessarily mean
- * that is gets input as a child modal window could get it.
+ * Schedule this window for deletion. It will be deleted at the start
+ * of the next logic update.
*/
- bool isModal();
+ void scheduleDelete();
/**
* Window dragging. This method also makes sure the window is not
@@ -169,16 +168,6 @@ class Window : public gcn::Window, public ConfigListener
static int instances; /**< Number of Window instances */
static ImageRect border; /**< The window border and background */
-
- /**
- * Loads window resources.
- */
- void loadResources();
-
- /**
- * Unloads window resources.
- */
- void unloadResources();
};
#endif