Cleaned a bit of the tile code. Built train station
This commit is contained in:
@ -13,6 +13,7 @@ set(DAWN_TARGET_NAME "Dawn")
|
|||||||
|
|
||||||
if(NOT DEFINED DAWN_TARGET)
|
if(NOT DEFINED DAWN_TARGET)
|
||||||
set(DAWN_TARGET linux-x64-glfw CACHE INTERNAL ${DAWN_CACHE_TARGET})
|
set(DAWN_TARGET linux-x64-glfw CACHE INTERNAL ${DAWN_CACHE_TARGET})
|
||||||
|
# set(DAWN_TARGET linux-x64-terminal CACHE INTERNAL ${DAWN_CACHE_TARGET})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Set Common Build Variables
|
# Set Common Build Variables
|
||||||
|
39
assets/maps/train_station.tmx
Normal file
39
assets/maps/train_station.tmx
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<map version="1.10" tiledversion="1.11.0" orientation="orthogonal" renderorder="right-down" width="40" height="30" tilewidth="8" tileheight="8" infinite="0" nextlayerid="3" nextobjectid="1">
|
||||||
|
<tileset firstgid="1" source="../tilemaps/tilemap.tsx"/>
|
||||||
|
<layer id="1" name="Tile Layer 1" width="40" height="30" offsetx="-10" offsety="-0.333333">
|
||||||
|
<data encoding="csv">
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,12,13,12,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,13,13,13,0,0,0,13,13,13,0,0,0,13,13,13,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,15,0,0,12,13,15,0,12,13,12,15,0,0,0,0,15,0,0,0,0,0,0,15,0,0,0,0,15,0,0,0,0,15,0,0,0,0,
|
||||||
|
10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,
|
||||||
|
8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,
|
||||||
|
8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,
|
||||||
|
10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,8,8,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,
|
||||||
|
0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,0,0,0,11,0,0,0,0,0,
|
||||||
|
0,0,0,0,11,0,12,13,12,11,12,13,12,0,11,0,0,0,0,11,0,9,9,0,11,0,0,0,0,11,0,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,11,8,12,13,12,11,12,13,12,8,11,8,8,8,8,11,8,9,9,8,11,8,8,8,8,11,8,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,15,8,8,8,8,9,9,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,8,8,12,13,12,0,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,8,8,12,13,12,10,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,14,6,6,6,6,6,0,0,0,0,
|
||||||
|
0,0,10,8,15,8,12,13,12,8,12,13,12,8,8,8,15,8,8,8,8,8,8,8,8,8,8,8,8,8,14,5,5,5,5,5,0,0,0,0,
|
||||||
|
0,0,10,8,8,8,12,13,12,8,12,13,12,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,5,5,5,5,5,0,0,0,0,
|
||||||
|
0,0,10,10,10,10,12,13,12,10,12,13,12,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
|
||||||
|
0,0,0,0,0,0,12,13,12,0,12,13,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
|
||||||
|
</data>
|
||||||
|
</layer>
|
||||||
|
<objectgroup id="2" name="Entities"/>
|
||||||
|
</map>
|
@ -3,8 +3,9 @@
|
|||||||
"height": 4300,
|
"height": 4300,
|
||||||
"width": 2
|
"width": 2
|
||||||
},
|
},
|
||||||
"activeFile": "",
|
"activeFile": "maps/train_station.tmx",
|
||||||
"expandedProjectPaths": [
|
"expandedProjectPaths": [
|
||||||
|
"maps",
|
||||||
"."
|
"."
|
||||||
],
|
],
|
||||||
"file.lastUsedOpenFilter": "All Files (*)",
|
"file.lastUsedOpenFilter": "All Files (*)",
|
||||||
@ -23,16 +24,27 @@
|
|||||||
"scale": 3.404166666666667,
|
"scale": 3.404166666666667,
|
||||||
"selectedLayer": 1,
|
"selectedLayer": 1,
|
||||||
"viewCenter": {
|
"viewCenter": {
|
||||||
"x": 116.328029375765,
|
"x": 120.1468788249694,
|
||||||
"y": 79.90208078335371
|
"y": 79.75520195838433
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"maps/testmap2.tmx": {
|
"maps/testmap2.tmx": {
|
||||||
|
"expandedObjectLayers": [
|
||||||
|
2
|
||||||
|
],
|
||||||
"scale": 5.0383,
|
"scale": 5.0383,
|
||||||
"selectedLayer": 1,
|
"selectedLayer": 1,
|
||||||
"viewCenter": {
|
"viewCenter": {
|
||||||
"x": 33.940019451005305,
|
"x": 19.94720441418733,
|
||||||
"y": 35.726336264216116
|
"y": 19.947204414187325
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"maps/train_station.tmx": {
|
||||||
|
"scale": 3,
|
||||||
|
"selectedLayer": 0,
|
||||||
|
"viewCenter": {
|
||||||
|
"x": 67.66666666666666,
|
||||||
|
"y": 49.333333333333314
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"testmap.tmx": {
|
"testmap.tmx": {
|
||||||
@ -54,21 +66,32 @@
|
|||||||
"tilemap.tsx": {
|
"tilemap.tsx": {
|
||||||
"scaleInDock": 1,
|
"scaleInDock": 1,
|
||||||
"scaleInEditor": 4
|
"scaleInEditor": 4
|
||||||
|
},
|
||||||
|
"tilemaps/entities.tsx": {
|
||||||
|
"scaleInDock": 1
|
||||||
|
},
|
||||||
|
"tilemaps/tilemap.tsx": {
|
||||||
|
"scaleInDock": 1
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"last.externalTilesetPath": "/home/yourwishes/htdocs/Dawn/assets",
|
"last.externalTilesetPath": "/home/yourwishes/htdocs/Dawn/assets",
|
||||||
"last.imagePath": "/home/yourwishes/htdocs/Dawn/assets",
|
"last.imagePath": "/home/yourwishes/htdocs/Dawn/assets",
|
||||||
"map.height": 5,
|
"map.height": 10,
|
||||||
"map.lastUsedFormat": "tmx",
|
"map.lastUsedFormat": "tmx",
|
||||||
"map.tileHeight": 8,
|
"map.tileHeight": 8,
|
||||||
"map.tileWidth": 8,
|
"map.tileWidth": 8,
|
||||||
"map.width": 5,
|
"map.width": 10,
|
||||||
"openFiles": [
|
"openFiles": [
|
||||||
|
"maps/testmap.tmx",
|
||||||
|
"maps/testmap2.tmx",
|
||||||
|
"maps/train_station.tmx"
|
||||||
],
|
],
|
||||||
"project": "tiled_project.tiled-project",
|
"project": "tiled_project.tiled-project",
|
||||||
"property.type": "string",
|
"property.type": "string",
|
||||||
"recentFiles": [
|
"recentFiles": [
|
||||||
"maps/testmap2.tmx"
|
"maps/testmap.tmx",
|
||||||
|
"maps/testmap2.tmx",
|
||||||
|
"maps/train_station.tmx"
|
||||||
],
|
],
|
||||||
"tileset.lastUsedFilter": "All Files (*)",
|
"tileset.lastUsedFilter": "All Files (*)",
|
||||||
"tileset.lastUsedFormat": "tsx",
|
"tileset.lastUsedFormat": "tsx",
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 322 B After Width: | Height: | Size: 408 B |
@ -165,6 +165,14 @@ TILES = {
|
|||||||
"BUILDING_WALL": [ 4, '-', COLORS["GRAY"] ],
|
"BUILDING_WALL": [ 4, '-', COLORS["GRAY"] ],
|
||||||
"ROOF": [ 5, '/', COLORS["BROWN"] ],
|
"ROOF": [ 5, '/', COLORS["BROWN"] ],
|
||||||
"WALKABLE_NULL": [ 6, ' ', COLORS["BLACK"] ],
|
"WALKABLE_NULL": [ 6, ' ', COLORS["BLACK"] ],
|
||||||
|
"COBBLESTONE": [ 7, '#', COLORS["GRAY"] ],
|
||||||
|
"STAIRS": [ 8, '=', COLORS["GRAY"] ],
|
||||||
|
"RAILING": [ 9, 'n', COLORS["BROWN"] ],
|
||||||
|
"COLUMN": [ 10, 'I', COLORS["WHITE"] ],
|
||||||
|
"RAIL_TRACK": [ 11, '|', COLORS["GRAY"] ],
|
||||||
|
"RAIL_SLEEPER": [ 12, '-', COLORS["BROWN"] ],
|
||||||
|
"CARPET": [ 13, '#', COLORS["RED"] ],
|
||||||
|
"LAMP": [ 14, 'i', COLORS["YELLOW"] ],
|
||||||
}
|
}
|
||||||
|
|
||||||
ENTITIES = {
|
ENTITIES = {
|
||||||
@ -222,5 +230,5 @@ def genTileset(filename, tileset, background):
|
|||||||
# Now write PIXEL_BUFFER to png
|
# Now write PIXEL_BUFFER to png
|
||||||
png.from_array(FLATTENED_PIXEL_BUFFER, 'RGBA').save(filename)
|
png.from_array(FLATTENED_PIXEL_BUFFER, 'RGBA').save(filename)
|
||||||
|
|
||||||
genTileset("./assets/map/tilemap.png", TILES, [ 0, 0, 0, 255 ])
|
genTileset("./assets/tilemaps/tilemap.png", TILES, [ 0, 0, 0, 255 ])
|
||||||
genTileset("./assets/map/entities.png", ENTITIES, [ 0, 0, 0, 100 ])
|
genTileset("./assets/tilemaps/entities.png", ENTITIES, [ 0, 0, 0, 100 ])
|
@ -34,6 +34,7 @@ target_sources(${DAWN_TARGET_NAME}
|
|||||||
# Assets
|
# Assets
|
||||||
tool_map(testmap maps/testmap.tmx)
|
tool_map(testmap maps/testmap.tmx)
|
||||||
tool_map(testmap2 maps/testmap2.tmx)
|
tool_map(testmap2 maps/testmap2.tmx)
|
||||||
|
tool_map(train_station maps/train_station.tmx)
|
||||||
tool_copy(en en.json)
|
tool_copy(en en.json)
|
||||||
|
|
||||||
add_dependencies(${DAWN_TARGET_NAME} dawnassets)
|
add_dependencies(${DAWN_TARGET_NAME} dawnassets)
|
||||||
|
@ -84,8 +84,8 @@ void drawMap(
|
|||||||
|
|
||||||
// Tile?
|
// Tile?
|
||||||
tile = mapTileGetByPosition(map, x - offsetX, y - offsetY, 0);
|
tile = mapTileGetByPosition(map, x - offsetX, y - offsetY, 0);
|
||||||
colorDest[x] = symbolGetColorByTile(tile);
|
colorDest[x] = tileColorGet(tile);
|
||||||
bufferDest[x] = symbolGetCharByTile(tile);
|
bufferDest[x] = tileSymbolGet(tile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -34,35 +34,6 @@ char_t symbolGetCharByEntity(const entity_t *ent) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char_t symbolGetCharByTile(const tile_t tile) {
|
|
||||||
switch(tile) {
|
|
||||||
case TILE_NULL:
|
|
||||||
case TILE_WALKABLE_NULL:
|
|
||||||
return ' ';
|
|
||||||
|
|
||||||
case TILE_GRASS:
|
|
||||||
return '#';
|
|
||||||
|
|
||||||
case TILE_WATER:
|
|
||||||
int32_t j = (int32_t)(TIME.time * 2) % 4;
|
|
||||||
switch(j) {
|
|
||||||
case 0: return '/';
|
|
||||||
case 1: return '|';
|
|
||||||
case 2: return '\\';
|
|
||||||
case 3: return '|';
|
|
||||||
}
|
|
||||||
|
|
||||||
case TILE_BUILDING_WALL:
|
|
||||||
return '-';
|
|
||||||
|
|
||||||
case TILE_ROOF:
|
|
||||||
return '/';
|
|
||||||
|
|
||||||
default:
|
|
||||||
assertUnreachable("Unknown char for tile.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t symbolGetColorByEntity(const entity_t *ent) {
|
uint8_t symbolGetColorByEntity(const entity_t *ent) {
|
||||||
assertNotNull(ent, "Entity cannot be NULL.");
|
assertNotNull(ent, "Entity cannot be NULL.");
|
||||||
switch(ent->type) {
|
switch(ent->type) {
|
||||||
@ -81,27 +52,4 @@ uint8_t symbolGetColorByEntity(const entity_t *ent) {
|
|||||||
default:
|
default:
|
||||||
assertUnreachable("Invalid entity type.");
|
assertUnreachable("Invalid entity type.");
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t symbolGetColorByTile(const tile_t tile) {
|
|
||||||
switch(tile) {
|
|
||||||
case TILE_NULL:
|
|
||||||
case TILE_WALKABLE_NULL:
|
|
||||||
return COLOR_BLACK;
|
|
||||||
|
|
||||||
case TILE_GRASS:
|
|
||||||
return COLOR_GREEN;
|
|
||||||
|
|
||||||
case TILE_WATER:
|
|
||||||
return COLOR_BLUE;
|
|
||||||
|
|
||||||
case TILE_BUILDING_WALL:
|
|
||||||
return COLOR_GRAY;
|
|
||||||
|
|
||||||
case TILE_ROOF:
|
|
||||||
return COLOR_BROWN;
|
|
||||||
|
|
||||||
default:
|
|
||||||
assertUnreachable("Unknown color for tile.");
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -7,7 +7,6 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "rpg/entity/entity.h"
|
#include "rpg/entity/entity.h"
|
||||||
#include "rpg/world/tile.h"
|
|
||||||
#include "display/color.h"
|
#include "display/color.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -18,26 +17,10 @@
|
|||||||
*/
|
*/
|
||||||
char_t symbolGetCharByEntity(const entity_t *ent);
|
char_t symbolGetCharByEntity(const entity_t *ent);
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the symbol for the given tile.
|
|
||||||
*
|
|
||||||
* @param tile Tile to get the symbol for.
|
|
||||||
* @return The symbol for the tile.
|
|
||||||
*/
|
|
||||||
char_t symbolGetCharByTile(const tile_t tile);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the color for the given entity.
|
* Returns the color for the given entity.
|
||||||
*
|
*
|
||||||
* @param ent Entity to get the color for.
|
* @param ent Entity to get the color for.
|
||||||
* @return The color for the entity.
|
* @return The color for the entity.
|
||||||
*/
|
*/
|
||||||
uint8_t symbolGetColorByEntity(const entity_t *ent);
|
uint8_t symbolGetColorByEntity(const entity_t *ent);
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the color for the given tile.
|
|
||||||
*
|
|
||||||
* @param tile Tile to get the color for.
|
|
||||||
* @return The color for the tile.
|
|
||||||
*/
|
|
||||||
uint8_t symbolGetColorByTile(const tile_t tile);
|
|
@ -72,6 +72,8 @@ gameupdateresult_t gameUpdate(const float_t delta) {
|
|||||||
printf("Updating unknown state %d\n", GAME.state);
|
printf("Updating unknown state %d\n", GAME.state);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(inputWasPressed(INPUT_BIND_FORCE_QUIT)) GAME.shouldExit = true;
|
||||||
|
|
||||||
// Perform render.
|
// Perform render.
|
||||||
displayUpdate();
|
displayUpdate();
|
||||||
|
|
||||||
|
@ -8,23 +8,29 @@
|
|||||||
#include "mapchange.h"
|
#include "mapchange.h"
|
||||||
#include "asset/assetmap.h"
|
#include "asset/assetmap.h"
|
||||||
#include "game/game.h"
|
#include "game/game.h"
|
||||||
|
#include "util/memory.h"
|
||||||
|
|
||||||
void gameStateMapChangeUpdate() {
|
void gameStateMapChangeUpdate() {
|
||||||
// First try and find the player object
|
// First try and find the player object
|
||||||
entity_t *player = NULL;
|
entity_t *player = NULL;
|
||||||
|
player_t oldPlayerData;
|
||||||
entitydirection_t dir = ENTITY_DIRECTION_SOUTH;
|
entitydirection_t dir = ENTITY_DIRECTION_SOUTH;
|
||||||
if(GAME.currentMap != NULL) {
|
if(GAME.currentMap != NULL) {
|
||||||
player = mapEntityGetByType(GAME.currentMap, ENTITY_TYPE_PLAYER);
|
player = mapEntityGetByType(GAME.currentMap, ENTITY_TYPE_PLAYER);
|
||||||
dir = player->direction;
|
dir = player->direction;
|
||||||
|
oldPlayerData = player->player;
|
||||||
}
|
}
|
||||||
|
|
||||||
assetMapLoad(MAP_LIST_PATHS[GAME.mapNext], &MAP_MAIN);
|
assetMapLoad(MAP_LIST_PATHS[GAME.mapNext], &MAP_MAIN);
|
||||||
GAME.state = GAME_STATE_OVERWORLD;
|
GAME.state = GAME_STATE_OVERWORLD;
|
||||||
GAME.currentMap = &MAP_MAIN;
|
GAME.currentMap = &MAP_MAIN;
|
||||||
|
|
||||||
// Do not reference player since its invalid, just check if it DID exist
|
// Do not reference player since its invalid, just check if it DID exist
|
||||||
if(GAME.currentMap != NULL && player != NULL) {
|
if(GAME.currentMap != NULL && player != NULL) {
|
||||||
player = mapEntityGetByType(GAME.currentMap, ENTITY_TYPE_PLAYER);
|
player = mapEntityGetByType(GAME.currentMap, ENTITY_TYPE_PLAYER);
|
||||||
|
if(player == NULL) return;
|
||||||
|
|
||||||
|
player->player = oldPlayerData;
|
||||||
player->direction = dir;
|
player->direction = dir;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -18,8 +18,9 @@ typedef bool_t inputstate_t;
|
|||||||
#define INPUT_BIND_ACCEPT 0x04
|
#define INPUT_BIND_ACCEPT 0x04
|
||||||
#define INPUT_BIND_CANCEL 0x05
|
#define INPUT_BIND_CANCEL 0x05
|
||||||
#define INPUT_BIND_PAUSE 0x06
|
#define INPUT_BIND_PAUSE 0x06
|
||||||
|
#define INPUT_BIND_FORCE_QUIT 0x07
|
||||||
|
|
||||||
#define INPUT_BIND_COUNT (INPUT_BIND_PAUSE + 1)
|
#define INPUT_BIND_COUNT (INPUT_BIND_FORCE_QUIT + 1)
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
inputstate_t currentState[INPUT_BIND_COUNT];
|
inputstate_t currentState[INPUT_BIND_COUNT];
|
||||||
|
@ -11,11 +11,11 @@
|
|||||||
#include "rpg/world/trigger.h"
|
#include "rpg/world/trigger.h"
|
||||||
#include "maplist.h"
|
#include "maplist.h"
|
||||||
|
|
||||||
#define MAP_WIDTH_MAX 2048
|
#define MAP_WIDTH_MAX 512
|
||||||
#define MAP_HEIGHT_MAX 2048
|
#define MAP_HEIGHT_MAX 512
|
||||||
#define MAP_LAYERS_MAX 1
|
#define MAP_LAYERS_MAX 1
|
||||||
#define MAP_ENTITIES_MAX 256
|
#define MAP_ENTITIES_MAX 64
|
||||||
#define MAP_TRIGGERS_MAX 64
|
#define MAP_TRIGGERS_MAX 32
|
||||||
|
|
||||||
typedef struct _map_t {
|
typedef struct _map_t {
|
||||||
tile_t tiles[MAP_WIDTH_MAX * MAP_HEIGHT_MAX * MAP_LAYERS_MAX];
|
tile_t tiles[MAP_WIDTH_MAX * MAP_HEIGHT_MAX * MAP_LAYERS_MAX];
|
||||||
|
@ -10,7 +10,8 @@
|
|||||||
|
|
||||||
const char_t * MAP_LIST_PATHS[] = {
|
const char_t * MAP_LIST_PATHS[] = {
|
||||||
"testmap.map",
|
"testmap.map",
|
||||||
"testmap2.map"
|
"testmap2.map",
|
||||||
|
"train_station.map"
|
||||||
};
|
};
|
||||||
|
|
||||||
const int32_t MAP_LIST_COUNT = sizeof(MAP_LIST_PATHS) / sizeof(char_t*);
|
const int32_t MAP_LIST_COUNT = sizeof(MAP_LIST_PATHS) / sizeof(char_t*);
|
||||||
|
@ -9,7 +9,9 @@
|
|||||||
#include "dawn.h"
|
#include "dawn.h"
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
MAP_LIST_TEST
|
MAP_LIST_TEST = 0,
|
||||||
|
MAP_LIST_TEST2 = 1,
|
||||||
|
MAP_LIST_TRAIN_STATION = 2,
|
||||||
} maplist_t;
|
} maplist_t;
|
||||||
|
|
||||||
extern const char_t *MAP_LIST_PATHS[];
|
extern const char_t *MAP_LIST_PATHS[];
|
||||||
|
@ -6,6 +6,67 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "tile.h"
|
#include "tile.h"
|
||||||
|
#include "assert/assert.h"
|
||||||
|
#include "game/time.h"
|
||||||
|
|
||||||
|
const char_t TILE_SYMBOLS[] = {
|
||||||
|
' ',// NULL
|
||||||
|
'#',
|
||||||
|
'/',
|
||||||
|
' ',
|
||||||
|
'-',// BUILDING_WALL
|
||||||
|
'/',
|
||||||
|
' ',
|
||||||
|
'#',
|
||||||
|
'=',// STAIRS
|
||||||
|
'n',
|
||||||
|
'I',
|
||||||
|
'|',
|
||||||
|
'-',// RAIL_SLEEPER
|
||||||
|
'#',
|
||||||
|
'i'
|
||||||
|
};
|
||||||
|
|
||||||
|
const uint8_t TILE_COLORS[] = {
|
||||||
|
COLOR_BLACK,// NULL
|
||||||
|
COLOR_GREEN,
|
||||||
|
COLOR_BLUE,
|
||||||
|
COLOR_MAGENTA,
|
||||||
|
COLOR_GRAY,// BUILDING_WALL
|
||||||
|
COLOR_BROWN,
|
||||||
|
COLOR_BLACK,
|
||||||
|
COLOR_GRAY,
|
||||||
|
COLOR_GRAY, // STAIRS
|
||||||
|
COLOR_BROWN,
|
||||||
|
COLOR_WHITE,
|
||||||
|
COLOR_GRAY,
|
||||||
|
COLOR_BROWN,// RAIL_SLEEPER
|
||||||
|
COLOR_RED,
|
||||||
|
COLOR_YELLOW
|
||||||
|
};
|
||||||
|
|
||||||
|
char_t tileSymbolGet(const tile_t tile) {
|
||||||
|
switch(tile) {
|
||||||
|
case TILE_WATER:
|
||||||
|
int32_t j = (int32_t)(TIME.time * 2) % 4;
|
||||||
|
switch(j) {
|
||||||
|
case 0: return '/';
|
||||||
|
case 1: return '|';
|
||||||
|
case 2: return '\\';
|
||||||
|
case 3: return '|';
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
return TILE_SYMBOLS[tile];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t tileColorGet(const tile_t tile) {
|
||||||
|
switch(tile) {
|
||||||
|
default:
|
||||||
|
return TILE_COLORS[tile];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool_t tileIsSolid(const tile_t tile) {
|
bool_t tileIsSolid(const tile_t tile) {
|
||||||
switch(tile) {
|
switch(tile) {
|
||||||
|
@ -6,18 +6,44 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "dawn.h"
|
#include "display/color.h"
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
TILE_NULL = 0,
|
TILE_NULL = 0,
|
||||||
TILE_GRASS = 1,
|
TILE_GRASS = 1,
|
||||||
TILE_WATER = 2,
|
TILE_WATER = 2,
|
||||||
// TILE_DOOR = 3,
|
|
||||||
TILE_BUILDING_WALL = 4,
|
TILE_BUILDING_WALL = 4,
|
||||||
TILE_ROOF = 5,
|
TILE_ROOF = 5,
|
||||||
TILE_WALKABLE_NULL = 6,
|
TILE_WALKABLE_NULL = 6,
|
||||||
|
TILE_COBBLESTONE = 7,
|
||||||
|
TILE_STAIRS = 8,
|
||||||
|
TILE_RAILING = 9,
|
||||||
|
TILE_COLUMN = 10,
|
||||||
|
TILE_RAIL_TRACK = 11,
|
||||||
|
TILE_RAIL_SLEEPER = 12,
|
||||||
|
TILE_CARPET = 13,
|
||||||
|
TILE_LAMP = 14
|
||||||
} tile_t;
|
} tile_t;
|
||||||
|
|
||||||
|
extern const char_t TILE_SYMBOLS[];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the symbol used by the given tile.
|
||||||
|
*
|
||||||
|
* @param tile Tile to get the symbol of.
|
||||||
|
* @return The symbol for this tile.
|
||||||
|
*/
|
||||||
|
char_t tileSymbolGet(const tile_t tile);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the color used by a given tile.
|
||||||
|
*
|
||||||
|
* @param tile Tile to get the color of.
|
||||||
|
* @return The color of this tile.
|
||||||
|
*/
|
||||||
|
uint8_t tileColorGet(const tile_t tile);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns whether or not the tile is solid.
|
* Returns whether or not the tile is solid.
|
||||||
*
|
*
|
||||||
|
@ -38,7 +38,7 @@ void mainMenuSelectCallback(
|
|||||||
) {
|
) {
|
||||||
// New Game
|
// New Game
|
||||||
if(y == 0) {
|
if(y == 0) {
|
||||||
GAME.mapNext = MAP_LIST_TEST;
|
GAME.mapNext = MAP_LIST_TRAIN_STATION;
|
||||||
GAME.state = GAME_STATE_MAP_CHANGE;
|
GAME.state = GAME_STATE_MAP_CHANGE;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -88,6 +88,7 @@ int32_t dawnGlfwStart() {
|
|||||||
dawnGlfwInputBind(INPUT_BIND_PAUSE, GLFW_KEY_P);
|
dawnGlfwInputBind(INPUT_BIND_PAUSE, GLFW_KEY_P);
|
||||||
dawnGlfwInputBind(INPUT_BIND_CANCEL, GLFW_KEY_Q);
|
dawnGlfwInputBind(INPUT_BIND_CANCEL, GLFW_KEY_Q);
|
||||||
dawnGlfwInputBind(INPUT_BIND_CANCEL, GLFW_KEY_BACKSPACE);
|
dawnGlfwInputBind(INPUT_BIND_CANCEL, GLFW_KEY_BACKSPACE);
|
||||||
|
dawnGlfwInputBind(INPUT_BIND_FORCE_QUIT, GLFW_KEY_BACKSLASH);
|
||||||
|
|
||||||
// Event callbacks
|
// Event callbacks
|
||||||
glfwSetFramebufferSizeCallback(DAWN_GLFW.window, &dawnGlfwOnResize);
|
glfwSetFramebufferSizeCallback(DAWN_GLFW.window, &dawnGlfwOnResize);
|
||||||
|
@ -56,6 +56,14 @@ void displayUpdate() {
|
|||||||
color = TERM_COLOR_CYAN;
|
color = TERM_COLOR_CYAN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case COLOR_GRAY:
|
||||||
|
color = TERM_COLOR_GRAY;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case COLOR_BROWN:
|
||||||
|
color = TERM_COLOR_BROWN;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
assertUnreachable("Invalid color.");
|
assertUnreachable("Invalid color.");
|
||||||
}
|
}
|
||||||
|
@ -16,5 +16,7 @@
|
|||||||
#define TERM_COLOR_YELLOW "\x1b[33m"
|
#define TERM_COLOR_YELLOW "\x1b[33m"
|
||||||
#define TERM_COLOR_MAGENTA "\x1b[35m"
|
#define TERM_COLOR_MAGENTA "\x1b[35m"
|
||||||
#define TERM_COLOR_CYAN "\x1b[36m"
|
#define TERM_COLOR_CYAN "\x1b[36m"
|
||||||
|
#define TERM_COLOR_GRAY "\x1b[90m"
|
||||||
|
#define TERM_COLOR_BROWN "\x1b[33m"
|
||||||
|
|
||||||
#define TERM_COLOR_RESET "\x1b[0m"
|
#define TERM_COLOR_RESET "\x1b[0m"
|
@ -10,7 +10,6 @@
|
|||||||
|
|
||||||
inputstate_t inputGetState(const inputbind_t bind) {
|
inputstate_t inputGetState(const inputbind_t bind) {
|
||||||
int32_t k = LINUX_TERM_HOST_KEY_PRESS;
|
int32_t k = LINUX_TERM_HOST_KEY_PRESS;
|
||||||
|
|
||||||
if(k == -1) return false;
|
if(k == -1) return false;
|
||||||
|
|
||||||
switch(bind) {
|
switch(bind) {
|
||||||
@ -32,6 +31,12 @@ inputstate_t inputGetState(const inputbind_t bind) {
|
|||||||
case INPUT_BIND_CANCEL:
|
case INPUT_BIND_CANCEL:
|
||||||
return k == 'q';
|
return k == 'q';
|
||||||
|
|
||||||
|
case INPUT_BIND_PAUSE:
|
||||||
|
return k == 'p';
|
||||||
|
|
||||||
|
case INPUT_BIND_FORCE_QUIT:
|
||||||
|
return k == '\\';
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,8 @@ for layer in root.findall('layer'):
|
|||||||
for i in range(0, len(data)):
|
for i in range(0, len(data)):
|
||||||
# minus 1 because tiled is 1 indexed
|
# minus 1 because tiled is 1 indexed
|
||||||
tileId = int(data[i]) - 1
|
tileId = int(data[i]) - 1
|
||||||
|
if(int(data[i]) == 0):
|
||||||
|
tileId = 0
|
||||||
layerOut["tiles"].append(tileId)
|
layerOut["tiles"].append(tileId)
|
||||||
|
|
||||||
output["layers"].append(layerOut)
|
output["layers"].append(layerOut)
|
||||||
|
Reference in New Issue
Block a user