mirror of
https://git.planet-casio.com/Slyvtt/Collab_RPG.git
synced 2025-01-01 14:33:39 +01:00
Compare commits
No commits in common. "1767643da1d987c90b4fbbab8968761d27e5148e" and "84043e31e7da7fe037b5351c65dcee93f0d4a651" have entirely different histories.
1767643da1
...
84043e31e7
6 changed files with 57 additions and 65 deletions
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 |
41
assets/WorldRPG.world
Normal file
41
assets/WorldRPG.world
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
{
|
||||||
|
"maps": [
|
||||||
|
{
|
||||||
|
"fileName": "level0.tmx",
|
||||||
|
"height": 192,
|
||||||
|
"width": 384,
|
||||||
|
"x": 0,
|
||||||
|
"y": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fileName": "level1.tmx",
|
||||||
|
"height": 192,
|
||||||
|
"width": 384,
|
||||||
|
"x": 384,
|
||||||
|
"y": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fileName": "level2.tmx",
|
||||||
|
"height": 192,
|
||||||
|
"width": 384,
|
||||||
|
"x": 0,
|
||||||
|
"y": 192
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fileName": "level3.tmx",
|
||||||
|
"height": 192,
|
||||||
|
"width": 384,
|
||||||
|
"x": 384,
|
||||||
|
"y": 192
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fileName": "level4.tmx",
|
||||||
|
"height": 192,
|
||||||
|
"width": 384,
|
||||||
|
"x": 384,
|
||||||
|
"y": 384
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"onlyShowAdjacentMaps": false,
|
||||||
|
"type": "world"
|
||||||
|
}
|
|
@ -269,8 +269,8 @@ void game_get_inputs(Game *game) {
|
||||||
if(mynpc) {
|
if(mynpc) {
|
||||||
mynpc->curx = (player->x << PRECISION) / PXSIZE;
|
mynpc->curx = (player->x << PRECISION) / PXSIZE;
|
||||||
mynpc->cury = (player->y << PRECISION) / PXSIZE;
|
mynpc->cury = (player->y << PRECISION) / PXSIZE;
|
||||||
mynpc->x = 0;
|
mynpc->x = player->x;
|
||||||
mynpc->y = 0;
|
mynpc->y = player->x;
|
||||||
mynpc->hasPath = 0;
|
mynpc->hasPath = 0;
|
||||||
mynpc->owns_path = false;
|
mynpc->owns_path = false;
|
||||||
mynpc->face = 0;
|
mynpc->face = 0;
|
||||||
|
|
71
src/npc.c
71
src/npc.c
|
@ -74,7 +74,7 @@ int npc_clear_path(NPC *npc) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int npc_append_path(int16_t x, int16_t y, NPC *npc) {
|
int npc_append_path(uint16_t x, uint16_t y, NPC *npc) {
|
||||||
npc->xpath = realloc(npc->xpath, npc->path_length * 2 + 2);
|
npc->xpath = realloc(npc->xpath, npc->path_length * 2 + 2);
|
||||||
npc->ypath = realloc(npc->ypath, npc->path_length * 2 + 2);
|
npc->ypath = realloc(npc->ypath, npc->path_length * 2 + 2);
|
||||||
if(npc->xpath == NULL || npc->ypath == NULL)
|
if(npc->xpath == NULL || npc->ypath == NULL)
|
||||||
|
@ -91,50 +91,6 @@ void as_clean(uint8_t *visited, uint8_t *gscore, uint8_t *fscore) {
|
||||||
free(fscore);
|
free(fscore);
|
||||||
}
|
}
|
||||||
|
|
||||||
int npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc){
|
|
||||||
uint8_t *map = full_map->walkable;
|
|
||||||
uint32_t w = full_map->w;
|
|
||||||
uint32_t h = full_map->h;
|
|
||||||
uint32_t sx = npc_from_curxy(npc->curx);
|
|
||||||
uint32_t sy = npc_from_curxy(npc->cury);
|
|
||||||
dest_x /= PXSIZE;
|
|
||||||
dest_y /= PXSIZE;
|
|
||||||
|
|
||||||
if(dest_x < 0 || dest_y < 0 || dest_x >= w*T_WIDTH || dest_y >= h*T_HEIGHT)
|
|
||||||
return 2;
|
|
||||||
|
|
||||||
/*if(map[dest_y*w + dest_x])
|
|
||||||
return 2;
|
|
||||||
if(map[sy*w + sx])
|
|
||||||
return 2;*/
|
|
||||||
|
|
||||||
if(!npc->owns_path || npc->path_length > 64)
|
|
||||||
npc_clear_path(npc);
|
|
||||||
|
|
||||||
/*int bx;
|
|
||||||
int by;
|
|
||||||
int bscore = 0x7FFFFFFF;
|
|
||||||
|
|
||||||
for(int i = sx-1; i < sx+2; i++){
|
|
||||||
for(int j = sy-1; j < sy+2; j++){
|
|
||||||
int tscore = (dest_x-sx)*(dest_x-sx) + (dest_y-sy)*(dest_y-sy);
|
|
||||||
if(tscore < bscore){
|
|
||||||
bscore = tscore;
|
|
||||||
bx = i;
|
|
||||||
by = j;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(bscore == 0x7FFFFFFF) return 3;*/
|
|
||||||
|
|
||||||
if(npc_append_path(dest_x,dest_y, npc))
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
npc->hasPath = true;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int as_reconstruct_path(int16_t *came_from, int w, int h, int16_t start,
|
int as_reconstruct_path(int16_t *came_from, int w, int h, int16_t start,
|
||||||
int16_t dest, bool is_alloc, NPC *npc) {
|
int16_t dest, bool is_alloc, NPC *npc) {
|
||||||
if(npc_clear_path(npc))
|
if(npc_clear_path(npc))
|
||||||
|
@ -176,8 +132,8 @@ int as_reconstruct_path(int16_t *came_from, int w, int h, int16_t start,
|
||||||
npc->ypath[npc->path_length - i - 1] = ty;
|
npc->ypath[npc->path_length - i - 1] = ty;
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
/*if(is_alloc)
|
if(is_alloc)
|
||||||
free(came_from);*/
|
free(came_from);
|
||||||
|
|
||||||
npc->hasPath = true;
|
npc->hasPath = true;
|
||||||
|
|
||||||
|
@ -185,8 +141,8 @@ int as_reconstruct_path(int16_t *came_from, int w, int h, int16_t start,
|
||||||
|
|
||||||
as_recons_fail:
|
as_recons_fail:
|
||||||
|
|
||||||
/*if(is_alloc)
|
if(is_alloc)
|
||||||
free(came_from);*/
|
free(came_from);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -194,8 +150,8 @@ as_recons_fail:
|
||||||
uint32_t xyram = 0xe500e000 + 32;
|
uint32_t xyram = 0xe500e000 + 32;
|
||||||
|
|
||||||
/* Custom a* implemetation
|
/* Custom a* implemetation
|
||||||
* Borked, use npc_pathfind instead*/
|
* Unoptimized, may become an issue */
|
||||||
int __npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc) {
|
int npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc) {
|
||||||
int32_t i, j;
|
int32_t i, j;
|
||||||
|
|
||||||
int32_t w = full_map->w/T_WIDTH/PXSIZE;
|
int32_t w = full_map->w/T_WIDTH/PXSIZE;
|
||||||
|
@ -224,7 +180,7 @@ int __npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc) {
|
||||||
|
|
||||||
bool is_alloc;
|
bool is_alloc;
|
||||||
|
|
||||||
if(isSH3() || w * h * 5 > 1024 * 15) {
|
if(1 || isSH3() || w * h * 5 > 1024 * 15) {
|
||||||
is_alloc = true;
|
is_alloc = true;
|
||||||
|
|
||||||
visited = malloc(w * h);
|
visited = malloc(w * h);
|
||||||
|
@ -286,9 +242,9 @@ int __npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc) {
|
||||||
bscore = fscore[i];
|
bscore = fscore[i];
|
||||||
}
|
}
|
||||||
if(bx == dest_x && by == dest_y) {
|
if(bx == dest_x && by == dest_y) {
|
||||||
if(is_alloc) as_clean(visited, gscore, fscore);
|
as_clean(visited, gscore, fscore);
|
||||||
return 0; /*as_reconstruct_path(came_from, w, h, spos,
|
return 0; /*as_reconstruct_path(came_from, w, h, spos,
|
||||||
dest_y * w + dest_x, is_alloc npc)*/
|
dest_y * w + dest_x, npc)*/
|
||||||
}
|
}
|
||||||
|
|
||||||
visited[by * w + bx] = 1;
|
visited[by * w + bx] = 1;
|
||||||
|
@ -318,10 +274,9 @@ int __npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(is_alloc){
|
as_clean(visited, gscore, fscore);
|
||||||
as_clean(visited, gscore, fscore);
|
|
||||||
free(came_from);
|
free(came_from);
|
||||||
}
|
|
||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,10 +10,6 @@
|
||||||
/*Maximum iterations before the pathfinding considers the target unreacheable*/
|
/*Maximum iterations before the pathfinding considers the target unreacheable*/
|
||||||
#define PATHFIND_MAX_ITER 64
|
#define PATHFIND_MAX_ITER 64
|
||||||
|
|
||||||
#define npc_from_curxy(a) (((a)>>PRECISION)/PXSIZE)
|
|
||||||
|
|
||||||
#define npc_to_curxy(a) (((a)*PXSIZE)<<PRECISION)
|
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
|
||||||
NPC_NONE = 0,
|
NPC_NONE = 0,
|
||||||
|
@ -45,7 +41,7 @@ int npc_clear_path(NPC *npc);
|
||||||
/* Adds point x,y to the path of npc
|
/* Adds point x,y to the path of npc
|
||||||
* Won't work on static NPCs, use npc_clear_path before or make them on the
|
* Won't work on static NPCs, use npc_clear_path before or make them on the
|
||||||
* heap */
|
* heap */
|
||||||
int npc_append_path(int16_t x, int16_t y, NPC *npc);
|
int npc_append_path(uint16_t x, uint16_t y, NPC *npc);
|
||||||
|
|
||||||
/* Clears the NPCs path and creates a new one going to dest,
|
/* Clears the NPCs path and creates a new one going to dest,
|
||||||
* avoiding non-walkable tiles
|
* avoiding non-walkable tiles
|
||||||
|
|
Loading…
Reference in a new issue