mirror of
https://git.planet-casio.com/Slyvtt/Collab_RPG.git
synced 2025-01-04 07:53:39 +01:00
Compare commits
No commits in common. "1a652762e3a77a647e34b0193ed4263447276cb9" and "311b7f27df05bdecf56ec07dec6abba93907205a" have entirely different histories.
1a652762e3
...
311b7f27df
11 changed files with 44 additions and 245 deletions
|
@ -74,8 +74,6 @@ set(ASSETS_cg
|
||||||
assets-cg/font.png
|
assets-cg/font.png
|
||||||
assets-cg/inventory.png
|
assets-cg/inventory.png
|
||||||
assets-cg/items.png
|
assets-cg/items.png
|
||||||
assets-cg/selection.png
|
|
||||||
assets-cg/selected.png
|
|
||||||
)
|
)
|
||||||
|
|
||||||
set(ASSETS_cg_EGA64
|
set(ASSETS_cg_EGA64
|
||||||
|
@ -90,8 +88,6 @@ set(ASSETS_fx
|
||||||
assets-fx/SGN_Icon.png
|
assets-fx/SGN_Icon.png
|
||||||
assets-fx/player_face.png
|
assets-fx/player_face.png
|
||||||
assets-fx/font.png
|
assets-fx/font.png
|
||||||
assets-fx/selection.png
|
|
||||||
assets-fx/selected.png
|
|
||||||
# ...
|
# ...
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 684 B After Width: | Height: | Size: 666 B |
Binary file not shown.
Before Width: | Height: | Size: 33 KiB After Width: | Height: | Size: 4.7 KiB |
Binary file not shown.
Before Width: | Height: | Size: 35 KiB After Width: | Height: | Size: 34 KiB |
|
@ -17,14 +17,6 @@ SGN_Icon.png:
|
||||||
type: bopti-image
|
type: bopti-image
|
||||||
name: SGN_Icon_img
|
name: SGN_Icon_img
|
||||||
|
|
||||||
selection.png:
|
|
||||||
type: bopti-image
|
|
||||||
name: selection_img
|
|
||||||
|
|
||||||
selected.png:
|
|
||||||
type: bopti-image
|
|
||||||
name: selected_img
|
|
||||||
|
|
||||||
font.png:
|
font.png:
|
||||||
name: fontRPG
|
name: fontRPG
|
||||||
type: font
|
type: font
|
||||||
|
|
|
@ -142,7 +142,7 @@ def convert_map(input: str, output: str, params: dict, target):
|
||||||
indoor = int(input_map.get_property("indoor"))
|
indoor = int(input_map.get_property("indoor"))
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
# Show a warning
|
# Show a warning
|
||||||
print(f"WARNING: Indoor property not found.")
|
print(f"WARNING: Indoor property not found.\n")
|
||||||
|
|
||||||
if indoor:
|
if indoor:
|
||||||
# Get the indoor tileset
|
# Get the indoor tileset
|
||||||
|
|
16
src/config.h
16
src/config.h
|
@ -27,13 +27,7 @@
|
||||||
#define P_HEIGHT 16
|
#define P_HEIGHT 16
|
||||||
/*Max number of dynamic NPCs.*/
|
/*Max number of dynamic NPCs.*/
|
||||||
#define NPC_STACK_SIZE 256
|
#define NPC_STACK_SIZE 256
|
||||||
/* The position of the slots in the inventory */
|
|
||||||
#define SLOT_Y 87
|
|
||||||
#define SLOT_X_EQUIPPED 222
|
|
||||||
#define SLOT_X 272
|
|
||||||
#define SLOT_W 28
|
|
||||||
#define SLOT_H 27
|
|
||||||
#define SLOT_SPACING 32
|
|
||||||
#else
|
#else
|
||||||
/* The tile size */
|
/* The tile size */
|
||||||
#define T_HEIGHT 8
|
#define T_HEIGHT 8
|
||||||
|
@ -46,13 +40,7 @@
|
||||||
#define P_HEIGHT 8
|
#define P_HEIGHT 8
|
||||||
/*Max number of "dynamic" NPCs. We are starved for static ram on fx !*/
|
/*Max number of "dynamic" NPCs. We are starved for static ram on fx !*/
|
||||||
#define NPC_STACK_SIZE 32
|
#define NPC_STACK_SIZE 32
|
||||||
/* The position of the slots in the inventory */
|
|
||||||
#define SLOT_Y 24
|
|
||||||
#define SLOT_X_EQUIPPED 72
|
|
||||||
#define SLOT_X 88
|
|
||||||
#define SLOT_W 8
|
|
||||||
#define SLOT_H 8
|
|
||||||
#define SLOT_SPACING 12
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* SPEED should NOT be 8 or bigger: it may cause bugs when handling
|
/* SPEED should NOT be 8 or bigger: it may cause bugs when handling
|
||||||
|
|
59
src/game.c
59
src/game.c
|
@ -36,11 +36,6 @@ void game_init(Game *game) {
|
||||||
events_init_handler(&game->handler);
|
events_init_handler(&game->handler);
|
||||||
events_bind_variable(&game->handler, (int *)&game->player.life, "life");
|
events_bind_variable(&game->handler, (int *)&game->player.life, "life");
|
||||||
events_bind_variable(&game->handler, &game->mana, "mana");
|
events_bind_variable(&game->handler, &game->mana, "mana");
|
||||||
inventory_init(&game->inventory);
|
|
||||||
/* For debugging */
|
|
||||||
game->inventory.slots[5].i = I_GLOVE;
|
|
||||||
game->inventory.slots[1].i = I_ARMOR;
|
|
||||||
game->inventory.slots[8].i = I_TALISMAN;
|
|
||||||
|
|
||||||
// reload_npc(&game);
|
// reload_npc(&game);
|
||||||
}
|
}
|
||||||
|
@ -129,8 +124,6 @@ void game_render_indicator(Game *game) {
|
||||||
void game_draw(Game *game) {
|
void game_draw(Game *game) {
|
||||||
/*Only clear if we are inside, the screen is guaranteed to be filled
|
/*Only clear if we are inside, the screen is guaranteed to be filled
|
||||||
* otherwise */
|
* otherwise */
|
||||||
/* (Mibi88) if we do so, we should only use opaque tiles in the background
|
|
||||||
layer (it's currently not the case), to artefacts when rendering dialogs. */
|
|
||||||
if(game->map_level->indoor)
|
if(game->map_level->indoor)
|
||||||
dclear(C_WHITE);
|
dclear(C_WHITE);
|
||||||
map_render_by_layer(game, BACKGROUND);
|
map_render_by_layer(game, BACKGROUND);
|
||||||
|
@ -143,7 +136,7 @@ void game_draw(Game *game) {
|
||||||
dprint(8, 8, C_BLACK, "npc_count: %d", npc_count);
|
dprint(8, 8, C_BLACK, "npc_count: %d", npc_count);
|
||||||
dprint(8, 16, C_BLACK, "Mana: %d", game->mana);
|
dprint(8, 16, C_BLACK, "Mana: %d", game->mana);
|
||||||
dprint(8, 24, C_BLACK, "X: %d Y: %d", game->player.x, game->player.y);
|
dprint(8, 24, C_BLACK, "X: %d Y: %d", game->player.x, game->player.y);
|
||||||
inventory_draw(&game->inventory, &game->player);
|
inventory_draw(game, &game->inventory);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Key management */
|
/* Key management */
|
||||||
|
@ -166,56 +159,6 @@ void game_get_inputs(Game *game) {
|
||||||
clearevents();
|
clearevents();
|
||||||
sleep();
|
sleep();
|
||||||
}
|
}
|
||||||
} else if(game->inventory.open) {
|
|
||||||
if(keydown(KEY_LEFT))
|
|
||||||
inventory_move_selection(&game->inventory, D_LEFT);
|
|
||||||
/* TODO: Make something cleaner */
|
|
||||||
while(keydown(KEY_LEFT)) {
|
|
||||||
clearevents();
|
|
||||||
sleep();
|
|
||||||
}
|
|
||||||
if(keydown(KEY_RIGHT))
|
|
||||||
inventory_move_selection(&game->inventory, D_RIGHT);
|
|
||||||
/* TODO: Make something cleaner */
|
|
||||||
while(keydown(KEY_RIGHT)) {
|
|
||||||
clearevents();
|
|
||||||
sleep();
|
|
||||||
}
|
|
||||||
if(keydown(KEY_UP))
|
|
||||||
inventory_move_selection(&game->inventory, D_UP);
|
|
||||||
/* TODO: Make something cleaner */
|
|
||||||
while(keydown(KEY_UP)) {
|
|
||||||
clearevents();
|
|
||||||
sleep();
|
|
||||||
}
|
|
||||||
if(keydown(KEY_DOWN))
|
|
||||||
inventory_move_selection(&game->inventory, D_DOWN);
|
|
||||||
/* TODO: Make something cleaner */
|
|
||||||
while(keydown(KEY_DOWN)) {
|
|
||||||
clearevents();
|
|
||||||
sleep();
|
|
||||||
}
|
|
||||||
if(keydown(KEY_OPTN))
|
|
||||||
inventory_move_from_selected(&game->inventory);
|
|
||||||
/* TODO: Make something cleaner */
|
|
||||||
while(keydown(KEY_OPTN)) {
|
|
||||||
clearevents();
|
|
||||||
sleep();
|
|
||||||
}
|
|
||||||
if(keydown(KEY_SQUARE)) {
|
|
||||||
inventory_use(&game->inventory, &game->player);
|
|
||||||
}
|
|
||||||
if(keydown(KEY_F1)) {
|
|
||||||
inventory_unequip(&game->inventory, IT_TALISMAN);
|
|
||||||
}
|
|
||||||
if(keydown(KEY_F2)) {
|
|
||||||
inventory_unequip(&game->inventory, IT_ARMOR);
|
|
||||||
}
|
|
||||||
if(keydown(KEY_F3)) {
|
|
||||||
inventory_unequip(&game->inventory, IT_WEAPON);
|
|
||||||
}
|
|
||||||
if(keydown(KEY_SHIFT))
|
|
||||||
game->inventory.selected = game->inventory.selection;
|
|
||||||
} else {
|
} else {
|
||||||
/* Player actions - Prototypes in player.h and implementation in
|
/* Player actions - Prototypes in player.h and implementation in
|
||||||
* player.c */
|
* player.c */
|
||||||
|
|
22
src/game.h
22
src/game.h
|
@ -32,30 +32,17 @@ typedef enum {
|
||||||
I_AMOUNT
|
I_AMOUNT
|
||||||
} Item;
|
} Item;
|
||||||
|
|
||||||
typedef enum {
|
|
||||||
IT_NONE,
|
|
||||||
IT_TALISMAN,
|
|
||||||
IT_ARMOR,
|
|
||||||
IT_WEAPON,
|
|
||||||
IT_FOOD,
|
|
||||||
IT_AMOUNT
|
|
||||||
} ItemType;
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
Item i : 4;
|
Item i;
|
||||||
unsigned char durability;
|
unsigned char durability;
|
||||||
} Slot;
|
} Slot;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
/* Backpack slots. */
|
|
||||||
Slot slots[SLOT_NUM];
|
Slot slots[SLOT_NUM];
|
||||||
/* Equipped items: first slot: talisman, second slot: armor, last slot:
|
Slot talisman;
|
||||||
weapon. */
|
Slot armor;
|
||||||
Slot equipped[3];
|
Slot weapon;
|
||||||
/* 1 if the inventory is open. */
|
|
||||||
char open : 1;
|
char open : 1;
|
||||||
char selected;
|
|
||||||
char selection;
|
|
||||||
} Inventory;
|
} Inventory;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -153,7 +140,6 @@ typedef struct {
|
||||||
uint8_t current_group;
|
uint8_t current_group;
|
||||||
uint8_t hostile_to_group;
|
uint8_t hostile_to_group;
|
||||||
|
|
||||||
/* uint16_t to keep the struct aligned */
|
|
||||||
uint16_t __padding;
|
uint16_t __padding;
|
||||||
} NPC;
|
} NPC;
|
||||||
|
|
||||||
|
|
166
src/inventory.c
166
src/inventory.c
|
@ -1,151 +1,51 @@
|
||||||
#include "inventory.h"
|
#include "inventory.h"
|
||||||
|
|
||||||
#include <gint/display.h>
|
#include <gint/display.h>
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
extern bopti_image_t inventory_img;
|
extern bopti_image_t inventory_img;
|
||||||
extern bopti_image_t items_img;
|
extern bopti_image_t items_img;
|
||||||
extern bopti_image_t selection_img;
|
|
||||||
extern bopti_image_t selected_img;
|
|
||||||
extern bopti_image_t player_male_inv_img;
|
extern bopti_image_t player_male_inv_img;
|
||||||
extern bopti_image_t player_female_inv_img;
|
extern bopti_image_t player_female_inv_img;
|
||||||
|
|
||||||
char item_types[I_AMOUNT] = {IT_NONE, IT_ARMOR, IT_WEAPON, IT_WEAPON,
|
void inventory_draw(Game *game, Inventory *inventory) {
|
||||||
IT_FOOD, IT_FOOD, IT_TALISMAN};
|
|
||||||
|
|
||||||
void inventory_init(Inventory *inventory) {
|
|
||||||
inventory->open = 0;
|
|
||||||
memset(inventory->slots, 0, sizeof(Slot) * SLOT_NUM);
|
|
||||||
memset(inventory->equipped, 0, sizeof(Slot) * 3);
|
|
||||||
inventory->selected = -1;
|
|
||||||
inventory->selection = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void inventory_draw(Inventory *inventory, Player *player) {
|
|
||||||
size_t i;
|
size_t i;
|
||||||
|
/* TODO: Cleanup! */
|
||||||
|
inventory->slots[5].i = I_GLOVE;
|
||||||
|
inventory->armor.i = I_ARMOR;
|
||||||
|
inventory->talisman.i = I_TALISMAN;
|
||||||
|
inventory->weapon.i = I_SWORD;
|
||||||
if(inventory->open) {
|
if(inventory->open) {
|
||||||
dimage(0, 0, &inventory_img);
|
dimage(0, 0, &inventory_img);
|
||||||
for(i = 0; i < SLOT_NUM; i++) {
|
for(i = 0; i < SLOT_NUM; i++) {
|
||||||
dsubimage(SLOT_X + (i % SLOT_COLUMNS) * SLOT_SPACING,
|
|
||||||
SLOT_Y + (i / SLOT_COLUMNS) * SLOT_SPACING, &items_img,
|
|
||||||
inventory->slots[i].i * SLOT_W, 0, SLOT_W, SLOT_H,
|
|
||||||
DIMAGE_NONE);
|
|
||||||
if(i == inventory->selection) {
|
|
||||||
dimage(SLOT_X + (i % SLOT_COLUMNS) * SLOT_SPACING,
|
|
||||||
SLOT_Y + (i / SLOT_COLUMNS) * SLOT_SPACING,
|
|
||||||
&selection_img);
|
|
||||||
}
|
|
||||||
if(i == inventory->selected) {
|
|
||||||
dimage(SLOT_X + (i % SLOT_COLUMNS) * SLOT_SPACING,
|
|
||||||
SLOT_Y + (i / SLOT_COLUMNS) * SLOT_SPACING,
|
|
||||||
&selected_img);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for(i = 0; i < 3; i++) {
|
|
||||||
dsubimage(SLOT_X_EQUIPPED, SLOT_Y + i * SLOT_SPACING, &items_img,
|
|
||||||
inventory->equipped[i].i * SLOT_W, 0, SLOT_W, SLOT_H,
|
|
||||||
DIMAGE_NONE);
|
|
||||||
}
|
|
||||||
#if GINT_RENDER_RGB
|
#if GINT_RENDER_RGB
|
||||||
/* Render the player between the two swords if we are on cg. */
|
dsubimage(272 + (i % SLOT_COLUMNS) * 32,
|
||||||
dimage(183, 20,
|
87 + (i / SLOT_COLUMNS) * 32, &items_img,
|
||||||
player->is_male ? &player_male_inv_img : &player_female_inv_img);
|
inventory->slots[i].i * 28, 0, 28, 27, DIMAGE_NONE);
|
||||||
|
#else
|
||||||
|
dsubimage(88 + (i % SLOT_COLUMNS) * 12,
|
||||||
|
24 + (i / SLOT_COLUMNS) * 12, &items_img,
|
||||||
|
inventory->slots[i].i * 8, 0, 8, 8, DIMAGE_NONE);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
/* TODO: Stats. */
|
#if GINT_RENDER_RGB
|
||||||
}
|
dsubimage(222, 87, &items_img, inventory->talisman.i * 28, 0, 28, 27,
|
||||||
|
DIMAGE_NONE);
|
||||||
char inventory_add(Inventory *inventory, Item item) {
|
dsubimage(222, 87 + 32, &items_img, inventory->armor.i * 28, 0, 28, 27,
|
||||||
size_t i;
|
DIMAGE_NONE);
|
||||||
for(i = 0; i < SLOT_NUM; i++) {
|
dsubimage(222, 87 + 64, &items_img, inventory->weapon.i * 28, 0, 28, 27,
|
||||||
if(!inventory->slots[i].i) {
|
DIMAGE_NONE);
|
||||||
inventory->slots[i].i = item;
|
#else
|
||||||
inventory->slots[i].durability = 255;
|
dsubimage(72, 24, &items_img, inventory->talisman.i * 8, 0, 8, 8,
|
||||||
return 0;
|
DIMAGE_NONE);
|
||||||
}
|
dsubimage(72, 24 + 12, &items_img, inventory->armor.i * 8, 0, 8, 8,
|
||||||
}
|
DIMAGE_NONE);
|
||||||
return 1;
|
dsubimage(72, 24 + 24, &items_img, inventory->weapon.i * 8, 0, 8, 8,
|
||||||
}
|
DIMAGE_NONE);
|
||||||
|
#endif
|
||||||
void inventory_move_from_selected(Inventory *inventory) {
|
#if GINT_RENDER_RGB
|
||||||
if(inventory->selected < 0)
|
dimage(183, 20,
|
||||||
return;
|
game->player.is_male ? &player_male_inv_img
|
||||||
Slot current = inventory->slots[inventory->selection];
|
: &player_female_inv_img);
|
||||||
Slot new = inventory->slots[inventory->selected];
|
#endif
|
||||||
inventory->slots[inventory->selection] = new;
|
|
||||||
inventory->slots[inventory->selected] = current;
|
|
||||||
}
|
|
||||||
|
|
||||||
void inventory_use(Inventory *inventory, Player *player) {
|
|
||||||
Item item = inventory->slots[inventory->selection].i;
|
|
||||||
switch(item_types[item]) {
|
|
||||||
case IT_TALISMAN:
|
|
||||||
inventory->equipped[0] = inventory->slots[inventory->selection];
|
|
||||||
break;
|
|
||||||
case IT_ARMOR:
|
|
||||||
inventory->equipped[1] = inventory->slots[inventory->selection];
|
|
||||||
break;
|
|
||||||
case IT_WEAPON:
|
|
||||||
inventory->equipped[2] = inventory->slots[inventory->selection];
|
|
||||||
break;
|
|
||||||
case IT_FOOD:
|
|
||||||
/* TODO */
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
inventory->slots[inventory->selection].i = I_NONE;
|
|
||||||
inventory->slots[inventory->selection].durability = 255;
|
|
||||||
}
|
|
||||||
|
|
||||||
void inventory_unequip(Inventory *inventory, ItemType type) {
|
|
||||||
if(inventory->slots[inventory->selection].i)
|
|
||||||
return;
|
|
||||||
switch(type) {
|
|
||||||
case IT_TALISMAN:
|
|
||||||
inventory->slots[inventory->selection] = inventory->equipped[0];
|
|
||||||
inventory->equipped[0].i = I_NONE;
|
|
||||||
inventory->equipped[0].durability = 255;
|
|
||||||
break;
|
|
||||||
case IT_ARMOR:
|
|
||||||
inventory->slots[inventory->selection] = inventory->equipped[1];
|
|
||||||
inventory->equipped[1].i = I_NONE;
|
|
||||||
inventory->equipped[1].durability = 255;
|
|
||||||
break;
|
|
||||||
case IT_WEAPON:
|
|
||||||
inventory->slots[inventory->selection] = inventory->equipped[2];
|
|
||||||
inventory->equipped[2].i = I_NONE;
|
|
||||||
inventory->equipped[2].durability = 255;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void inventory_move_selection(Inventory *inventory, Direction direction) {
|
|
||||||
switch(direction) {
|
|
||||||
case D_UP:
|
|
||||||
inventory->selection -= SLOT_COLUMNS;
|
|
||||||
if(inventory->selection < 0)
|
|
||||||
inventory->selection = 0;
|
|
||||||
break;
|
|
||||||
case D_DOWN:
|
|
||||||
inventory->selection += SLOT_COLUMNS;
|
|
||||||
if(inventory->selection >= SLOT_NUM) {
|
|
||||||
inventory->selection = SLOT_NUM - 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case D_LEFT:
|
|
||||||
if(inventory->selection > 0) {
|
|
||||||
inventory->selection--;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case D_RIGHT:
|
|
||||||
if(inventory->selection < SLOT_NUM - 1) {
|
|
||||||
inventory->selection++;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,12 +4,6 @@
|
||||||
/* The structs related to the inventory are defined in game.h */
|
/* The structs related to the inventory are defined in game.h */
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
|
|
||||||
void inventory_init(Inventory *inventory);
|
void inventory_draw(Game *game, Inventory *inventory);
|
||||||
void inventory_draw(Inventory *inventory, Player *player);
|
|
||||||
char inventory_add(Inventory *inventory, Item item);
|
|
||||||
void inventory_move_from_selected(Inventory *inventory);
|
|
||||||
void inventory_use(Inventory *inventory, Player *player);
|
|
||||||
void inventory_unequip(Inventory *inventory, ItemType type);
|
|
||||||
void inventory_move_selection(Inventory *inventory, Direction direction);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue