Fullscreen, vsync, fullscreen_bpp and fsaa options in the config; fsaa is experimental atm, causes visible spaces between blocks.

This commit is contained in:
q66 2012-04-03 13:59:02 +02:00 committed by Perttu Ahola
parent 2eec788544
commit e8e73d37fb
3 changed files with 29 additions and 4 deletions

@ -62,6 +62,12 @@
# Initial window size # Initial window size
#screenW = 800 #screenW = 800
#screenH = 600 #screenH = 600
#fullscreen = false
#fullscreen_bpp = 24
# Experimental option, might cause visible spaces between blocks
# when set to higher number than 0
#fsaa = 0
#vsync = false
# Address to connect to (#blank = start local server) # Address to connect to (#blank = start local server)
#address = #address =
# Enable random user input, for testing # Enable random user input, for testing

@ -74,6 +74,10 @@ void set_default_settings(Settings *settings)
settings->setDefault("viewing_range_nodes_min", "35"); settings->setDefault("viewing_range_nodes_min", "35");
settings->setDefault("screenW", "800"); settings->setDefault("screenW", "800");
settings->setDefault("screenH", "600"); settings->setDefault("screenH", "600");
settings->setDefault("fullscreen", "false");
settings->setDefault("fullscreen_bpp", "24");
settings->setDefault("fsaa", "0");
settings->setDefault("vsync", "false");
settings->setDefault("address", ""); settings->setDefault("address", "");
settings->setDefault("random_input", "false"); settings->setDefault("random_input", "false");
settings->setDefault("client_unload_unused_data_timeout", "600"); settings->setDefault("client_unload_unused_data_timeout", "600");

@ -1213,10 +1213,16 @@ int main(int argc, char *argv[])
// Resolution selection // Resolution selection
bool fullscreen = false; bool fullscreen = g_settings->getBool("fullscreen");
u16 screenW = g_settings->getU16("screenW"); u16 screenW = g_settings->getU16("screenW");
u16 screenH = g_settings->getU16("screenH"); u16 screenH = g_settings->getU16("screenH");
// bpp, fsaa, vsync
bool vsync = g_settings->getBool("vsync");
u16 bits = g_settings->getU16("fullscreen_bpp");
u16 fsaa = g_settings->getU16("fsaa");
// Determine driver // Determine driver
video::E_DRIVER_TYPE driverType; video::E_DRIVER_TYPE driverType;
@ -1249,9 +1255,18 @@ int main(int argc, char *argv[])
MyEventReceiver receiver; MyEventReceiver receiver;
IrrlichtDevice *device; IrrlichtDevice *device;
device = createDevice(driverType,
core::dimension2d<u32>(screenW, screenH), SIrrlichtCreationParameters params = SIrrlichtCreationParameters();
16, fullscreen, false, false, &receiver); params.DriverType = driverType;
params.WindowSize = core::dimension2d<u32>(screenW, screenH);
params.Bits = bits;
params.AntiAlias = fsaa;
params.Fullscreen = fullscreen;
params.Stencilbuffer = false;
params.Vsync = vsync;
params.EventReceiver = &receiver;
device = createDeviceEx(params);
if (device == 0) if (device == 0)
return 1; // could not create selected driver. return 1; // could not create selected driver.