1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-21 06:53:53 +00:00

added integer settings

This commit is contained in:
Marc Zinnschlag 2015-12-08 17:21:58 +01:00
parent c158224314
commit c61d717e41
14 changed files with 405 additions and 12 deletions

View file

@ -124,7 +124,7 @@ opencs_units_noqt (view/settings
) )
opencs_units (view/prefs opencs_units (view/prefs
dialogue pagebase dialogue pagebase page
) )
opencs_units (model/settings opencs_units (model/settings
@ -138,7 +138,7 @@ opencs_hdrs_noqt (model/settings
) )
opencs_units (model/prefs opencs_units (model/prefs
state state setting intsetting
) )
opencs_units_noqt (model/prefs opencs_units_noqt (model/prefs

View file

@ -9,3 +9,23 @@ const std::string& CSMPrefs::Category::getKey() const
{ {
return mKey; return mKey;
} }
CSMPrefs::State *CSMPrefs::Category::getState() const
{
return mParent;
}
void CSMPrefs::Category::addSetting (Setting *setting)
{
mSettings.push_back (setting);
}
CSMPrefs::Category::Iterator CSMPrefs::Category::begin()
{
return mSettings.begin();
}
CSMPrefs::Category::Iterator CSMPrefs::Category::end()
{
return mSettings.end();
}

View file

@ -1,16 +1,26 @@
#ifndef CSV_PREFS_CATEGORY_H #ifndef CSM_PREFS_CATEGORY_H
#define CSM_PREFS_CATEGORY_H #define CSM_PREFS_CATEGORY_H
#include <string> #include <string>
#include <vector>
namespace CSMPrefs namespace CSMPrefs
{ {
class State; class State;
class Setting;
class Category class Category
{ {
public:
typedef std::vector<Setting *> Container;
typedef Container::iterator Iterator;
private:
State *mParent; State *mParent;
std::string mKey; std::string mKey;
Container mSettings;
public: public:
@ -18,6 +28,13 @@ namespace CSMPrefs
const std::string& getKey() const; const std::string& getKey() const;
State *getState() const;
void addSetting (Setting *setting);
Iterator begin();
Iterator end();
}; };
} }

View file

@ -0,0 +1,69 @@
#include "intsetting.hpp"
#include <limits>
#include <QLabel>
#include <QSpinBox>
#include <components/settings/settings.hpp>
#include "category.hpp"
#include "state.hpp"
CSMPrefs::IntSetting::IntSetting (Category *parent, Settings::Manager *values,
const std::string& key, const std::string& label, int default_)
: Setting (parent, values, key, label), mMin (0), mMax (std::numeric_limits<int>::max()),
mDefault (default_)
{}
CSMPrefs::IntSetting& CSMPrefs::IntSetting::setRange (int min, int max)
{
mMin = min;
mMax = max;
return *this;
}
CSMPrefs::IntSetting& CSMPrefs::IntSetting::setMin (int min)
{
mMin = min;
return *this;
}
CSMPrefs::IntSetting& CSMPrefs::IntSetting::setMax (int max)
{
mMax = max;
return *this;
}
CSMPrefs::IntSetting& CSMPrefs::IntSetting::setTooltip (const std::string& tooltip)
{
mTooltip = tooltip;
return *this;
}
std::pair<QWidget *, QWidget *> CSMPrefs::IntSetting::makeWidgets (QWidget *parent)
{
QLabel *label = new QLabel (QString::fromUtf8 (getLabel().c_str()), parent);
QSpinBox *widget = new QSpinBox (parent);
widget->setRange (mMin, mMax);
widget->setValue (mDefault);
if (!mTooltip.empty())
{
QString tooltip = QString::fromUtf8 (mTooltip.c_str());
label->setToolTip (tooltip);
widget->setToolTip (tooltip);
}
connect (widget, SIGNAL (valueChanged (int)), this, SLOT (valueChanged (int)));
return std::make_pair (label, widget);
}
void CSMPrefs::IntSetting::valueChanged (int value)
{
getValues().setInt (getKey(), getParent()->getKey(), value);
getParent()->getState()->update (*this);
}

View file

@ -0,0 +1,39 @@
#ifndef CSM_PREFS_INTSETTING_H
#define CSM_PREFS_INTSETTING_H
#include "setting.hpp"
namespace CSMPrefs
{
class IntSetting : public Setting
{
Q_OBJECT
int mMin;
int mMax;
std::string mTooltip;
int mDefault;
public:
IntSetting (Category *parent, Settings::Manager *values,
const std::string& key, const std::string& label, int default_);
IntSetting& setRange (int min, int max);
IntSetting& setMin (int min);
IntSetting& setMax (int max);
IntSetting& setTooltip (const std::string& tooltip);
/// Return label, input widget.
virtual std::pair<QWidget *, QWidget *> makeWidgets (QWidget *parent);
private slots:
void valueChanged (int value);
};
}
#endif

View file

@ -0,0 +1,32 @@
#include "setting.hpp"
#include "category.hpp"
#include "state.hpp"
Settings::Manager& CSMPrefs::Setting::getValues()
{
return *mValues;
}
CSMPrefs::Setting::Setting (Category *parent, Settings::Manager *values,
const std::string& key, const std::string& label)
: QObject (parent->getState()), mParent (parent), mValues (values), mKey (key), mLabel (label)
{}
CSMPrefs::Setting:: ~Setting() {}
const CSMPrefs::Category *CSMPrefs::Setting::getParent() const
{
return mParent;
}
const std::string& CSMPrefs::Setting::getKey() const
{
return mKey;
}
const std::string& CSMPrefs::Setting::getLabel() const
{
return mLabel;
}

View file

@ -0,0 +1,53 @@
#ifndef CSM_PREFS_SETTING_H
#define CSM_PREFS_SETTING_H
#include <string>
#include <utility>
#include <QObject>
class QWidget;
namespace Settings
{
class Manager;
}
namespace CSMPrefs
{
class Category;
class Setting : public QObject
{
Q_OBJECT
Category *mParent;
Settings::Manager *mValues;
std::string mKey;
std::string mLabel;
protected:
Settings::Manager& getValues();
public:
Setting (Category *parent, Settings::Manager *values, const std::string& key, const std::string& label);
virtual ~Setting();
/// Return label, input widget.
///
/// \note first can be a 0-pointer, which means that the label is part of the input
/// widget.
virtual std::pair<QWidget *, QWidget *> makeWidgets (QWidget *parent) = 0;
const Category *getParent() const;
const std::string& getKey() const;
const std::string& getLabel() const;
};
}
#endif

View file

@ -3,6 +3,9 @@
#include <stdexcept> #include <stdexcept>
#include <algorithm> #include <algorithm>
#include <sstream>
#include "intsetting.hpp"
CSMPrefs::State *CSMPrefs::State::sThis = 0; CSMPrefs::State *CSMPrefs::State::sThis = 0;
@ -29,6 +32,24 @@ void CSMPrefs::State::load()
void CSMPrefs::State::declare() void CSMPrefs::State::declare()
{ {
declareCategory ("Windows"); declareCategory ("Windows");
declareInt ("default-width", "Default window width", 800).
setTooltip ("Newly opened top-level windows will open with this width.").
setMin (80);
declareInt ("default-height", "Default window height", 600).
setTooltip ("Newly opened top-level windows will open with this height.").
setMin (80);
// reuse
// show-statusbar
declareInt ("max-subviews", "Maximum number of subviews per top-level window", 256).
setTooltip ("If the maximum number is reached and a new subview is opened "
"it will be placed into a new top-level window.").
setRange (1, 256);
// hide-subview
declareInt ("minimum-width", "Minimum subview width", 325).
setTooltip ("Minimum width of subviews.").
setRange (50, 10000);
// mainwindow-scrollbar
// grow-limit
declareCategory ("Records"); declareCategory ("Records");
@ -39,14 +60,33 @@ void CSMPrefs::State::declare()
declareCategory ("Reports"); declareCategory ("Reports");
declareCategory ("Search & Replace"); declareCategory ("Search & Replace");
declareInt ("char-before", "Characters before search string", 10).
setTooltip ("Maximum number of character to display in search result before the searched text");
declareInt ("char-after", "Characters after search string", 10).
setTooltip ("Maximum number of character to display in search result after the searched text");
// auto-delete
declareCategory ("Scripts"); declareCategory ("Scripts");
// show-linenum
// mono-font
// warnings
// toolbar
declareInt ("compile-delay", "Delay between updating of source errors", 100).
setTooltip ("Delay in milliseconds").
setRange (0, 10000);
declareInt ("error-height", "Initial height of the error panel", 100).
setRange (100, 10000);
// syntax-colouring
declareCategory ("General Input"); declareCategory ("General Input");
declareCategory ("3D Scene Input"); declareCategory ("3D Scene Input");
declareCategory ("Tooltips"); declareCategory ("Tooltips");
// scene
// scene-hide-basic
declareInt ("scene-delay", "Tooltip delay in milliseconds", 500).
setMin (1);
} }
void CSMPrefs::State::declareCategory (const std::string& key) void CSMPrefs::State::declareCategory (const std::string& key)
@ -64,6 +104,37 @@ void CSMPrefs::State::declareCategory (const std::string& key)
} }
} }
CSMPrefs::IntSetting& CSMPrefs::State::declareInt (const std::string& key,
const std::string& label, int default_)
{
if (mCurrentCategory==mCategories.end())
throw std::logic_error ("no category for setting");
std::ostringstream stream;
stream << default_;
setDefault (key, stream.str());
default_ = mSettings.getInt (key, mCurrentCategory->second.getKey());
CSMPrefs::IntSetting *setting =
new CSMPrefs::IntSetting (&mCurrentCategory->second, &mSettings, key, label, default_);
mCurrentCategory->second.addSetting (setting);
return *setting;
}
void CSMPrefs::State::setDefault (const std::string& key, const std::string& default_)
{
Settings::CategorySetting fullKey (mCurrentCategory->second.getKey(), key);
Settings::CategorySettingValueMap::iterator iter =
mSettings.mDefaultSettings.find (fullKey);
if (iter==mSettings.mDefaultSettings.end())
mSettings.mDefaultSettings.insert (std::make_pair (fullKey, default_));
}
CSMPrefs::State::State (const Files::ConfigurationManager& configurationManager) CSMPrefs::State::State (const Files::ConfigurationManager& configurationManager)
: mConfigFile ("opencs.ini"), mConfigurationManager (configurationManager), : mConfigFile ("opencs.ini"), mConfigurationManager (configurationManager),
mCurrentCategory (mCategories.end()) mCurrentCategory (mCategories.end())
@ -108,6 +179,11 @@ CSMPrefs::Category& CSMPrefs::State::getCategory (const std::string& key)
return iter->second; return iter->second;
} }
void CSMPrefs::State::update (const Setting& setting)
{
emit (settingChanged (setting));
}
CSMPrefs::State& CSMPrefs::State::get() CSMPrefs::State& CSMPrefs::State::get()
{ {
if (!sThis) if (!sThis)

View file

@ -13,9 +13,12 @@
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include "category.hpp" #include "category.hpp"
#include "setting.hpp"
namespace CSMPrefs namespace CSMPrefs
{ {
class IntSetting;
class State : public QObject class State : public QObject
{ {
Q_OBJECT Q_OBJECT
@ -47,6 +50,10 @@ namespace CSMPrefs
void declareCategory (const std::string& key); void declareCategory (const std::string& key);
IntSetting& declareInt (const std::string& key, const std::string& label, int default_);
void setDefault (const std::string& key, const std::string& default_);
public: public:
State (const Files::ConfigurationManager& configurationManager); State (const Files::ConfigurationManager& configurationManager);
@ -61,7 +68,13 @@ namespace CSMPrefs
Category& getCategory (const std::string& key); Category& getCategory (const std::string& key);
void update (const Setting& setting);
static State& get(); static State& get();
signals:
void settingChanged (const Setting& setting);
}; };
// convenience function // convenience function

View file

@ -10,7 +10,7 @@
#include "../../model/prefs/state.hpp" #include "../../model/prefs/state.hpp"
#include "pagebase.hpp" #include "page.hpp"
void CSVPrefs::Dialogue::buildCategorySelector (QSplitter *main) void CSVPrefs::Dialogue::buildCategorySelector (QSplitter *main)
{ {
@ -49,6 +49,13 @@ void CSVPrefs::Dialogue::buildContentArea (QSplitter *main)
main->addWidget (mContent); main->addWidget (mContent);
} }
CSVPrefs::PageBase *CSVPrefs::Dialogue::makePage (const std::string& key)
{
// special case page code goes here
return new Page (CSMPrefs::get().getCategory (key), mContent);
}
CSVPrefs::Dialogue::Dialogue() CSVPrefs::Dialogue::Dialogue()
{ {
setWindowTitle ("User Settings"); setWindowTitle ("User Settings");
@ -107,7 +114,7 @@ void CSVPrefs::Dialogue::selectionChanged (QListWidgetItem *current, QListWidget
} }
} }
PageBase *page = new PageBase (CSMPrefs::get().getCategory (key), mContent); PageBase *page = makePage (key);
mContent->setCurrentIndex (mContent->addWidget (page)); mContent->setCurrentIndex (mContent->addWidget (page));
} }
} }

