diff options
author | psi29a <psi29a@gmail.com> | 2021-06-19 00:20:29 +0000 |
---|---|---|
committer | psi29a <psi29a@gmail.com> | 2021-06-19 00:20:54 +0000 |
commit | 3db857e8c8b2bd1714799bc4976e3dbe579b2c94 (patch) | |
tree | 5d906c3116d4a3d1611c582304b8df91bb573d20 | |
parent | 5a27d6eed70b0e61883bb2b384c9969270892972 (diff) |
Merge branch 'object_paging_min_size_combo_box' into 'master'cherry-pick-f6619658
Adding Object Paging Min Size combo box to Advanced -> Visuals
See merge request OpenMW/openmw!917
(cherry picked from commit f66196588c16a9a16211d8f400ce7812127f26c0)
9f2f5174 Adding Object Paging Min Size combo box to Advanced -> Visuals
89950e55 Preventing type conversion of double to float for objectPagingMinSize
-rw-r--r-- | apps/launcher/advancedpage.cpp | 4 | ||||
-rw-r--r-- | components/settings/settings.cpp | 16 | ||||
-rw-r--r-- | components/settings/settings.hpp | 2 | ||||
-rw-r--r-- | files/ui/advancedpage.ui | 32 |
4 files changed, 53 insertions, 1 deletions
diff --git a/apps/launcher/advancedpage.cpp b/apps/launcher/advancedpage.cpp index ed36634b62..bddb70aa02 100644 --- a/apps/launcher/advancedpage.cpp +++ b/apps/launcher/advancedpage.cpp @@ -136,6 +136,7 @@ bool Launcher::AdvancedPage::loadSettings() loadSettingBool(activeGridObjectPagingCheckBox, "object paging active grid", "Terrain"); viewingDistanceComboBox->setValue(convertToCells(Settings::Manager::getInt("viewing distance", "Camera"))); + objectPagingMinSizeComboBox->setValue(Settings::Manager::getDouble("object paging min size", "Terrain")); } // Audio @@ -287,6 +288,9 @@ void Launcher::AdvancedPage::saveSettings() { Settings::Manager::setInt("viewing distance", "Camera", convertToUnits(viewingDistance)); } + double objectPagingMinSize = objectPagingMinSizeComboBox->value(); + if (objectPagingMinSize != Settings::Manager::getDouble("object paging min size", "Terrain")) + Settings::Manager::setDouble("object paging min size", "Terrain", objectPagingMinSize); } // Audio diff --git a/components/settings/settings.cpp b/components/settings/settings.cpp index 13501ac8c9..09a3d1f516 100644 --- a/components/settings/settings.cpp +++ b/components/settings/settings.cpp @@ -61,6 +61,15 @@ float Manager::getFloat (const std::string& setting, const std::string& category return number; } +double Manager::getDouble (const std::string& setting, const std::string& category) +{ + const std::string& value = getString(setting, category); + std::stringstream stream(value); + double number = 0.0; + stream >> number; + return number; +} + int Manager::getInt (const std::string& setting, const std::string& category) { const std::string& value = getString(setting, category); @@ -128,6 +137,13 @@ void Manager::setFloat (const std::string &setting, const std::string &category, setString(setting, category, stream.str()); } +void Manager::setDouble (const std::string &setting, const std::string &category, const double value) +{ + std::ostringstream stream; + stream << value; + setString(setting, category, stream.str()); +} + void Manager::setBool(const std::string &setting, const std::string &category, const bool value) { setString(setting, category, value ? "true" : "false"); diff --git a/components/settings/settings.hpp b/components/settings/settings.hpp index ecc5aa5fd3..e3a29d4c34 100644 --- a/components/settings/settings.hpp +++ b/components/settings/settings.hpp @@ -44,6 +44,7 @@ namespace Settings static int getInt (const std::string& setting, const std::string& category); static float getFloat (const std::string& setting, const std::string& category); + static double getDouble (const std::string& setting, const std::string& category); static std::string getString (const std::string& setting, const std::string& category); static bool getBool (const std::string& setting, const std::string& category); static osg::Vec2f getVector2 (const std::string& setting, const std::string& category); @@ -51,6 +52,7 @@ namespace Settings static void setInt (const std::string& setting, const std::string& category, const int value); static void setFloat (const std::string& setting, const std::string& category, const float value); + static void setDouble (const std::string& setting, const std::string& category, const double value); static void setString (const std::string& setting, const std::string& category, const std::string& value); static void setBool (const std::string& setting, const std::string& category, const bool value); static void setVector2 (const std::string& setting, const std::string& category, const osg::Vec2f value); diff --git a/files/ui/advancedpage.ui b/files/ui/advancedpage.ui index b9d5c7ef57..8abe8f59a4 100644 --- a/files/ui/advancedpage.ui +++ b/files/ui/advancedpage.ui @@ -478,6 +478,36 @@ </layout> </item> <item row="1" column="0"> + <layout class="QHBoxLayout" name="objectPagingMinSizeLayout"> + <item> + <widget class="QLabel" name="objectPagingMinSizeLabel"> + <property name="toolTip"> + <string><html><head/><body><p>Controls how large an object must be to be visible in the scene. The object’s size is divided by its distance to the camera and the result of the division is compared with this value. The smaller this value is, the more objects you will see in the scene.</p></body></html></string> + </property> + <property name="text"> + <string>Object paging min size</string> + </property> + </widget> + </item> + <item> + <widget class="QDoubleSpinBox" name="objectPagingMinSizeComboBox"> + <property name="decimals"> + <number>3</number> + </property> + <property name="minimum"> + <double>0.000000000000000</double> + </property> + <property name="maximum"> + <double>0.250000000000000</double> + </property> + <property name="singleStep"> + <double>0.005000000000000</double> + </property> + </widget> + </item> + </layout> + </item> + <item row="2" column="0"> <widget class="QCheckBox" name="distantLandCheckBox"> <property name="toolTip"> <string><html><head/><body><p>If true, use paging and LOD algorithms to display the entire terrain. If false, only display terrain of the loaded cells.</p></body></html></string> @@ -487,7 +517,7 @@ </property> </widget> </item> - <item row="2" column="0"> + <item row="3" column="0"> <layout class="QVBoxLayout" name="distantLandLayout"> <property name="leftMargin"> <number>20</number> |