Browse Source

Moved SDL-specific code to SDL_Extensions

Ivan Savenko 2 years ago
parent
commit
70c0937972

+ 35 - 0
client/renderSDL/SDL_Extensions.cpp

@@ -891,7 +891,42 @@ void CSDL_Ext::getClipRect(SDL_Surface * src, Rect & other)
 	other = CSDL_Ext::fromSDL(rect);
 }
 
+bool CSDL_Ext::isResolutionSupported(const std::vector<Point> & resolutions, const Point toTest )
+{
+#if defined(VCMI_ANDROID) || defined(VCMI_IOS)
+	// ios can use any resolution
+	// presumably, same goes for Android
+	return true;
+#else
+	// in fullscreen only resolutions supported by monitor can be used
+	return vstd::contains(resolutions, toTest);
+#endif
+}
+
+std::vector<Point> CSDL_Ext::getSupportedResolutions()
+{
+	int displayID = SDL_GetWindowDisplayIndex(mainWindow);
+	return getSupportedResolutions(displayID);
+}
+
+std::vector<Point> CSDL_Ext::getSupportedResolutions( int displayIndex)
+{
+	std::vector<Point> result;
 
+	int modesCount = SDL_GetNumDisplayModes(displayIndex);
+
+	for (int i =0; i < modesCount; ++i)
+	{
+		SDL_DisplayMode mode;
+		if (SDL_GetDisplayMode(displayIndex, i, &mode) != 0)
+			continue;
+
+		Point resolution(mode.w, mode.h);
+
+		result.push_back(resolution);
+	}
+	return result;
+}
 
 template SDL_Surface * CSDL_Ext::createSurfaceWithBpp<2>(int, int);
 template SDL_Surface * CSDL_Ext::createSurfaceWithBpp<3>(int, int);

+ 5 - 0
client/renderSDL/SDL_Extensions.h

@@ -130,6 +130,11 @@ typedef void (*TColorPutterAlpha)(uint8_t *&ptr, const uint8_t & R, const uint8_
 	void applyEffectBpp( SDL_Surface * surf, const Rect & rect, int mode );
 	void applyEffect(SDL_Surface * surf, const Rect & rect, int mode); //mode: 0 - sepia, 1 - grayscale
 
+	bool isResolutionSupported(const std::vector<Point> & resolutions, const Point toTest );
+
+	std::vector<Point> getSupportedResolutions();
+	std::vector<Point> getSupportedResolutions( int displayIndex);
+
 	void setColorKey(SDL_Surface * surface, SDL_Color color);
 
 	///set key-color to 0,255,255

+ 6 - 32
client/windows/GUIClasses.cpp

@@ -63,6 +63,8 @@
 #include "../lib/NetPacksBase.h"
 #include "../lib/StartInfo.h"
 
+#include <SDL_surface.h>
+
 CRecruitmentWindow::CCreatureCard::CCreatureCard(CRecruitmentWindow * window, const CCreature * crea, int totalAmount)
 	: CIntObject(LCLICK | RCLICK),
 	parent(window),
@@ -582,30 +584,8 @@ void CSystemOptionsWindow::setFullscreenMode( bool on)
 	}
 }
 
-void CSystemOptionsWindow::fillSupportedResolutions()
-{
-	supportedResolutions.clear();
-
-	// in game we can only change resolution, display is fixed
-	int displayID = SDL_GetWindowDisplayIndex(mainWindow);
-
-	int modesCount = SDL_GetNumDisplayModes(displayID);
-
-	for (int i =0; i < modesCount; ++i)
-	{
-		SDL_DisplayMode mode;
-		if (SDL_GetDisplayMode(displayID, i, &mode) != 0)
-			continue;
-
-		Point resolution(mode.w, mode.h);
-
-		supportedResolutions.push_back(resolution);
-	}
-}
-
 void CSystemOptionsWindow::fillSelectableResolutions()
 {
-	fillSupportedResolutions();
 	selectableResolutions.clear();
 
 	for(const auto & it : conf.guiOptions)
@@ -629,18 +609,12 @@ bool CSystemOptionsWindow::isResolutionSupported(const Point & resolution)
 
 bool CSystemOptionsWindow::isResolutionSupported(const Point & resolution, bool fullscreen)
 {
-#ifdef VCMI_IOS
-	// ios can use any resolution
-	bool canUseAllResolutions = true;
-#else
-	// in fullscreen only resolutions supported by monitor can be used
-	bool canUseAllResolutions = (fullscreen == false);
-#endif
-
-	if (canUseAllResolutions)
+	if (!fullscreen)
 		return true;
 
-	return vstd::contains(supportedResolutions, resolution);
+	auto supportedList = CSDL_Ext::getSupportedResolutions();
+
+	return CSDL_Ext::isResolutionSupported(supportedList, resolution);
 }
 
 void CSystemOptionsWindow::selectGameRes()

+ 0 - 1
client/windows/GUIClasses.h

@@ -238,7 +238,6 @@ private:
 	void bmainmenuf(); //return to main menu
 
 	void setFullscreenMode( bool on);
-	void fillSupportedResolutions();
 	void fillSelectableResolutions();
 	bool isResolutionSupported(const Point & resolution);
 	bool isResolutionSupported(const Point & resolution, bool fullscreen);