summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/game.cpp14
-rw-r--r--src/graphic/graphic.cpp7
-rw-r--r--src/gui/inventory.cpp281
-rw-r--r--src/gui/inventory.h30
4 files changed, 56 insertions, 276 deletions
diff --git a/src/game.cpp b/src/game.cpp
index 0003170b..c6e8d855 100644
--- a/src/game.cpp
+++ b/src/game.cpp
@@ -460,13 +460,13 @@ void do_parse() {
//Get the items
case 0x01ee:
for(int loop=0;loop<(RFIFOW(2)-4)/18;loop++)
- inventory.addItem(RFIFOW(4+loop*18+2), RFIFOW(4+loop*18+6));
+ inventory.add_item(RFIFOW(4+loop*18), RFIFOW(4+loop*18+2), RFIFOW(4+loop*18+6));
break;
case 0x00a8: // could I use the item?
// index RFIFOW(2)
// succes or not RFIFOB(6);
- if(RFIFOB(6))
- inventory.addItem(RFIFOW(2),RFIFOW(4));
+ //if(RFIFOB(6))
+ // inventory.add_item(RFIFOW(2),RFIFOW(4));
break;
// Warp
case 0x0091:
@@ -649,8 +649,10 @@ void do_parse() {
break;
// Buy/Sell dialog
case 0x00c4:
- show_npc_dialog = 2;
- current_npc = RFIFOL(2);
+ if(show_npc_dialog==0) {
+ show_npc_dialog = 2;
+ current_npc = RFIFOL(2);
+ }
break;
// Buy dialog
case 0x00c6:
@@ -682,7 +684,7 @@ void do_parse() {
break;
// Add item to inventory
case 0x00a0:
- inventory.addItem(RFIFOW(6), RFIFOW(4));
+ inventory.add_item(RFIFOW(2), RFIFOW(6), RFIFOW(4));
break;
// Manage non implemented packets
default:
diff --git a/src/graphic/graphic.cpp b/src/graphic/graphic.cpp
index 43768f54..1631ef10 100644
--- a/src/graphic/graphic.cpp
+++ b/src/graphic/graphic.cpp
@@ -63,9 +63,10 @@ DIALOG npc_dialog[] = {
DIALOG buy_sell_dialog[] = {
/* (dialog proc) (x) (y) (w) (h) (fg) (bg) (key) (flags) (d1) (d2) (dp) (dp2) (dp3) */
- { tmw_dialog_proc, 350, 200, 100, 80, 0, 0, 0, 0, 0, 0, (char *)"Shop", NULL, NULL },
- { tmw_button_proc, 360, 225, 80, 20, 255, 0, 0, D_EXIT, 0, 0, (char *)"&BUY", NULL, NULL },
- { tmw_button_proc, 360, 250, 80, 20, 255, 0, 0, D_EXIT, 0, 0, (char *)"&SELL", NULL, NULL },
+ { tmw_dialog_proc, 350, 200, 100, 105, 0, 0, 0, 0, 0, 0, (char *)"Shop", NULL, NULL },
+ { tmw_button_proc, 360, 225, 80, 20, 255, 0, 0, D_EXIT, 0, 0, (char *)"&Buy", NULL, NULL },
+ { tmw_button_proc, 360, 250, 80, 20, 255, 0, 0, D_EXIT, 0, 0, (char *)"&Sell", NULL, NULL },
+ { tmw_button_proc, 360, 275, 80, 20, 255, 0, 0, D_EXIT, 0, 0, (char *)"&Cancel",NULL, NULL },
{ NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL }
};
diff --git a/src/gui/inventory.cpp b/src/gui/inventory.cpp
index ca9bde7a..26f289d2 100644
--- a/src/gui/inventory.cpp
+++ b/src/gui/inventory.cpp
@@ -33,270 +33,55 @@ DIALOG inventory_dialog[] = {
DIALOG_PLAYER *inventory_player;
+/** Initialize inventory */
void TmwInventory::create(int tempxpos, int tempypos) {
- xpos = tempxpos;
- ypos = tempypos;
itemset = load_datafile("./data/graphic/items.dat");
- empty = load_bitmap("./data/graphic/empty.bmp", NULL);
- selected = load_bitmap("./data/graphic/selected.bmp", NULL);
-
- for(int i = 0; i< 10; i++) {
- for(int ii = 0; ii< 10; ii++) {
- items[i][ii].flag = 0; //doesn't hold anything
- items[i][ii].itemIDNum = -1; //doesn't exist :)
- items[i][ii].xpos = empty->w*i+1;
- items[i][ii].ypos = empty->h*ii+20;
- items[i][ii].num = 0;
- }
+
+ for(int i=0;i<INVENTORY_SIZE;i++) {
+ items[i].id = -1; // if id is negative there's no item
+ items[i].quantity = 0;
}
- //draw_rle_sprite(buffer, (RLE_SPRITE *)itemPIC[items[itemX][itemY].itemIDNum].pic, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos));
-
- //create two fake items
- /*items[0][0].flag = 1;
- items[0][0].itemIDNum = 0;
- items[0][0].num = 1;
-
- items[2][0].flag = 1;
- items[2][0].itemIDNum = 1;
- items[2][0].num = 3;*/
-
- backgroundSmall = create_bitmap(empty->w*10+10, empty->h+10);
- backgroundBig = create_bitmap(empty->w*10+10, empty->h*10+10);
- title = create_bitmap(15, backgroundSmall->h);
- clear_to_color(title, makecol(0, 0, 200));
- clear_to_color(backgroundSmall, makecol(0,0,100));
- clear_to_color(backgroundBig, makecol(0,0,100));
- areDisplaying = 0;
- dragingWindow = 0;
- lastSelectedX = -1;
- lastSelectedY = -1;
- bigwindow = 0; //false
-
- inventory_player = init_dialog(inventory_dialog, -1);
+
+ inventory_player = init_dialog(inventory_dialog, -1);
+ position_dialog(inventory_dialog, x, y);
+ show_inventory = false;
}
+/** Draw inventory window */
void TmwInventory::draw(BITMAP * buffer) {
- // let's draw the inventory
- if(areDisplaying) {
- position_dialog(inventory_dialog, xpos, ypos);
+ if(show_inventory) {
dialog_message(inventory_dialog,MSG_DRAW,0,0);
- update_dialog(inventory_player);
- int max = 1;
- /*if(!bigwindow) {
- max = 1;
- blit(backgroundSmall, buffer, 0, 0, xpos-5, ypos-5, 800, 600);
- } else {
- max = 10;
- blit(backgroundBig, buffer, 0, 0, xpos-5, ypos-5, 800, 600);
- }*/
- //blit(title, buffer, 0, 0, xpos+backgroundSmall->w-5, ypos+-5, 800, 600);
- for(int itemX=0;itemX<10;itemX++) {
- for(int itemY=0;itemY<max;itemY++) {
- int draw = 0;
- //blit(empty, buffer, 0, 0, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos), 800, 600);
-
- if(mouse_b&1) {
- if(xpos+items[itemX][itemY].xpos+empty->w > mouse_x && xpos+items[itemX][itemY].xpos < mouse_x)
- if(ypos+items[itemX][itemY].ypos+empty->h > mouse_y && ypos+items[itemX][itemY].ypos < mouse_y) {
- //selected
- masked_blit(selected, buffer, 0, 0, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos), 800, 600);
- draw = 1;
- if(items[itemX][itemY].flag) // have a item
- if(!dragingItem) { //not dragging it
- dragingItem=1; //begin to drag
- ghostOldIDX = itemX;
- ghostOldIDY = itemY;
- ghostID = items[itemX][itemY].itemIDNum;
- ghostX = mouse_x;
- ghostY = mouse_y;
- }
- }
- } else { // if !mouse_b&1
- if(lastSelectedX != -1 && dragingItem) { // have stoped dragging it over a itemholder
- //swap place
- itemHolder temp;
- int txpos1,typos1,txpos2,typos2;
- txpos1 = items[lastSelectedX][lastSelectedY].xpos;
- typos1 = items[lastSelectedX][lastSelectedY].ypos;
- txpos2 = items[ghostOldIDX][ghostOldIDY].xpos;
- typos2 = items[ghostOldIDX][ghostOldIDY].ypos;
- temp = items[lastSelectedX][lastSelectedY];
- items[lastSelectedX][lastSelectedY] = items[ghostOldIDX][ghostOldIDY];
- items[ghostOldIDX][ghostOldIDY] = temp;
- items[lastSelectedX][lastSelectedY].xpos = txpos1;
- items[lastSelectedX][lastSelectedY].ypos = typos1;
- items[ghostOldIDX][ghostOldIDY].xpos = txpos2;
- items[ghostOldIDX][ghostOldIDY].ypos = typos2;
- }
- dragingItem = 0; // stop dragging
- }
-
- if(mouse_b&2 && items[itemX][itemY].flag) { // if roght mouse button over an item
- if(xpos+items[itemX][itemY].xpos+empty->w > mouse_x && xpos+items[itemX][itemY].xpos < mouse_x)
- if(ypos+items[itemX][itemY].ypos+empty->h > mouse_y && ypos+items[itemX][itemY].ypos < mouse_y) {
- //selected
- masked_blit(selected, buffer, 0, 0, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos), 800, 600);
- draw = 1;
- if(itemMeny){ itemMeny=0; } else { itemMeny=1; itemIdn =items[itemX][itemY].itemIDNum ;itemMeny_x = (xpos+items[itemX][itemY].xpos)+selected->w;itemMeny_y = (ypos+items[itemX][itemY].ypos)+selected->h;}
- }
- }
-
- if(xpos+items[itemX][itemY].xpos+empty->w > mouse_x && xpos+items[itemX][itemY].xpos < mouse_x && ypos+items[itemX][itemY].ypos+empty->h > mouse_y && ypos+items[itemX][itemY].ypos < mouse_y ) {
- // a hoover
- lastSelectedX = itemX;
- lastSelectedY = itemY;
- }
-
- xpos = inventory_dialog[0].x;
- ypos = inventory_dialog[0].y;
-
- if(items[itemX][itemY].flag) //draw the item
- // If the item is known
- if(items[itemX][itemY].itemIDNum>=501 && items[itemX][itemY].itemIDNum<=510)
- masked_blit((BITMAP *)itemset[items[itemX][itemY].itemIDNum-500].dat, buffer, 0, 0, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos), 32, 32);
- // If the item is unknown
- else
- masked_blit((BITMAP *)itemset[0].dat, buffer, 0, 0, (xpos+items[itemX][itemY].xpos), (ypos+items[itemX][itemY].ypos), 32, 32);
-
- //the number of that item
- if(!bigwindow)
- alfont_textprintf_centre_aa(buffer, gui_font, xpos+items[itemX][itemY].xpos+20, ypos+items[itemX][itemY].ypos+empty->h-15, makecol(0,0,0), "%i",items[itemX][itemY].num);
- else
- alfont_textprintf_centre_aa(buffer, gui_font, xpos+items[itemX][itemY].xpos+20, ypos+items[itemX][itemY].ypos+empty->h-15, makecol(0,0,0), "%i",items[itemX][itemY].num);
-
- }
- }
-
- if(mouse_b&2) {
- if(xpos+title->w+backgroundSmall->w > mouse_x && xpos+backgroundSmall->w < mouse_x)
- if(ypos+title->h > mouse_y && ypos < mouse_y) {
- if(bigwindow)
- bigwindow=0;
- else
- bigwindow = 1;
- }
- }
- }
-
- /*if(mouse_b&1) {
- if(xpos+title->w+backgroundSmall->w > mouse_x && xpos+backgroundSmall->w < mouse_x)
- if(ypos+title->h > mouse_y && ypos < mouse_y) { //begin to move the window
- xpos = mouse_x-(backgroundSmall->w);
- ypos = mouse_y;
- dragingWindow=1;
- }
- } else { dragingWindow=0;}*/
-
- /*if(dragingWindow) { //moving the window ?
- xpos = mouse_x-(backgroundSmall->w);
- ypos = mouse_y;
- }*/
-
- if(dragingItem) { //moving the item
- masked_blit((BITMAP *)itemset[ghostID].dat, buffer, 0, 0, ghostX, ghostY, 800, 600);
- ghostX = mouse_x;
- ghostY = mouse_y;
- }
-
- if(itemMeny){
- if(itemMeny_y < mouse_y && itemMeny_y+10 > mouse_y) {
- if(mouse_b&1) {
- useItem(itemIdn);
- itemMeny = 0;
- }
- alfont_textprintf_aa(buffer, gui_font, itemMeny_x, itemMeny_y, makecol(255,237,33), "Use item");
- } else {
- alfont_textprintf_aa(buffer, gui_font, itemMeny_x, itemMeny_y, MAKECOL_BLACK, "Use item");
- }
- if(itemMeny_y+10 < mouse_y && itemMeny_y+20 > mouse_y) {
- if(mouse_b&1) {
- rmItem(itemIdn);
- itemMeny = 0;
- }
- alfont_textprintf_aa(buffer, gui_font, itemMeny_x, itemMeny_y+10, makecol(255,237,33), "Del item");
- } else {
- alfont_textprintf_aa(buffer, gui_font, itemMeny_x, itemMeny_y+10, MAKECOL_BLACK, "Del item");
- }
+ update_dialog(inventory_player);
}
}
-
-void TmwInventory::show(int val) {
- if(val)
- areDisplaying = 1;
-
- if(!val)
- areDisplaying = 0;
+/** Set if inventory is visible */
+void TmwInventory::show(bool val) {
+ show_inventory = val;
}
-int TmwInventory::addItem(int idnum, int antal) {
- int found, tempi, tempii = 0;
- found = 0;
- tempi = -1;
- for(int i = 0; i< 10; i++) {
- for(int ii = 0; ii< 10; ii++) {
- if(items[i][ii].itemIDNum == idnum) {
- found = 1; items[i][ii].num = antal;
- return -2;
- }
- }
- }
-
- if(!found) {
- for(int ii = 0; ii< 10; ii++) {
- for(int i = 0; i< 10; i++) {
- if(items[i][ii].flag == 0) {
- tempi = i;
- tempii = ii;
- ii=10;
- i=10;
- }
- }
- }
-
- if(tempi != -1) {
- items[tempi][tempii].flag = 1;
- items[tempi][tempii].itemIDNum = idnum;
- items[tempi][tempii].num = antal;
- return 1;
- } else {
- return -1;
- }
- }
- return -3;
+/** Add an item the inventory */
+int TmwInventory::add_item(int index, int id, int quantity) {
+ items[index].id = id;
+ items[index].quantity = quantity;
+ return 0;
}
-int TmwInventory::rmItem(int idnum) {
- int found, tempi;
- found = 0;
- tempi = -1;
- for(int i = 0; i< 10; i++) {
- for(int ii = 0; ii< 10; ii++) {
- if(items[i][ii].itemIDNum == idnum) {
- items[i][ii].itemIDNum = -1;
- items[i][ii].flag = 0;
- items[i][ii].num = 0;
- return 1;
- }
- }
- }
- return -1;
+/** Remove a item from the inventory */
+int TmwInventory::remove_item(int id) {
+ for(int i=0;i<INVENTORY_SIZE;i++)
+ if(items[i].id==id) {
+ items[i].id = -1;
+ items[i].quantity = 0;
+ }
+ return 0;
}
-int TmwInventory::changeNum(int idnum, int antal) {
- int found, tempi;
- found = 0;
- tempi = -1;
- for(int i = 0; i< 10; i++) {
- for(int ii = 0; ii< 10; ii++) {
- if(items[i][ii].itemIDNum == idnum) {
- items[i][ii].num = antal;
- return 1;
- }
- }
- }
- return -1;
+/** Change quantity of an item */
+int TmwInventory::change_quantity(int index, int quantity) {
+ items[index].quantity = quantity;
+ return 0;
}
int TmwInventory::useItem(int idnum) {
@@ -307,4 +92,4 @@ int TmwInventory::useItem(int idnum) {
while((out_size>0))flush();
return 0;
-}
+}*/
diff --git a/src/gui/inventory.h b/src/gui/inventory.h
index e88094ed..61ec9e7b 100644
--- a/src/gui/inventory.h
+++ b/src/gui/inventory.h
@@ -31,47 +31,39 @@
#define _INVENTORY_H
#include <allegro.h>
-/*#ifdef WIN32
-#include <winalleg.h>
-#endif*/
#include "../main.h"
#include "../game.h"
#include "../log.h"
#include "../net/network.h"
#include "gui.h"
+#define INVENTORY_SIZE 10
+
struct itemHolder { // the holder of a item
- int flag; // don't really know why I use this :)
- int itemIDNum; // the id of the item
- int num; // number of items
- int xpos, ypos; // where am I?
+ int id; // the id of the item
+ int quantity; // number of items
+ //int index; // item position
};
-
-
class TmwInventory{
public:
TmwInventory() {};
~TmwInventory() {};
- void create(int tempxpos, int tempypos); // create the window
+ void create(int x, int y); // create the window
void draw(BITMAP *); // draw the window (if areDisplaying != 0 )
- void show(int val); // choose between showing and not showing the window
+ void show(bool val); // choose between showing and not showing the window
void toggle() { if(areDisplaying){show(0);}else{show(1);} }
//API
- int addItem(int idnum, int antal); //add a item
- int rmItem(int idnum); //remove a item
+ int add_item(int index, int id, int quantity); // add a item
+ int remove_item(int id); // remove a item
int changeNum(int idnum, int antal); // change number of a item
int useItem(int idnum);
//END API
private:
- BITMAP * backgroundSmall;
- BITMAP * backgroundBig;
- BITMAP * title;
- BITMAP * empty;
- BITMAP * selected;
- itemHolder items[10][10]; // this is the test holder of items
+ itemHolder items[INVENTORY_SIZE]; // this is the holder of items
DATAFILE *itemset;
+ bool show_inventory;
int ghostX, ghostY, ghostID, ghostOldIDX,ghostOldIDY; //info needed when moving item
int dragingItem, lastSelectedX,lastSelectedY; //info needed when moving item
int areDisplaying, dragingWindow;