summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorAaron Marks <nymacro@gmail.com>2005-01-04 04:46:02 +0000
committerAaron Marks <nymacro@gmail.com>2005-01-04 04:46:02 +0000
commit52b6be101b78990d5b4523dd5c6523dc5c7c6709 (patch)
tree0990d5d596a0910d037bcab6853ecf9b073939ff /src/gui
parent2be6f298a1c39dff04070588f75a3bed0c495b8b (diff)
downloadmana-52b6be101b78990d5b4523dd5c6523dc5c7c6709.tar.gz
mana-52b6be101b78990d5b4523dd5c6523dc5c7c6709.tar.bz2
mana-52b6be101b78990d5b4523dd5c6523dc5c7c6709.tar.xz
mana-52b6be101b78990d5b4523dd5c6523dc5c7c6709.zip
Converted Skills dialog from old gui to Guichan. Files modified: graphics.cpp, graphics.h, game.cpp, main.cpp, skills.h, skills.cpp. Other files are unmodified (timestamp error)
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/skill.cpp224
-rw-r--r--src/gui/skill.h49
2 files changed, 144 insertions, 129 deletions
diff --git a/src/gui/skill.cpp b/src/gui/skill.cpp
index 455036ef..d3308aa5 100644
--- a/src/gui/skill.cpp
+++ b/src/gui/skill.cpp
@@ -25,16 +25,6 @@
extern PLAYER_INFO *char_info;
-int n_skills = 0;
-SKILL *skill_head = NULL;
-
-char str_string[8];
-char agi_string[8];
-char vit_string[8];
-char int_string[8];
-char dex_string[8];
-char luk_string[8];
-
char *skill_db[] = {
// 0-99
"", "Basic", "", "", "", "", "", "", "", "",
@@ -60,119 +50,125 @@ char *skill_db[] = {
"", "", "", "", "", "", "", "", "", "",
};
-DIALOG skill_dialog[] = {
- /* (dialog proc) (x) (y) (w) (h) (fg) (bg) (key) (flags) (d1) (d2) (dp) (dp2) (dp3) */
- { tmw_dialog_proc, 300, 200, 150, 60, 0, 0, 0, 0, 0, 0, (char *)"Skills", NULL, NULL },
- { tmw_text_proc, 304, 224, 252, 100, 0, 0, 0, 0, 0, 0, str_string, NULL, NULL },
- { tmw_plus_proc, 354, 224, 16, 16, 0, 0, '0', 0, 0, 1, (void*)increaseStatus,NULL, NULL },
- { tmw_text_proc, 304, 234, 252, 100, 0, 0, 0, 0, 0, 0, agi_string, NULL, NULL },
- { tmw_plus_proc, 354, 234, 16, 16, 0, 0, '0', 0, 1, 1, (void*)increaseStatus,NULL, NULL },
- { tmw_text_proc, 304, 244, 252, 100, 0, 0, 0, 0, 0, 0, vit_string, NULL, NULL },
- { tmw_plus_proc, 354, 244, 16, 16, 0, 0, '0', 0, 2, 1, (void*)increaseStatus,NULL, NULL },
- { tmw_text_proc, 374, 224, 252, 100, 0, 0, 0, 0, 0, 0, int_string, NULL, NULL },
- { tmw_plus_proc, 424, 224, 16, 16, 0, 0, '0', 0, 3, 1, (void*)increaseStatus,NULL, NULL },
- { tmw_text_proc, 374, 234, 252, 100, 0, 0, 0, 0, 0, 0, dex_string, NULL, NULL },
- { tmw_plus_proc, 424, 234, 16, 16, 0, 0, '0', 0, 4, 1, (void*)increaseStatus,NULL, NULL },
- { tmw_text_proc, 374, 244, 252, 100, 0, 0, 0, 0, 0, 0, luk_string, NULL, NULL },
- { tmw_plus_proc, 424, 244, 16, 16, 0, 0, '0', 0, 5, 1, (void*)increaseStatus,NULL, NULL },
- { NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL }
-};
-void update_skill_dialog() {
- int skillTemp = 0;
- for(int loop = 0; loop<=char_info->lv;loop++)
- skillTemp += int( (float)loop / (float)5.0 ) + (int)2;
- sprintf(str_string, "STR: %i", char_info->STR);
- sprintf(agi_string, "AGI: %i", char_info->AGI);
- sprintf(vit_string, "VIT: %i", char_info->VIT);
- sprintf(int_string, "INT: %i", char_info->INT);
- sprintf(dex_string, "DEX: %i", char_info->DEX);
- sprintf(luk_string, "LUK: %i", char_info->LUK);
- if(char_info->STR+char_info->AGI+char_info->VIT+char_info->INT+char_info->DEX+char_info->LUK == skillTemp)
- {
- skill_dialog[2].d2 = skill_dialog[4].d2 = skill_dialog[6].d2 =skill_dialog[8].d2 =skill_dialog[10].d2 = 0;
- } else {
- skill_dialog[2].d2 = skill_dialog[4].d2 = skill_dialog[6].d2 =skill_dialog[8].d2 =skill_dialog[10].d2 = 1;
- }
+SkillListModel::SkillListModel()
+{
+ //
}
-void add_skill(short id, short lv, short sp) {
- SKILL *skill = skill_head;
- SKILL *temp = (SKILL *)malloc(sizeof(SKILL));
- temp->id = id;
- temp->lv = lv;
- temp->sp = sp;
- temp->next = NULL;
- if(!skill_head)
- skill_head = temp;
- else {
- while(skill->next)
- skill = skill->next;
- skill->next = temp;
- }
+SkillListModel::~SkillListModel()
+{
+ for (int i = skillList.size() - 1; i >= 0; i--)
+ {
+ delete skillList[i];
+ skillList.pop_back();
+ }
}
-char *skill_list(int index, int *list_size) {
- if(index<0) {
- *list_size = n_skills;
- return NULL;
- } else {
- int iterator = 0;
- SKILL *temp = skill_head;
- while(iterator<index) {
- temp = temp->next;
- iterator++;
- }
- char *name = (char *)malloc(30);
- sprintf(name, "%s lv:%i %i SP", skill_db[temp->id], temp->lv, temp->sp);
- return name;
- // need to clean allocated memory
- }
+int SkillListModel::getNumberOfElements()
+{
+ return skillList.size();
}
-int get_skill_id(int index) {
- int iterator = 0;
- SKILL *temp = skill_head;
- while(iterator<index) {
- temp = temp->next;
- iterator++;
- }
- return temp->id;
+std::string SkillListModel::getElementAt(int i)
+{
+ //
+ if (i >= 0 && i < skillList.size())
+ {
+ //return skill_db[skillList[i]->id];
+ char tmp[128];
+ sprintf(tmp, "%s Lv: %i Sp: %i", skill_db[skillList[i]->id], skillList[i]->lv, skillList[i]->sp);
+ return tmp;
+ }
+ return "";
}
-SKILL *is_skill(int id) {
- SKILL *temp = skill_head;
- while(temp) {
- if(temp->id==id)return temp;
- temp = temp->next;
- }
- return NULL;
+bool SkillListModel::hasSkill(int id)
+{
+ for (int i = 0; i < skillList.size(); i++)
+ if (skillList[i]->id == id)
+ return true;
+ return false;
}
-void increaseStatus(void *dp3, int d1) {
- WFIFOW(0) = net_w_value(0x00bb);
- switch(d1) {
- case 0:
- WFIFOW(2) = net_w_value(0x000d);
- break;
- case 1:
- WFIFOW(2) = net_w_value(0x000e);
- break;
- case 2:
- WFIFOW(2) = net_w_value(0x000f);
- break;
- case 3:
- WFIFOW(2) = net_w_value(0x0010);
- break;
- case 4:
- WFIFOW(2) = net_w_value(0x0011);
- break;
- case 5:
- WFIFOW(2) = net_w_value(0x0012);
- break;
- }
- WFIFOW(4) = net_b_value(1);
- WFIFOSET(5);
- while((out_size>0))flush();
- skill_dialog[2].d2 = skill_dialog[4].d2 = skill_dialog[6].d2 = skill_dialog[8].d2 = skill_dialog[10].d2 = 0;
+void SkillListModel::addSkill(int id, int lv, int sp)
+{
+ SKILL *tmp = new SKILL;
+ tmp->id = id;
+ tmp->lv = lv;
+ tmp->sp = sp;
+ skillList.push_back(tmp);
}
+
+void SkillListModel::setSkill(int id, int lv, int sp)
+{
+ if (!hasSkill(id))
+ return;
+ skillList[id]->lv = lv;
+ skillList[id]->sp = sp;
+}
+
+//
+
+SkillDialog::SkillDialog(gcn::Container *parent)
+ : Window(parent, "Skills")
+{
+ skills = new SkillListModel;
+
+ skillListBox = new gcn::ListBox(skills);
+ pointsLabel = new gcn::Label("Skill Points:");
+ incButton = new Button(" Up ");
+ closeButton = new Button("Close");
+
+ incButton->setEventId("inc");
+ closeButton->setEventId("close");
+
+ skillListBox->setDimension(gcn::Rectangle(0, 0, 200, 180));
+ pointsLabel->setDimension(gcn::Rectangle(0, 0, 200, 16));
+
+ skillListBox->setPosition(8, 4);
+ pointsLabel->setPosition(8, 190);
+ incButton->setPosition(64, 210);
+ closeButton->setPosition(160, 210);
+
+ add(skillListBox);
+ add(pointsLabel);
+ add(incButton);
+ add(closeButton);
+
+ incButton->addActionListener(this);
+ closeButton->addActionListener(this);
+
+ setSize(240, 240);
+ setLocationRelativeTo(getParent());
+}
+
+SkillDialog::~SkillDialog()
+{
+ delete skillListBox;
+ delete pointsLabel;
+ delete incButton;
+ delete closeButton;
+
+ delete skills;
+}
+
+void SkillDialog::action(const std::string& eventId)
+{
+ if (eventId == "inc")
+ {
+ //increment skill
+ } else if (eventId == "close")
+ {
+ setVisible(false);
+ }
+}
+
+void SkillDialog::setPoints(int i)
+{
+ char tmp[128];
+ sprintf(tmp, "Skill points: %i", i);
+ if (pointsLabel != NULL)
+ pointsLabel->setCaption(tmp);
+}
+
diff --git a/src/gui/skill.h b/src/gui/skill.h
index 33e94a18..21f76212 100644
--- a/src/gui/skill.h
+++ b/src/gui/skill.h
@@ -21,30 +21,49 @@
* $Id$
*/
-#ifdef WIN32
- #pragma warning (disable:4312)
-#endif
-
#ifndef _SKILL_H
#define _SKILL_H
#include <allegro.h>
+#include "button.h"
#include "../main.h"
-//DIALOG skill_dialog[];
+struct SKILL {
+ short id; //index into "skill_db" array
+ short lv, sp;
+};
-extern int n_skills;
+class SkillListModel : public gcn::ListModel
+{
+ std::vector<SKILL*> skillList;
+ public:
+ SkillListModel();
+ ~SkillListModel();
-struct SKILL {
- short id, lv, sp;
- SKILL *next;
+ int getNumberOfElements();
+ std::string getElementAt(int);
+
+ bool hasSkill(int id);
+ void addSkill(int id, int lv, int sp);
+ void setSkill(int id, int lv, int sp);
};
+class SkillDialog : public Window, public gcn::ActionListener
+{
+ gcn::ListBox *skillListBox;
+ SkillListModel *skills;
+ gcn::Label *pointsLabel;
+
+ Button *incButton;
+ Button *closeButton;
+ public:
+ SkillDialog(gcn::Container *);
+ ~SkillDialog();
+
+ void action(const std::string&);
+ SkillListModel* getModel() { return skills; }
+
+ void setPoints(int i);
+};
-void update_skill_dialog();
-void add_skill(short id, short lv, short sp);
-char *skill_list(int index, int *list_size);
-int get_skill_id(int index);
-SKILL *is_skill(int id);
-void increaseStatus(void *dp3, int d1);
#endif