From 750ce0ec3eaccf47bd40c5da7434dfece55ee478 Mon Sep 17 00:00:00 2001 From: Matt Hayward Date: Sun, 19 Mar 2023 09:07:19 +0000 Subject: [PATCH] #331 - Add ability to define window position in Start call - Add new vScreenPosition parameter to Start method - Use {30, 30} as default value to maintain api compatibility and current default behaviour --- olcPixelGameEngine.h | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/olcPixelGameEngine.h b/olcPixelGameEngine.h index 92dee603..b3320c45 100644 --- a/olcPixelGameEngine.h +++ b/olcPixelGameEngine.h @@ -965,7 +965,7 @@ namespace olc public: olc::rcode Construct(int32_t screen_w, int32_t screen_h, int32_t pixel_w, int32_t pixel_h, bool full_screen = false, bool vsync = false, bool cohesion = false); - olc::rcode Start(); + olc::rcode Start(const olc::vi2d& vWindowPosition); public: // User Override Interfaces // Called once on application startup, use to load your resources @@ -1991,12 +1991,12 @@ namespace olc } #if !defined(PGE_USE_CUSTOM_START) - olc::rcode PixelGameEngine::Start() + olc::rcode PixelGameEngine::Start(const olc::vi2d& vWindowPosition = { 30, 30 }) { if (platform->ApplicationStartUp() != olc::OK) return olc::FAIL; // Construct the window - if (platform->CreateWindowPane({ 30,30 }, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; + if (platform->CreateWindowPane(vWindowPosition, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; olc_UpdateWindowSize(vWindowSize.x, vWindowSize.y); // Start the thread @@ -6130,12 +6130,12 @@ namespace olc { std::atomic* Platform_GLUT::bActiveRef{ nullptr }; //Custom Start - olc::rcode PixelGameEngine::Start() + olc::rcode PixelGameEngine::Start(const olc::vi2d& vWindowPosition = {30, 30}) { if (platform->ApplicationStartUp() != olc::OK) return olc::FAIL; // Construct the window - if (platform->CreateWindowPane({ 30,30 }, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; + if (platform->CreateWindowPane(vWindowPosition, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; olc_UpdateWindowSize(vWindowSize.x, vWindowSize.y); if (platform->ThreadStartUp() == olc::FAIL) return olc::FAIL; @@ -6540,12 +6540,12 @@ namespace olc //Emscripten needs a special Start function //Much of this is usually done in EngineThread, but that isn't used here - olc::rcode PixelGameEngine::Start() + olc::rcode PixelGameEngine::Start(const olc::vi2d& vWindowPosition = { 30, 30 }) { if (platform->ApplicationStartUp() != olc::OK) return olc::FAIL; // Construct the window - if (platform->CreateWindowPane({ 30,30 }, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; + if (platform->CreateWindowPane(vWindowPosition, vWindowSize, bFullScreen) != olc::OK) return olc::FAIL; olc_UpdateWindowSize(vWindowSize.x, vWindowSize.y); // Some implementations may form an event loop here