Continue menu
This commit is contained in:
parent
6e8badf4b1
commit
5d30b9d600
4 changed files with 48 additions and 26 deletions
6
assets.h
6
assets.h
|
@ -25,9 +25,9 @@ static const char *LCR_texts[] =
|
||||||
"play repl",
|
"play repl",
|
||||||
|
|
||||||
// main menu items:
|
// main menu items:
|
||||||
"camera",
|
"camera: $",
|
||||||
"music",
|
"music: $",
|
||||||
"sound",
|
"sound: $",
|
||||||
"save repl",
|
"save repl",
|
||||||
"exit",
|
"exit",
|
||||||
|
|
||||||
|
|
19
audio.h
19
audio.h
|
@ -17,6 +17,7 @@
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
uint32_t frame;
|
uint32_t frame;
|
||||||
|
uint8_t on;
|
||||||
uint8_t soundPlayed;
|
uint8_t soundPlayed;
|
||||||
uint16_t soundPlayedFrame;
|
uint16_t soundPlayedFrame;
|
||||||
uint32_t noise;
|
uint32_t noise;
|
||||||
|
@ -38,19 +39,14 @@ void LCR_audioInit(void)
|
||||||
{
|
{
|
||||||
LCR_LOG0("initializing audio");
|
LCR_LOG0("initializing audio");
|
||||||
LCR_audio.frame = 0;
|
LCR_audio.frame = 0;
|
||||||
|
LCR_audio.on = 1;
|
||||||
LCR_audio.soundPlayed = LCR_SOUND_NONE;
|
LCR_audio.soundPlayed = LCR_SOUND_NONE;
|
||||||
LCR_audio.soundPlayedFrame = 0;
|
LCR_audio.soundPlayedFrame = 0;
|
||||||
LCR_audio.noise = 0;
|
LCR_audio.noise = 0;
|
||||||
|
LCR_audio.crashSample = 0;
|
||||||
LCR_audio.crashSample = 0;
|
LCR_audio.engineOsc = 0;
|
||||||
|
LCR_audio.engineInc = 1;
|
||||||
LCR_audio.engineOsc = 0;
|
LCR_audio.engineIntensity = 0;
|
||||||
|
|
||||||
LCR_audio.engineInc = 1;
|
|
||||||
|
|
||||||
LCR_audio.engineIntensity = 0;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void LCR_audioSetEngineIntensity(uint8_t value)
|
void LCR_audioSetEngineIntensity(uint8_t value)
|
||||||
|
@ -75,6 +71,9 @@ uint8_t LCR_audioGetNextSample(void)
|
||||||
{
|
{
|
||||||
unsigned char result = 128;
|
unsigned char result = 128;
|
||||||
|
|
||||||
|
if (!LCR_audio.on)
|
||||||
|
return result;
|
||||||
|
|
||||||
switch (LCR_audio.soundPlayed)
|
switch (LCR_audio.soundPlayed)
|
||||||
{
|
{
|
||||||
case LCR_SOUND_CRASH_SMALL:
|
case LCR_SOUND_CRASH_SMALL:
|
||||||
|
|
|
@ -26,11 +26,14 @@ void LCR_appendResourceStr(const char *str)
|
||||||
|
|
||||||
void audioFillCallback(void *userdata, uint8_t *s, int l)
|
void audioFillCallback(void *userdata, uint8_t *s, int l)
|
||||||
{
|
{
|
||||||
if (musicFile)
|
if (musicFile && LCR_gameMusicOn())
|
||||||
{
|
{
|
||||||
if (!fread(s,1,l,musicFile))
|
if (!fread(s,1,l,musicFile))
|
||||||
rewind(musicFile);
|
rewind(musicFile);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
for (int i = 0; i < l; ++i)
|
||||||
|
s[i] = 128;
|
||||||
|
|
||||||
for (int i = 0; i < l; ++i)
|
for (int i = 0; i < l; ++i)
|
||||||
s[i] = s[i] / 2 + LCR_gameGetNextAudioSample() / 2;
|
s[i] = s[i] / 2 + LCR_gameGetNextAudioSample() / 2;
|
||||||
|
|
44
game.h
44
game.h
|
@ -61,7 +61,7 @@
|
||||||
- Call the below described functions as described.
|
- Call the below described functions as described.
|
||||||
- If you want to support music, make your frontend play music from the "music"
|
- If you want to support music, make your frontend play music from the "music"
|
||||||
file in assets. It is in raw format, storing 8bit unsigned samples at 8000
|
file in assets. It is in raw format, storing 8bit unsigned samples at 8000
|
||||||
Hz. Use the LCR_gameGetMusicVolume to check what the music volume is. If you
|
Hz. Use the LCR_gameMusicOn to check what the music volume is. If you
|
||||||
don't support music, set LCR_SETTING_MUSIC to 0 in your frontend code so
|
don't support music, set LCR_SETTING_MUSIC to 0 in your frontend code so
|
||||||
that the game knows music is disabled.
|
that the game knows music is disabled.
|
||||||
*/
|
*/
|
||||||
|
@ -138,7 +138,7 @@ uint8_t LCR_gameStep(uint32_t timeMs);
|
||||||
/**
|
/**
|
||||||
Gets the current music volume;
|
Gets the current music volume;
|
||||||
*/
|
*/
|
||||||
uint8_t LCR_gameGetMusicVolume(void);
|
uint8_t LCR_gameMusicOn(void);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Gets next audio sample (unsigned 8bit samples, 8 KHz).
|
Gets next audio sample (unsigned 8bit samples, 8 KHz).
|
||||||
|
@ -147,6 +147,8 @@ uint8_t LCR_gameGetNextAudioSample(void);
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "settings.h"
|
||||||
|
|
||||||
#define LCR_LOG0(s) ;
|
#define LCR_LOG0(s) ;
|
||||||
#define LCR_LOG1(s) ;
|
#define LCR_LOG1(s) ;
|
||||||
#define LCR_LOG2(s) ;
|
#define LCR_LOG2(s) ;
|
||||||
|
@ -194,7 +196,7 @@ struct
|
||||||
uint32_t nextRacingTickTime;
|
uint32_t nextRacingTickTime;
|
||||||
uint8_t controlMode;
|
uint8_t controlMode;
|
||||||
uint8_t debugDraw;
|
uint8_t debugDraw;
|
||||||
uint8_t musicVolume;
|
uint8_t musicOn;
|
||||||
uint8_t keyStates[LCR_KEYS_TOTAL]; /**< Assures unchanging key states
|
uint8_t keyStates[LCR_KEYS_TOTAL]; /**< Assures unchanging key states
|
||||||
during a single frame, hold number of
|
during a single frame, hold number of
|
||||||
frames for which the key has been
|
frames for which the key has been
|
||||||
|
@ -218,10 +220,10 @@ const char *menuItemNamePointers[LCR_MENU_MAX_ITEMS];
|
||||||
} resourceFile;
|
} resourceFile;
|
||||||
} LCR_game;
|
} LCR_game;
|
||||||
|
|
||||||
uint8_t LCR_gameGetMusicVolume(void)
|
uint8_t LCR_gameMusicOn(void)
|
||||||
{
|
{
|
||||||
#if LCR_SETTING_MUSIC
|
#if LCR_SETTING_MUSIC
|
||||||
return LCR_game.musicVolume;
|
return LCR_game.musicOn;
|
||||||
#else
|
#else
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
@ -399,11 +401,11 @@ LCR_game.menuItemCount = 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void LCR_gameSetMenuItemStr(uint8_t item, const char *str)
|
void LCR_gameSetMenuItemStr(uint8_t item, const char *str, char replaceChar)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < LCR_MENU_STRING_SIZE - 1; ++i)
|
for (int i = 0; i < LCR_MENU_STRING_SIZE - 1; ++i)
|
||||||
{
|
{
|
||||||
LCR_game.menuItemNames[item][i] = str[i];
|
LCR_game.menuItemNames[item][i] = str[i] == '$' ? replaceChar : str[i];
|
||||||
LCR_game.menuItemNames[item][i + 1] = 0;
|
LCR_game.menuItemNames[item][i + 1] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -411,7 +413,12 @@ void LCR_gameSetMenuItemStr(uint8_t item, const char *str)
|
||||||
void LCR_gameLoadMainMenuItems(void)
|
void LCR_gameLoadMainMenuItems(void)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 5; ++i)
|
for (int i = 0; i < 5; ++i)
|
||||||
LCR_gameSetMenuItemStr(i,LCR_texts[4 + i]);
|
{
|
||||||
|
char replaceChar = i == 0 ? 'X' :
|
||||||
|
(i == 1 ? '0' + LCR_game.musicOn : ('0' + LCR_audio.on));
|
||||||
|
|
||||||
|
LCR_gameSetMenuItemStr(i,LCR_texts[4 + i],replaceChar);
|
||||||
|
}
|
||||||
|
|
||||||
LCR_game.menuItemCount = 4;
|
LCR_game.menuItemCount = 4;
|
||||||
}
|
}
|
||||||
|
@ -433,17 +440,17 @@ void LCR_gameInit(void)
|
||||||
for (int i = 0; i < LCR_MENU_MAX_ITEMS; ++i)
|
for (int i = 0; i < LCR_MENU_MAX_ITEMS; ++i)
|
||||||
LCR_game.menuItemNamePointers[i] = LCR_game.menuItemNames[i];
|
LCR_game.menuItemNamePointers[i] = LCR_game.menuItemNames[i];
|
||||||
|
|
||||||
LCR_gameLoadMainMenuItems();
|
|
||||||
|
|
||||||
LCR_game.menuSelectedTab = 0;
|
LCR_game.menuSelectedTab = 0;
|
||||||
LCR_game.menuSelectedItem = 0;
|
LCR_game.menuSelectedItem = 0;
|
||||||
|
|
||||||
LCR_game.frame = 0;
|
LCR_game.frame = 0;
|
||||||
LCR_game.musicVolume = 255;
|
LCR_game.musicOn = 1;
|
||||||
LCR_game.nextRenderFrameTime = 0;
|
LCR_game.nextRenderFrameTime = 0;
|
||||||
LCR_game.nextRacingTickTime = 0;
|
LCR_game.nextRacingTickTime = 0;
|
||||||
LCR_game.controlMode = LCR_CONTROL_MODE_DRIVE;
|
LCR_game.controlMode = LCR_CONTROL_MODE_DRIVE;
|
||||||
|
|
||||||
|
LCR_gameLoadMainMenuItems();
|
||||||
|
|
||||||
LCR_gameSetState(LCR_GAME_STATE_MENU);
|
LCR_gameSetState(LCR_GAME_STATE_MENU);
|
||||||
|
|
||||||
LCR_currentMap.blockCount = 0; // means no map loaded
|
LCR_currentMap.blockCount = 0; // means no map loaded
|
||||||
|
@ -677,6 +684,17 @@ void LCR_gameHandleInput(void)
|
||||||
case 0:
|
case 0:
|
||||||
switch (LCR_game.menuSelectedItem)
|
switch (LCR_game.menuSelectedItem)
|
||||||
{
|
{
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
LCR_game.musicOn = !LCR_game.musicOn;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
LCR_audio.on = !LCR_audio.on;
|
||||||
|
break;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
LCR_gameSetState(LCR_GAME_STATE_END);
|
LCR_gameSetState(LCR_GAME_STATE_END);
|
||||||
break;
|
break;
|
||||||
|
@ -684,6 +702,7 @@ void LCR_gameHandleInput(void)
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LCR_gameLoadMainMenuItems();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
|
@ -708,6 +727,7 @@ void LCR_gameHandleInput(void)
|
||||||
{
|
{
|
||||||
LCR_LOG1("menu open");
|
LCR_LOG1("menu open");
|
||||||
LCR_gameSetState(LCR_GAME_STATE_MENU);
|
LCR_gameSetState(LCR_GAME_STATE_MENU);
|
||||||
|
LCR_game.menuSelectedItem = 0;
|
||||||
}
|
}
|
||||||
else if (LCR_game.keyStates[LCR_KEY_A] == 1)
|
else if (LCR_game.keyStates[LCR_KEY_A] == 1)
|
||||||
LCR_gameResetRun();
|
LCR_gameResetRun();
|
||||||
|
@ -875,7 +895,7 @@ uint8_t LCR_gameStep(uint32_t time)
|
||||||
LCR_sleep(sleep);
|
LCR_sleep(sleep);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LCR_LOG1("can't sleep, frames take too long!");
|
LCR_LOG2("can't sleep");
|
||||||
}
|
}
|
||||||
|
|
||||||
LCR_game.frame++;
|
LCR_game.frame++;
|
||||||
|
|
Loading…
Reference in a new issue