Introducing windowed fullscreen. Closes #9.
This commit is contained in:
parent
36173438cc
commit
40da86aad6
@ -3,6 +3,8 @@
|
|||||||
<height>786</height>
|
<height>786</height>
|
||||||
</resolution>
|
</resolution>
|
||||||
|
|
||||||
|
<windowedFullscreen>true</windowedFullscreen>
|
||||||
|
|
||||||
<shadowCubeSize>1024</shadowCubeSize>
|
<shadowCubeSize>1024</shadowCubeSize>
|
||||||
|
|
||||||
<farPlane>150.0</farPlane>
|
<farPlane>150.0</farPlane>
|
||||||
|
@ -145,3 +145,11 @@ void Application::startGame() {
|
|||||||
bool Application::isGameStarted() {
|
bool Application::isGameStarted() {
|
||||||
return gameStarted;
|
return gameStarted;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Application::setFullscreen(bool state) {
|
||||||
|
this->fullscreen = state;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Application::makeFullscreen() {
|
||||||
|
return fullscreen;
|
||||||
|
}
|
||||||
|
@ -35,7 +35,10 @@ class Application {
|
|||||||
void setLoadingScreenContinuePath(std::string path);
|
void setLoadingScreenContinuePath(std::string path);
|
||||||
bool isGameStarted();
|
bool isGameStarted();
|
||||||
void startGame();
|
void startGame();
|
||||||
|
void setFullscreen(bool state);
|
||||||
|
bool makeFullscreen();
|
||||||
private:
|
private:
|
||||||
|
bool fullscreen;
|
||||||
bool gameStarted;
|
bool gameStarted;
|
||||||
int ignoredMouseUpdates;
|
int ignoredMouseUpdates;
|
||||||
bool focused;
|
bool focused;
|
||||||
|
@ -17,6 +17,7 @@ void Loader::loadConfig(Application* application) {
|
|||||||
|
|
||||||
application->setWindowWidth(queryInt(resolution, "width"));
|
application->setWindowWidth(queryInt(resolution, "width"));
|
||||||
application->setWindowHeight(queryInt(resolution, "height"));
|
application->setWindowHeight(queryInt(resolution, "height"));
|
||||||
|
application->setFullscreen(queryBool(config, "windowedFullscreen"));
|
||||||
application->setShadowCubeSize(queryInt(config, "shadowCubeSize"));
|
application->setShadowCubeSize(queryInt(config, "shadowCubeSize"));
|
||||||
application->setFarPlane(queryFloat(config, "farPlane"));
|
application->setFarPlane(queryFloat(config, "farPlane"));
|
||||||
application->setMaxShadowRenderCount(queryInt(config, "maxShadowRenderCount"));
|
application->setMaxShadowRenderCount(queryInt(config, "maxShadowRenderCount"));
|
||||||
|
22
game/main.cc
22
game/main.cc
@ -112,13 +112,29 @@ bool createWindow()
|
|||||||
// define whether the window can get resized:
|
// define whether the window can get resized:
|
||||||
glfwWindowHint(GLFW_RESIZABLE, true);
|
glfwWindowHint(GLFW_RESIZABLE, true);
|
||||||
|
|
||||||
// try to create an OpenGL context in a window and check the supported OpenGL version:
|
if(app.makeFullscreen()) {
|
||||||
// R,G,B,A, Depth,Stencil
|
const GLFWvidmode* mode = glfwGetVideoMode(glfwGetPrimaryMonitor());
|
||||||
window = glfwCreateWindow(app.getGraphics()->getWindowSize().x, app.getGraphics()->getWindowSize().y, "SWP MarbleGame Group C", NULL, NULL);
|
|
||||||
|
glfwWindowHint(GLFW_RED_BITS, mode->redBits);
|
||||||
|
glfwWindowHint(GLFW_GREEN_BITS, mode->greenBits);
|
||||||
|
glfwWindowHint(GLFW_BLUE_BITS, mode->blueBits);
|
||||||
|
glfwWindowHint(GLFW_REFRESH_RATE, mode->refreshRate);
|
||||||
|
window = glfwCreateWindow(mode->width, mode->height, "Saxum", glfwGetPrimaryMonitor(), NULL);
|
||||||
|
|
||||||
if (!window) {
|
if (!window) {
|
||||||
ACGL::Utils::error() << "Failed to open a GLFW window - requested OpenGL: " << ACGL_OPENGL_VERSION << std::endl;
|
ACGL::Utils::error() << "Failed to open a GLFW window - requested OpenGL: " << ACGL_OPENGL_VERSION << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// try to create an OpenGL context in a window and check the supported OpenGL version:
|
||||||
|
// R,G,B,A, Depth,Stencil
|
||||||
|
window = glfwCreateWindow(app.getGraphics()->getWindowSize().x, app.getGraphics()->getWindowSize().y, "Saxum", NULL, NULL);
|
||||||
|
if (!window) {
|
||||||
|
ACGL::Utils::error() << "Failed to open a GLFW window - requested OpenGL: " << ACGL_OPENGL_VERSION << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
glfwMakeContextCurrent(window);
|
glfwMakeContextCurrent(window);
|
||||||
#ifdef SAXUM_DEBUG
|
#ifdef SAXUM_DEBUG
|
||||||
ACGL::init(true);
|
ACGL::init(true);
|
||||||
|
Loading…
Reference in New Issue
Block a user