Show info if your game has problems with sync #497
This commit is contained in:
parent
4f0b6dab37
commit
8f3e01a528
File diff suppressed because one or more lines are too long
BIN
config.tic
BIN
config.tic
Binary file not shown.
11
src/config.c
11
src/config.c
|
@ -66,6 +66,16 @@ static void readConfigNoSound(Config* config, lua_State* lua)
|
||||||
lua_pop(lua, 1);
|
lua_pop(lua, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void readConfigShowSync(Config* config, lua_State* lua)
|
||||||
|
{
|
||||||
|
lua_getglobal(lua, "SHOW_SYNC");
|
||||||
|
|
||||||
|
if(lua_isboolean(lua, -1))
|
||||||
|
config->data.showSync = lua_toboolean(lua, -1);
|
||||||
|
|
||||||
|
lua_pop(lua, 1);
|
||||||
|
}
|
||||||
|
|
||||||
static void readCursorTheme(Config* config, lua_State* lua)
|
static void readCursorTheme(Config* config, lua_State* lua)
|
||||||
{
|
{
|
||||||
lua_getfield(lua, -1, "CURSOR");
|
lua_getfield(lua, -1, "CURSOR");
|
||||||
|
@ -189,6 +199,7 @@ static void readConfig(Config* config)
|
||||||
readConfigVideoScale(config, lua);
|
readConfigVideoScale(config, lua);
|
||||||
readConfigCheckNewVersion(config, lua);
|
readConfigCheckNewVersion(config, lua);
|
||||||
readConfigNoSound(config, lua);
|
readConfigNoSound(config, lua);
|
||||||
|
readConfigShowSync(config, lua);
|
||||||
readTheme(config, lua);
|
readTheme(config, lua);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
51
src/studio.c
51
src/studio.c
|
@ -232,6 +232,7 @@ static struct
|
||||||
FileSystem* fs;
|
FileSystem* fs;
|
||||||
|
|
||||||
bool quitFlag;
|
bool quitFlag;
|
||||||
|
bool deSync;
|
||||||
|
|
||||||
s32 argc;
|
s32 argc;
|
||||||
char **argv;
|
char **argv;
|
||||||
|
@ -322,6 +323,7 @@ static struct
|
||||||
|
|
||||||
.fullscreen = false,
|
.fullscreen = false,
|
||||||
.quitFlag = false,
|
.quitFlag = false,
|
||||||
|
.deSync = false,
|
||||||
.argc = 0,
|
.argc = 0,
|
||||||
.argv = NULL,
|
.argv = NULL,
|
||||||
};
|
};
|
||||||
|
@ -2081,7 +2083,7 @@ static void blitSound()
|
||||||
else SDL_QueueAudio(studio.audio.device, studio.tic->samples.buffer, studio.tic->samples.size);
|
else SDL_QueueAudio(studio.audio.device, studio.tic->samples.buffer, studio.tic->samples.size);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void drawRecordLabel(u32* frame, s32 pitch, s32 sx, s32 sy, const u32* color)
|
static void drawRecordLabel(u32* frame, s32 sx, s32 sy, const u32* color)
|
||||||
{
|
{
|
||||||
static const u16 RecLabel[] =
|
static const u16 RecLabel[] =
|
||||||
{
|
{
|
||||||
|
@ -2102,6 +2104,35 @@ static void drawRecordLabel(u32* frame, s32 pitch, s32 sx, s32 sy, const u32* co
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void drawDesyncLabel(u32* frame)
|
||||||
|
{
|
||||||
|
static const u16 DesyncLabel[] =
|
||||||
|
{
|
||||||
|
0b0110101010010011,
|
||||||
|
0b1000101011010100,
|
||||||
|
0b1110111010110100,
|
||||||
|
0b0010001010010100,
|
||||||
|
0b1100110010010011,
|
||||||
|
};
|
||||||
|
|
||||||
|
if(studio.deSync && getConfig()->showSync)
|
||||||
|
{
|
||||||
|
enum{sx = TIC80_WIDTH-24, sy = 8, Cols = sizeof DesyncLabel[0]*BITS_IN_BYTE, Rows = COUNT_OF(DesyncLabel)};
|
||||||
|
|
||||||
|
const u32* pal = tic_palette_blit(&studio.tic->config.palette);
|
||||||
|
const u32* color = &pal[tic_color_red];
|
||||||
|
|
||||||
|
for(s32 y = 0; y < Rows; y++)
|
||||||
|
{
|
||||||
|
for(s32 x = 0; x < Cols; x++)
|
||||||
|
{
|
||||||
|
if(DesyncLabel[y] & (1 << x))
|
||||||
|
memcpy(&frame[sx + Cols - 1 - x + ((y+sy) << TIC80_FULLWIDTH_BITS)], color, sizeof *color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void recordFrame(u32* pixels)
|
static void recordFrame(u32* pixels)
|
||||||
{
|
{
|
||||||
if(studio.video.record)
|
if(studio.video.record)
|
||||||
|
@ -2114,7 +2145,7 @@ static void recordFrame(u32* pixels)
|
||||||
if(studio.video.frame % TIC_FRAMERATE < TIC_FRAMERATE / 2)
|
if(studio.video.frame % TIC_FRAMERATE < TIC_FRAMERATE / 2)
|
||||||
{
|
{
|
||||||
const u32* pal = tic_palette_blit(&studio.tic->config.palette);
|
const u32* pal = tic_palette_blit(&studio.tic->config.palette);
|
||||||
drawRecordLabel(pixels, TIC80_FULLWIDTH, TIC80_WIDTH-24, 8, &pal[tic_color_red]);
|
drawRecordLabel(pixels, TIC80_WIDTH-24, 8, &pal[tic_color_red]);
|
||||||
}
|
}
|
||||||
|
|
||||||
studio.video.frame++;
|
studio.video.frame++;
|
||||||
|
@ -2169,6 +2200,7 @@ static void blitTexture()
|
||||||
SDL_memcpy(pixels, tic->screen, sizeof tic->screen);
|
SDL_memcpy(pixels, tic->screen, sizeof tic->screen);
|
||||||
|
|
||||||
recordFrame(pixels);
|
recordFrame(pixels);
|
||||||
|
drawDesyncLabel(pixels);
|
||||||
|
|
||||||
SDL_UnlockTexture(studio.texture);
|
SDL_UnlockTexture(studio.texture);
|
||||||
|
|
||||||
|
@ -2766,17 +2798,24 @@ s32 main(s32 argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
while (!studio.quitFlag)
|
while (!studio.quitFlag)
|
||||||
{
|
{
|
||||||
nextTick += Delta;
|
nextTick += Delta;
|
||||||
tick();
|
tick();
|
||||||
|
|
||||||
if(SDL_GetWindowFlags(studio.window) & SDL_WINDOW_MINIMIZED || useTimer)
|
studio.deSync = false;
|
||||||
{
|
{
|
||||||
s64 delay = nextTick - SDL_GetPerformanceCounter();
|
s64 delay = nextTick - SDL_GetPerformanceCounter();
|
||||||
|
|
||||||
if(delay > 0)
|
if(delay > 0)
|
||||||
SDL_Delay((u32)(delay * 1000 / SDL_GetPerformanceFrequency()));
|
{
|
||||||
else nextTick -= delay;
|
if(SDL_GetWindowFlags(studio.window) & SDL_WINDOW_MINIMIZED || useTimer)
|
||||||
|
SDL_Delay((u32)(delay * 1000 / SDL_GetPerformanceFrequency()));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
nextTick -= delay;
|
||||||
|
studio.deSync = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,6 +101,7 @@ typedef struct
|
||||||
|
|
||||||
bool checkNewVersion;
|
bool checkNewVersion;
|
||||||
bool noSound;
|
bool noSound;
|
||||||
|
bool showSync;
|
||||||
|
|
||||||
} StudioConfig;
|
} StudioConfig;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue