GRAPHICS: Create a dynamic list of available renderers
This allows us to not offer a renderer which is not available on the platform.
This commit is contained in:
parent
6400589ee9
commit
8ec10f5892
3 changed files with 22 additions and 12 deletions
|
@ -43,12 +43,19 @@ static const RendererTypeDescription rendererTypes[] = {
|
||||||
|
|
||||||
DECLARE_TRANSLATION_ADDITIONAL_CONTEXT("OpenGL with shaders", "lowres")
|
DECLARE_TRANSLATION_ADDITIONAL_CONTEXT("OpenGL with shaders", "lowres")
|
||||||
|
|
||||||
const RendererTypeDescription *Renderer::listTypes() {
|
Common::Array<RendererTypeDescription> Renderer::listTypes() {
|
||||||
return rendererTypes;
|
uint32 available = getAvailableTypes();
|
||||||
|
Common::Array<RendererTypeDescription> ret;
|
||||||
|
for (const RendererTypeDescription *rt = rendererTypes; rt->code; ++rt) {
|
||||||
|
if (available & rt->id) {
|
||||||
|
ret.push_back(*rt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
RendererType Renderer::parseTypeCode(const Common::String &code) {
|
RendererType Renderer::parseTypeCode(const Common::String &code) {
|
||||||
const RendererTypeDescription *rt = listTypes();
|
const RendererTypeDescription *rt = rendererTypes;
|
||||||
while (rt->code) {
|
while (rt->code) {
|
||||||
if (rt->code == code) {
|
if (rt->code == code) {
|
||||||
return rt->id;
|
return rt->id;
|
||||||
|
@ -60,7 +67,7 @@ RendererType Renderer::parseTypeCode(const Common::String &code) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Common::String Renderer::getTypeCode(RendererType type) {
|
Common::String Renderer::getTypeCode(RendererType type) {
|
||||||
const RendererTypeDescription *rt = listTypes();
|
const RendererTypeDescription *rt = rendererTypes;
|
||||||
while (rt->code) {
|
while (rt->code) {
|
||||||
if (rt->id == type) {
|
if (rt->id == type) {
|
||||||
return rt->code;
|
return rt->code;
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#define GRAPHICS_RENDERER_H
|
#define GRAPHICS_RENDERER_H
|
||||||
|
|
||||||
#include "common/scummsys.h"
|
#include "common/scummsys.h"
|
||||||
|
#include "common/array.h"
|
||||||
#include "common/str.h"
|
#include "common/str.h"
|
||||||
|
|
||||||
namespace Graphics {
|
namespace Graphics {
|
||||||
|
@ -56,7 +57,7 @@ struct RendererTypeDescription {
|
||||||
|
|
||||||
class Renderer {
|
class Renderer {
|
||||||
public:
|
public:
|
||||||
static const RendererTypeDescription *listTypes();
|
static Common::Array<RendererTypeDescription> listTypes();
|
||||||
|
|
||||||
/** Convert a renderer code to a RendererType enum value */
|
/** Convert a renderer code to a RendererType enum value */
|
||||||
static RendererType parseTypeCode(const Common::String &code);
|
static RendererType parseTypeCode(const Common::String &code);
|
||||||
|
@ -75,7 +76,7 @@ public:
|
||||||
return getBestMatchingType(desired, getAvailableTypes() & supported);
|
return getBestMatchingType(desired, getAvailableTypes() & supported);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
/** @} */
|
/** @} */
|
||||||
} // End of namespace Graphics
|
} // End of namespace Graphics
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1446,12 +1446,14 @@ void OptionsDialog::addGraphicControls(GuiObject *boss, const Common::String &pr
|
||||||
_rendererTypePopUp = new PopUpWidget(boss, prefix + "grRendererTypePopup");
|
_rendererTypePopUp = new PopUpWidget(boss, prefix + "grRendererTypePopup");
|
||||||
_rendererTypePopUp->appendEntry(_("<default>"), Graphics::kRendererTypeDefault);
|
_rendererTypePopUp->appendEntry(_("<default>"), Graphics::kRendererTypeDefault);
|
||||||
_rendererTypePopUp->appendEntry("");
|
_rendererTypePopUp->appendEntry("");
|
||||||
const Graphics::RendererTypeDescription *rt = Graphics::Renderer::listTypes();
|
Common::Array<Graphics::RendererTypeDescription> rt = Graphics::Renderer::listTypes();
|
||||||
for (; rt->code; ++rt) {
|
for (Common::Array<Graphics::RendererTypeDescription>::iterator it = rt.begin();
|
||||||
if (g_system->getOverlayWidth() > 320)
|
it != rt.end(); ++it) {
|
||||||
_rendererTypePopUp->appendEntry(_(rt->description), rt->id);
|
if (g_system->getOverlayWidth() > 320) {
|
||||||
else
|
_rendererTypePopUp->appendEntry(_(it->description), it->id);
|
||||||
_rendererTypePopUp->appendEntry(_c(rt->description, "lowres"), rt->id);
|
} else {
|
||||||
|
_rendererTypePopUp->appendEntry(_c(it->description, "lowres"), it->id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_antiAliasPopUpDesc = new StaticTextWidget(boss, prefix + "grAntiAliasPopupDesc", _("3D Anti-aliasing:"));
|
_antiAliasPopUpDesc = new StaticTextWidget(boss, prefix + "grAntiAliasPopupDesc", _("3D Anti-aliasing:"));
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue