diff options
Diffstat (limited to 'src/sars.h')
-rw-r--r-- | src/sars.h | 13 |
1 files changed, 11 insertions, 2 deletions
@@ -30,12 +30,21 @@ typedef enum sars_context_t { SARS_CONTEXT_CNT } sars_context_t; +typedef enum sars_winmode_t { + SARS_WINMODE_WINDOW, /* windowed in the ideal aspect ratio (may be letterboxed if resized or --window WxH) */ + SARS_WINMODE_FULLSCREEN, /* fullscreened, in the ideal aspect ratio (likely letterboxed) */ + SARS_WINMODE_FILLSCREEN, /* fullscreened, in the screen's aspect ratio (likely stretched) */ + SARS_WINMODE_CNT +} sars_winmode_t; + typedef struct sars_t { SDL_Window *window; SDL_GLContext *gl; stage_t *stage; unsigned window_width, window_height; - unsigned windowed:1; + sars_winmode_t winmode; + + m4f_t projection_x; } sars_t; void sars_canvas_size(sars_t *sars, int *res_width, int *res_height); @@ -45,8 +54,8 @@ void sars_viewport_size(sars_t *sars, int *res_width, int *res_height); void sars_viewport_to_ndc(sars_t *sars, int x, int y, float *res_x, float *res_y); void sars_viewport_from_ndc(sars_t *sars, float x, float y, int *res_x, int *res_y); uint32_t sars_viewport_id(sars_t *sars); -void sars_toggle_fullscreen(sars_t *sars); void sars_render(play_t *play, void *context); void sars_dispatch(play_t *play, void *context, SDL_Event *event); +sars_winmode_t sars_winmode_set(sars_t *sars, sars_winmode_t winmode); #endif |