View file

@ -10,6 +10,8 @@ class QListWidgetItem;
namespace CSVPrefs namespace CSVPrefs
{ {
class PageBase;
class Dialogue : public QMainWindow class Dialogue : public QMainWindow
{ {
Q_OBJECT Q_OBJECT
@ -23,6 +25,8 @@ namespace CSVPrefs
void buildContentArea (QSplitter *main); void buildContentArea (QSplitter *main);
PageBase *makePage (const std::string& key);
public: public:
Dialogue(); Dialogue();

View file

@ -0,0 +1,40 @@
#include "page.hpp"
#include <QGridLayout>
#include "../../model/prefs/setting.hpp"
#include "../../model/prefs/category.hpp"
CSVPrefs::Page::Page (CSMPrefs::Category& category, QWidget *parent)
: PageBase (category, parent)
{
QWidget *widget = new QWidget (parent);
mGrid = new QGridLayout (widget);
for (CSMPrefs::Category::Iterator iter = category.begin(); iter!=category.end(); ++iter)
addSetting (*iter);
setWidget (widget);
}
void CSVPrefs::Page::addSetting (CSMPrefs::Setting *setting)
{
std::pair<QWidget *, QWidget *> widgets = setting->makeWidgets (this);
int next = mGrid->rowCount();
if (widgets.first)
{
mGrid->addWidget (widgets.first, next, 0);
mGrid->addWidget (widgets.second, next, 1);
}
else if (widgets.second)
{
mGrid->addWidget (widgets.second, next, 0, next, 1);
}
else
{
mGrid->addWidget (new QWidget (this), next, 0);
}
}

View file

@ -0,0 +1,29 @@
#ifndef CSV_PREFS_PAGE_H
#define CSV_PREFS_PAGE_H
#include "pagebase.hpp"
class QGridLayout;
namespace CSMPrefs
{
class Setting;
}
namespace CSVPrefs
{
class Page : public PageBase
{
Q_OBJECT
QGridLayout *mGrid;
public:
Page (CSMPrefs::Category& category, QWidget *parent);
void addSetting (CSMPrefs::Setting *setting);
};
}
#endif

View file

@ -1,17 +1,11 @@
#include "pagebase.hpp" #include "pagebase.hpp"
#include <QLabel>
#include "../../model/prefs/category.hpp" #include "../../model/prefs/category.hpp"
CSVPrefs::PageBase::PageBase (CSMPrefs::Category& category, QWidget *parent) CSVPrefs::PageBase::PageBase (CSMPrefs::Category& category, QWidget *parent)
: QScrollArea (parent), mCategory (category) : QScrollArea (parent), mCategory (category)
{ {}
QLabel *temp = new QLabel (category.getKey().c_str(), this);
setWidget (temp);
}
CSMPrefs::Category& CSVPrefs::PageBase::getCategory() CSMPrefs::Category& CSVPrefs::PageBase::getCategory()
{ {