mirror of https://github.com/snes9xgit/snes9x.git
Add -fullscreen option, which starts snes9x in fullscreen mode.
This commit is contained in:
parent
b02099f52b
commit
71648e7a86
73
unix/x11.cpp
73
unix/x11.cpp
|
@ -190,6 +190,7 @@
|
||||||
|
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
#include <X11/Xutil.h>
|
#include <X11/Xutil.h>
|
||||||
|
#include <X11/Xatom.h>
|
||||||
#include <X11/keysym.h>
|
#include <X11/keysym.h>
|
||||||
#include <X11/cursorfont.h>
|
#include <X11/cursorfont.h>
|
||||||
|
|
||||||
|
@ -239,6 +240,9 @@ struct GUIData
|
||||||
int mouse_y;
|
int mouse_y;
|
||||||
bool8 mod1_pressed;
|
bool8 mod1_pressed;
|
||||||
bool8 no_repeat;
|
bool8 no_repeat;
|
||||||
|
bool8 fullscreen;
|
||||||
|
int x_offset;
|
||||||
|
int y_offset;
|
||||||
#ifdef MITSHM
|
#ifdef MITSHM
|
||||||
XShmSegmentInfo sm_info;
|
XShmSegmentInfo sm_info;
|
||||||
bool8 use_shared_memory;
|
bool8 use_shared_memory;
|
||||||
|
@ -293,6 +297,8 @@ void S9xExtraDisplayUsage (void)
|
||||||
|
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-setrepeat Allow altering keyboard auto-repeat");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-setrepeat Allow altering keyboard auto-repeat");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "");
|
S9xMessage(S9X_INFO, S9X_USAGE, "");
|
||||||
|
S9xMessage(S9X_INFO, S9X_USAGE, "-fullscreen Switch to full-screen on start");
|
||||||
|
S9xMessage(S9X_INFO, S9X_USAGE, "");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-v1 Video mode: Blocky (default)");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-v1 Video mode: Blocky (default)");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-v2 Video mode: TV");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-v2 Video mode: TV");
|
||||||
S9xMessage(S9X_INFO, S9X_USAGE, "-v3 Video mode: Smooth");
|
S9xMessage(S9X_INFO, S9X_USAGE, "-v3 Video mode: Smooth");
|
||||||
|
@ -309,6 +315,9 @@ void S9xParseDisplayArg (char **argv, int &i, int argc)
|
||||||
if (!strcasecmp(argv[i], "-setrepeat"))
|
if (!strcasecmp(argv[i], "-setrepeat"))
|
||||||
GUI.no_repeat = FALSE;
|
GUI.no_repeat = FALSE;
|
||||||
else
|
else
|
||||||
|
if (!strcasecmp(argv[i], "-fullscreen"))
|
||||||
|
GUI.fullscreen = TRUE;
|
||||||
|
else
|
||||||
if (!strncasecmp(argv[i], "-v", 2))
|
if (!strncasecmp(argv[i], "-v", 2))
|
||||||
{
|
{
|
||||||
switch (argv[i][2])
|
switch (argv[i][2])
|
||||||
|
@ -467,6 +476,7 @@ const char * S9xParseDisplayConfig (ConfigFile &conf, int pass)
|
||||||
}
|
}
|
||||||
|
|
||||||
GUI.no_repeat = !conf.GetBool("Unix/X11::SetKeyRepeat", TRUE);
|
GUI.no_repeat = !conf.GetBool("Unix/X11::SetKeyRepeat", TRUE);
|
||||||
|
GUI.fullscreen = conf.GetBool("Unix/X11::Fullscreen", FALSE);
|
||||||
|
|
||||||
if (conf.Exists("Unix/X11::VideoMode"))
|
if (conf.Exists("Unix/X11::VideoMode"))
|
||||||
{
|
{
|
||||||
|
@ -569,16 +579,51 @@ void S9xInitDisplay (int argc, char **argv)
|
||||||
S9xBlit2xSaIFilterInit();
|
S9xBlit2xSaIFilterInit();
|
||||||
S9xBlitHQ2xFilterInit();
|
S9xBlitHQ2xFilterInit();
|
||||||
|
|
||||||
|
/* Set up parameters for creating the window */
|
||||||
XSetWindowAttributes attrib;
|
XSetWindowAttributes attrib;
|
||||||
|
|
||||||
memset(&attrib, 0, sizeof(attrib));
|
memset(&attrib, 0, sizeof(attrib));
|
||||||
attrib.background_pixel = BlackPixelOfScreen(GUI.screen);
|
attrib.background_pixel = BlackPixelOfScreen(GUI.screen);
|
||||||
attrib.colormap = XCreateColormap(GUI.display, RootWindowOfScreen(GUI.screen), GUI.visual, AllocNone);
|
attrib.colormap = XCreateColormap(GUI.display, RootWindowOfScreen(GUI.screen), GUI.visual, AllocNone);
|
||||||
|
|
||||||
GUI.window = XCreateWindow(GUI.display, RootWindowOfScreen(GUI.screen),
|
/* Try to switch to Fullscreen. */
|
||||||
(WidthOfScreen(GUI.screen) - SNES_WIDTH * 2) / 2, (HeightOfScreen(GUI.screen) - SNES_HEIGHT_EXTENDED * 2) / 2,
|
if (GUI.fullscreen == TRUE)
|
||||||
SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2, 0, GUI.depth, InputOutput, GUI.visual, CWBackPixel | CWColormap, &attrib);
|
{
|
||||||
|
/* Create the window with maximum screen width,height positioned at 0,0. */
|
||||||
|
GUI.window = XCreateWindow(GUI.display, RootWindowOfScreen(GUI.screen),
|
||||||
|
0, 0,
|
||||||
|
WidthOfScreen(GUI.screen), HeightOfScreen(GUI.screen), 0,
|
||||||
|
GUI.depth, InputOutput, GUI.visual, CWBackPixel | CWColormap, &attrib);
|
||||||
|
|
||||||
|
/* Try to tell the Window Manager not to decorate this window. */
|
||||||
|
Atom wm_state = XInternAtom (GUI.display, "_NET_WM_STATE", true );
|
||||||
|
Atom wm_fullscreen = XInternAtom (GUI.display, "_NET_WM_STATE_FULLSCREEN", true );
|
||||||
|
|
||||||
|
XChangeProperty(GUI.display, GUI.window, wm_state, XA_ATOM, 32, PropModeReplace, (unsigned char *)&wm_fullscreen, 1);
|
||||||
|
|
||||||
|
/* Last: position the output window in the center of the screen. */
|
||||||
|
GUI.x_offset = (WidthOfScreen(GUI.screen) - SNES_WIDTH * 2) / 2;
|
||||||
|
GUI.y_offset = (HeightOfScreen(GUI.screen) - SNES_HEIGHT_EXTENDED * 2) / 2;
|
||||||
|
} else {
|
||||||
|
/* Create the window. */
|
||||||
|
GUI.window = XCreateWindow(GUI.display, RootWindowOfScreen(GUI.screen),
|
||||||
|
(WidthOfScreen(GUI.screen) - SNES_WIDTH * 2) / 2, (HeightOfScreen(GUI.screen) - SNES_HEIGHT_EXTENDED * 2) / 2,
|
||||||
|
SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2, 0, GUI.depth, InputOutput, GUI.visual, CWBackPixel | CWColormap, &attrib);
|
||||||
|
|
||||||
|
/* Tell the Window Manager that we do not wish to be resizable */
|
||||||
|
XSizeHints Hints;
|
||||||
|
memset((void *) &Hints, 0, sizeof(XSizeHints));
|
||||||
|
|
||||||
|
Hints.flags = PSize | PMinSize | PMaxSize;
|
||||||
|
Hints.min_width = Hints.max_width = Hints.base_width = SNES_WIDTH * 2;
|
||||||
|
Hints.min_height = Hints.max_height = Hints.base_height = SNES_HEIGHT_EXTENDED * 2;
|
||||||
|
XSetWMNormalHints(GUI.display, GUI.window, &Hints);
|
||||||
|
|
||||||
|
/* Last: Windowed SNES is not drawn with any offsets. */
|
||||||
|
GUI.x_offset = GUI.y_offset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Load UI cursors */
|
||||||
static XColor bg, fg;
|
static XColor bg, fg;
|
||||||
static char data[8] = { 0, 0, 0, 0, 0, 0, 0, 0 };
|
static char data[8] = { 0, 0, 0, 0, 0, 0, 0, 0 };
|
||||||
Pixmap bitmap;
|
Pixmap bitmap;
|
||||||
|
@ -590,22 +635,19 @@ void S9xInitDisplay (int argc, char **argv)
|
||||||
|
|
||||||
GUI.gc = DefaultGCOfScreen(GUI.screen);
|
GUI.gc = DefaultGCOfScreen(GUI.screen);
|
||||||
|
|
||||||
XSizeHints Hints;
|
/* Other window-manager hints */
|
||||||
XWMHints WMHints;
|
XWMHints WMHints;
|
||||||
|
|
||||||
memset((void *) &Hints, 0, sizeof(XSizeHints));
|
|
||||||
memset((void *) &WMHints, 0, sizeof(XWMHints));
|
memset((void *) &WMHints, 0, sizeof(XWMHints));
|
||||||
|
|
||||||
Hints.flags = PSize | PMinSize | PMaxSize;
|
/* Rely on the Window Manager to provide us with keyboard input */
|
||||||
Hints.min_width = Hints.max_width = Hints.base_width = SNES_WIDTH * 2;
|
|
||||||
Hints.min_height = Hints.max_height = Hints.base_height = SNES_HEIGHT_EXTENDED * 2;
|
|
||||||
WMHints.input = True;
|
WMHints.input = True;
|
||||||
WMHints.flags = InputHint;
|
WMHints.flags = InputHint;
|
||||||
|
|
||||||
XSetWMHints(GUI.display, GUI.window, &WMHints);
|
XSetWMHints(GUI.display, GUI.window, &WMHints);
|
||||||
XSetWMNormalHints(GUI.display, GUI.window, &Hints);
|
|
||||||
XSelectInput(GUI.display, GUI.window, FocusChangeMask | ExposureMask | KeyPressMask | KeyReleaseMask | StructureNotifyMask | ButtonPressMask | ButtonReleaseMask);
|
XSelectInput(GUI.display, GUI.window, FocusChangeMask | ExposureMask | KeyPressMask | KeyReleaseMask | StructureNotifyMask | ButtonPressMask | ButtonReleaseMask);
|
||||||
|
|
||||||
|
/* Bring up our window (and put it in foreground) */
|
||||||
XMapRaised(GUI.display, GUI.window);
|
XMapRaised(GUI.display, GUI.window);
|
||||||
XClearWindow(GUI.display, GUI.window);
|
XClearWindow(GUI.display, GUI.window);
|
||||||
|
|
||||||
|
@ -634,10 +676,13 @@ void S9xInitDisplay (int argc, char **argv)
|
||||||
|
|
||||||
void S9xDeinitDisplay (void)
|
void S9xDeinitDisplay (void)
|
||||||
{
|
{
|
||||||
S9xTextMode();
|
|
||||||
TakedownImage();
|
TakedownImage();
|
||||||
XSync(GUI.display, False);
|
if (GUI.display != NULL)
|
||||||
XCloseDisplay(GUI.display);
|
{
|
||||||
|
S9xTextMode();
|
||||||
|
XSync(GUI.display, False);
|
||||||
|
XCloseDisplay(GUI.display);
|
||||||
|
}
|
||||||
S9xBlitFilterDeinit();
|
S9xBlitFilterDeinit();
|
||||||
S9xBlit2xSaIFilterDeinit();
|
S9xBlit2xSaIFilterDeinit();
|
||||||
S9xBlitHQ2xFilterDeinit();
|
S9xBlitHQ2xFilterDeinit();
|
||||||
|
@ -969,12 +1014,12 @@ static void Repaint (bool8 isFrameBoundry)
|
||||||
#ifdef MITSHM
|
#ifdef MITSHM
|
||||||
if (GUI.use_shared_memory)
|
if (GUI.use_shared_memory)
|
||||||
{
|
{
|
||||||
XShmPutImage(GUI.display, GUI.window, GUI.gc, GUI.image, 0, 0, 0, 0, SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2, False);
|
XShmPutImage(GUI.display, GUI.window, GUI.gc, GUI.image, 0, 0, GUI.x_offset, GUI.y_offset, SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2, False);
|
||||||
XSync(GUI.display, False);
|
XSync(GUI.display, False);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
XPutImage(GUI.display, GUI.window, GUI.gc, GUI.image, 0, 0, 0, 0, SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2);
|
XPutImage(GUI.display, GUI.window, GUI.gc, GUI.image, 0, 0, GUI.x_offset, GUI.y_offset, SNES_WIDTH * 2, SNES_HEIGHT_EXTENDED * 2);
|
||||||
|
|
||||||
Window root, child;
|
Window root, child;
|
||||||
int root_x, root_y, x, y;
|
int root_x, root_y, x, y;
|
||||||
|
|
Loading…
Reference in New Issue