summaryrefslogtreecommitdiff
path: root/src/graphic/graphic.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/graphic/graphic.cpp')
-rw-r--r--src/graphic/graphic.cpp50
1 files changed, 14 insertions, 36 deletions
diff --git a/src/graphic/graphic.cpp b/src/graphic/graphic.cpp
index cc450d33..bba04d52 100644
--- a/src/graphic/graphic.cpp
+++ b/src/graphic/graphic.cpp
@@ -46,6 +46,7 @@ BuyDialog *buyDialog;
SellDialog *sellDialog;
BuySellDialog *buySellDialog;
InventoryWindow *inventoryWindow;
+NpcListDialog *npcListDialog;
void ChatListener::action(const std::string& eventId)
{
@@ -98,15 +99,6 @@ DIALOG skill_list_dialog[] = {
{ NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL }
};
-DIALOG npc_list_dialog[] = {
- /* (dialog proc) (x) (y) (w) (h) (fg) (bg) (key) (flags) (d1) (d2) (dp) (dp2) (dp3) */
- { tmw_dialog_proc, 300, 200, 260, 200, 0, 0, 0, 0, 0, 0, (char *)"NPC", NULL, NULL },
- { tmw_button_proc, 450, 376, 50, 20, 255, 0, 'o', D_EXIT, 0, 0, (char *)"&Ok", NULL, NULL },
- { tmw_button_proc, 508, 376, 50, 20, 255, 0, 'c', D_EXIT, 0, 0, (char *)"&Cancel", NULL, NULL },
- { tmw_list_proc, 304, 224, 252, 100, 0, 0, 0, 0, 0, 0, (char *)item_list, NULL, NULL },
- { NULL, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL }
-};
-
char hairtable[14][4][2] = {
// S(x,y) W(x,y) N(x,y) E(x,y)
{ { 0, 0}, {-1, 2}, {-1, 2}, {0, 2} }, // STAND
@@ -200,11 +192,13 @@ GraphicEngine::GraphicEngine() {
inventoryWindow->setVisible(false);
inventoryWindow->setPosition(100, 100);
+ npcListDialog = new NpcListDialog(guiTop);
+ npcListDialog->setVisible(false);
+
npc_player = init_dialog(npc_dialog, -1);
position_dialog(npc_dialog, 300, 200);
skill_player = init_dialog(skill_dialog, -1);
skill_list_player = init_dialog(skill_list_dialog, -1);
- npc_list_player = init_dialog(npc_list_dialog, -1);
buffer = create_bitmap(SCREEN_W, SCREEN_H);
if(!buffer) {
@@ -291,28 +285,27 @@ void GraphicEngine::refresh() {
else if (node->job < 10) { // Draw a player
node->text_x = sx * 32 + get_x_offset(node) - offset_x;
node->text_y = sy * 32 + get_y_offset(node) - offset_y;
+ int hf = node->hair_color - 1 + 10 * (dir + 4 *
+ (node->hair_style - 1));
if (node->action == SIT) node->frame = 0;
if (node->action == ATTACK) {
int pf = node->frame + node->action + 4 * node->weapon;
- int wf = 16 * node->weapon + 4 * node->frame;
playerset->spriteset[4 * pf + dir]->draw(buffer,
- node->text_x-64, node->text_y-80);
- /*draw_rle_sprite(buffer, (RLE_SPRITE*)weaponset[wf + dir].dat,
- node->text_x, node->text_y);*/
- hairset->spriteset[node->hair_color-1+10*(dir+4*(node->hair_style-1))]->draw(
- buffer, node->text_x -2 + 2*hairtable[pf][dir][0],
- node->text_y -50 + 2*hairtable[pf][dir][1]);
+ node->text_x - 64, node->text_y - 80);
+ hairset->spriteset[hf]->draw(
+ buffer, node->text_x - 2 + 2 * hairtable[pf][dir][0],
+ node->text_y - 50 + 2 * hairtable[pf][dir][1]);
}
else {
int pf = node->frame + node->action;
playerset->spriteset[4 * pf + dir]->draw(buffer,
- node->text_x-64, node->text_y-80);
- hairset->spriteset[node->hair_color-1+10*(dir+4*(node->hair_style-1))]->draw(
- buffer, node->text_x - 2 + 2*hairtable[pf][dir][0],
- node->text_y - 50 + 2*hairtable[pf][dir][1]);
+ node->text_x - 64, node->text_y - 80);
+ hairset->spriteset[hf]->draw(
+ buffer, node->text_x - 2 + 2 * hairtable[pf][dir][0],
+ node->text_y - 50 + 2 * hairtable[pf][dir][1]);
}
if (node->emotion != 0) {
emotionset->spriteset[node->emotion - 1]->draw(buffer,
@@ -472,21 +465,6 @@ void GraphicEngine::refresh() {
WFIFOSET(6);
}
break;
- case 5:
- dialog_message(npc_list_dialog, MSG_DRAW, 0, 0);
- if (!gui_update(npc_list_player)) {
- show_npc_dialog = shutdown_dialog(npc_list_player);
- if (show_npc_dialog == 1) {
- WFIFOW(0) = net_w_value(0x00b8);
- WFIFOL(2) = net_l_value(current_npc);
- WFIFOB(6) = net_b_value(npc_list_dialog[3].d1+1);
- WFIFOSET(7);
- }
- show_npc_dialog = 0;
- npc_list_player = init_dialog(npc_list_dialog, -1);
- remove_all_items();
- }
- break;
}
if (show_skill_dialog) {