Change file strcture: Add assets folder
Change file strcture to make creating a release easier: - files: move all resources needed by the executable to the folder assets - cmake: copy the assets folder to build folder after compilation - adjust all filepaths in source files
This commit is contained in:
parent
4ea40d99d2
commit
778c69f67a
@ -28,7 +28,6 @@ endif()
|
||||
|
||||
# --- Locate SDL2 ---
|
||||
# Uses SDL2_DIR on Windows, on Linux it's found automatically
|
||||
# Locate SDL2
|
||||
find_package(SDL2 REQUIRED)
|
||||
|
||||
# --- Locate SDL2_ttf ---
|
||||
@ -57,6 +56,7 @@ set(SOURCES
|
||||
)
|
||||
|
||||
|
||||
#--- executable ---
|
||||
add_executable(Snake ${SOURCES})
|
||||
|
||||
|
||||
@ -68,6 +68,10 @@ else()
|
||||
endif()
|
||||
|
||||
|
||||
# --- Copy assets to output folder ---
|
||||
file(COPY ${CMAKE_SOURCE_DIR}/assets DESTINATION ${CMAKE_BINARY_DIR})
|
||||
|
||||
|
||||
# --- Copy SDL2 DLLs to the output folder on Windows ---
|
||||
if(WIN32)
|
||||
foreach(DLL ${SDL2_DLLS} ${SDL2_TTF_DLLS})
|
||||
|
BIN
assets/player_scores.bin
Normal file
BIN
assets/player_scores.bin
Normal file
Binary file not shown.
@ -8,7 +8,7 @@ config_t config = {
|
||||
.cycleDurationMs = 400,
|
||||
.difficulty = 1,
|
||||
.snakeDefaultLength = 2,
|
||||
.leaderboardFilename = "",
|
||||
.leaderboardFilename = "player_scores.bin",
|
||||
//.defaultMapName = "default" //10x10
|
||||
.defaultMapName = "intermediate" //15x15
|
||||
//.defaultMapName = "empty" //20x10
|
||||
|
24
src/game.c
24
src/game.c
@ -23,10 +23,10 @@ gameData_t game = {
|
||||
|
||||
// list of audio files randomly played when food eaten
|
||||
const char *eatSounds[] = {
|
||||
"../sounds/eat-bite1.wav",
|
||||
"../sounds/eat-bite2.wav",
|
||||
"../sounds/eat-crunch1.wav",
|
||||
"../sounds/eat-crunch2.wav"};
|
||||
"assets/sounds/eat-bite1.wav",
|
||||
"assets/sounds/eat-bite2.wav",
|
||||
"assets/sounds/eat-crunch1.wav",
|
||||
"assets/sounds/eat-crunch2.wav"};
|
||||
#define EAT_SOUNDS_COUNT 4
|
||||
|
||||
|
||||
@ -76,11 +76,11 @@ void handlePortals()
|
||||
snakeSetHeadPos(p.targetX, p.targetY);
|
||||
LOGI("game: entered portal i=%d at x=%d, y=%d -> set head to x=%d y=%d\n", i, p.posX, p.posY, p.targetX, p.targetY);
|
||||
//--- play sound ---
|
||||
//playSoundAsync("../sounds/portal1_short.wav"); //too short
|
||||
//playSoundAsync("../sounds/portal2_oscillate.wav"); //too much bass
|
||||
//playSoundAsync("../sounds/space-gun.wav"); //too loud
|
||||
playSoundAsync("../sounds/portal3_in-out.wav");
|
||||
//playSoundAsync("../sounds/portal4_ramp.wav");
|
||||
//playSoundAsync("assets/sounds/portal1_short.wav"); //too short
|
||||
//playSoundAsync("assets/sounds/portal2_oscillate.wav"); //too much bass
|
||||
//playSoundAsync("assets/sounds/space-gun.wav"); //too loud
|
||||
playSoundAsync("assets/sounds/portal3_in-out.wav");
|
||||
//playSoundAsync("assets/sounds/portal4_ramp.wav");
|
||||
return;
|
||||
}
|
||||
}
|
||||
@ -111,12 +111,12 @@ void runGameCycle()
|
||||
// TODO consider game.lifesRemaining and reset if still good?
|
||||
//--- play crash sound ---
|
||||
LOGI("game: collided with wall or self! => show leaderboard\n");
|
||||
playSound("../sounds/crash_rock-cinematic.wav", false);
|
||||
playSound("assets/sounds/crash_rock-cinematic.wav", false);
|
||||
DELAY(200);
|
||||
//--- leaderboard ---
|
||||
//game.gameState = MENU; //TODO add config.collisionEnabled option?
|
||||
savePlayerScore("../build/player_scores.bin"/*(game.snake.length - config.snakeDefaultLength), ttlStorage.userName, config.difficulty, *storedMaps[ttlStorage.userSelectedMap - 1]*/);
|
||||
readTopScores("../build/player_scores.bin");
|
||||
savePlayerScore(config.leaderboardFilename/*(game.snake.length - config.snakeDefaultLength), ttlStorage.userName, config.difficulty, *storedMaps[ttlStorage.userSelectedMap - 1]*/);
|
||||
readTopScores(config.leaderboardFilename);
|
||||
game.gameState = MENU;
|
||||
activeMenu = LEADERBOARD;
|
||||
return;
|
||||
|
@ -124,8 +124,8 @@ void renderStartMenu()
|
||||
//=========== only first loop ================
|
||||
if(ttlStorage.lastTimeStep == 0)
|
||||
{
|
||||
ttlStorage.ptrFont_200 = TTF_OpenFont("../fonts/Quirkus.ttf", ttlStorage.fontSize_200);
|
||||
ttlStorage.ptrFont_30 = TTF_OpenFont("../fonts/Quirkus.ttf", ttlStorage.fontSize_30);
|
||||
ttlStorage.ptrFont_200 = TTF_OpenFont("assets/fonts/Quirkus.ttf", ttlStorage.fontSize_200);
|
||||
ttlStorage.ptrFont_30 = TTF_OpenFont("assets/fonts/Quirkus.ttf", ttlStorage.fontSize_30);
|
||||
|
||||
|
||||
SDL_Color textColor1 = {255, 0, 255}; // rosa Text
|
||||
@ -240,7 +240,7 @@ void renderSettings()
|
||||
if(ttlStorage.lastTimeStep == 0)
|
||||
{
|
||||
printf("In first loop\n");
|
||||
ttlStorage.ptrFont_20 = TTF_OpenFont("../fonts/Prototype.ttf", ttlStorage.fontSize_20);
|
||||
ttlStorage.ptrFont_20 = TTF_OpenFont("assets/fonts/Prototype.ttf", ttlStorage.fontSize_20);
|
||||
SDL_StartTextInput(); // start text input
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user