forked from mirror/openmw-tes3mp
fix some settings bugs
This commit is contained in:
parent
2b68e4d489
commit
797c2c538d
2 changed files with 24 additions and 15 deletions
|
@ -5,6 +5,7 @@
|
||||||
#include <OgreString.h>
|
#include <OgreString.h>
|
||||||
|
|
||||||
#include <boost/lexical_cast.hpp>
|
#include <boost/lexical_cast.hpp>
|
||||||
|
#include <boost/algorithm/string.hpp>
|
||||||
|
|
||||||
#include <components/settings/settings.hpp>
|
#include <components/settings/settings.hpp>
|
||||||
|
|
||||||
|
@ -39,6 +40,17 @@ namespace
|
||||||
else
|
else
|
||||||
return "Trilinear";
|
return "Trilinear";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void parseResolution (int &x, int &y, const std::string& str)
|
||||||
|
{
|
||||||
|
std::vector<std::string> split;
|
||||||
|
boost::algorithm::split (split, str, boost::is_any_of("x"));
|
||||||
|
assert (split.size() >= 2);
|
||||||
|
boost::trim(split[0]);
|
||||||
|
boost::trim(split[1]);
|
||||||
|
x = boost::lexical_cast<int> (split[0]);
|
||||||
|
y = boost::lexical_cast<int> (split[1]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace MWGui
|
namespace MWGui
|
||||||
|
@ -103,7 +115,12 @@ namespace MWGui
|
||||||
for (Ogre::StringVector::const_iterator it=videoModes.begin();
|
for (Ogre::StringVector::const_iterator it=videoModes.begin();
|
||||||
it!=videoModes.end(); ++it)
|
it!=videoModes.end(); ++it)
|
||||||
{
|
{
|
||||||
mResolutionList->addItem(*it);
|
int resX, resY;
|
||||||
|
parseResolution (resX, resY, *it);
|
||||||
|
std::string str = boost::lexical_cast<std::string>(resX) + " x " + boost::lexical_cast<std::string>(resY);
|
||||||
|
|
||||||
|
if (mResolutionList->findItemIndexWith(str) == MyGUI::ITEM_NONE)
|
||||||
|
mResolutionList->addItem(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
// read settings
|
// read settings
|
||||||
|
@ -174,13 +191,8 @@ namespace MWGui
|
||||||
void SettingsWindow::onResolutionAccept()
|
void SettingsWindow::onResolutionAccept()
|
||||||
{
|
{
|
||||||
std::string resStr = mResolutionList->getItemNameAt(mResolutionList->getIndexSelected());
|
std::string resStr = mResolutionList->getItemNameAt(mResolutionList->getIndexSelected());
|
||||||
size_t xPos = resStr.find("x");
|
int resX, resY;
|
||||||
std::string resXStr = resStr.substr(0, xPos-1);
|
parseResolution (resX, resY, resStr);
|
||||||
Ogre::StringUtil::trim(resXStr);
|
|
||||||
std::string resYStr = resStr.substr(xPos+2, resStr.size()-(xPos+2));
|
|
||||||
Ogre::StringUtil::trim(resYStr);
|
|
||||||
int resX = boost::lexical_cast<int>(resXStr);
|
|
||||||
int resY = boost::lexical_cast<int>(resYStr);
|
|
||||||
|
|
||||||
Settings::Manager::setInt("resolution x", "Video", resX);
|
Settings::Manager::setInt("resolution x", "Video", resX);
|
||||||
Settings::Manager::setInt("resolution y", "Video", resY);
|
Settings::Manager::setInt("resolution y", "Video", resY);
|
||||||
|
@ -217,13 +229,8 @@ namespace MWGui
|
||||||
for (unsigned int i=0; i<mResolutionList->getItemCount(); ++i)
|
for (unsigned int i=0; i<mResolutionList->getItemCount(); ++i)
|
||||||
{
|
{
|
||||||
std::string resStr = mResolutionList->getItemNameAt(i);
|
std::string resStr = mResolutionList->getItemNameAt(i);
|
||||||
size_t xPos = resStr.find("x");
|
int resX, resY;
|
||||||
std::string resXStr = resStr.substr(0, xPos-1);
|
parseResolution (resX, resY, resStr);
|
||||||
Ogre::StringUtil::trim(resXStr);
|
|
||||||
std::string resYStr = resStr.substr(xPos+2, resStr.size()-(xPos+2));
|
|
||||||
Ogre::StringUtil::trim(resYStr);
|
|
||||||
int resX = boost::lexical_cast<int>(resXStr);
|
|
||||||
int resY = boost::lexical_cast<int>(resYStr);
|
|
||||||
|
|
||||||
if (resX == Settings::Manager::getInt("resolution x", "Video")
|
if (resX == Settings::Manager::getInt("resolution x", "Video")
|
||||||
&& resY == Settings::Manager::getInt("resolution y", "Video"))
|
&& resY == Settings::Manager::getInt("resolution y", "Video"))
|
||||||
|
|
|
@ -66,6 +66,8 @@ void Manager::saveUser(const std::string& file)
|
||||||
}
|
}
|
||||||
fout << it->first.second << " = " << it->second << '\n';
|
fout << it->first.second << " = " << it->second << '\n';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fout.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::string Manager::getString (const std::string& setting, const std::string& category)
|
const std::string Manager::getString (const std::string& setting, const std::string& category)
|
||||||
|
|
Loading…
Reference in a new issue