Add "Steps per hour" system setting (#211)

* Implements a steps per hour (global) setting that gets returned by PTM GetStepHistory

* Make setting label text clearer

* Add setting to SDL frontend

* Add setting to Android (no UI)

* Remove IntSetting enum value

* Follow convension in android default ini
This commit is contained in:
szdarkhack 2024-08-20 22:04:29 +03:00 committed by GitHub
parent 8538a57be0
commit e1ff3b8dbe
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
9 changed files with 42 additions and 9 deletions

View file

@ -223,6 +223,7 @@ void Config::ReadValues() {
ReadSetting("System", Settings::values.init_ticks_override); ReadSetting("System", Settings::values.init_ticks_override);
ReadSetting("System", Settings::values.plugin_loader_enabled); ReadSetting("System", Settings::values.plugin_loader_enabled);
ReadSetting("System", Settings::values.allow_plugin_loader); ReadSetting("System", Settings::values.allow_plugin_loader);
ReadSetting("System", Settings::values.steps_per_hour);
// Camera // Camera
using namespace Service::CAM; using namespace Service::CAM;

View file

@ -307,6 +307,10 @@ init_ticks_type =
# Defaults to 0. # Defaults to 0.
init_ticks_override = init_ticks_override =
# Number of steps per hour reported by the pedometer.
# Defaults to 0.
steps_per_hour =
# Plugin loader state, if enabled plugins will be loaded from the SD card. # Plugin loader state, if enabled plugins will be loaded from the SD card.
# You can also set if homebrew apps are allowed to enable the plugin loader # You can also set if homebrew apps are allowed to enable the plugin loader
plugin_loader = plugin_loader =

View file

@ -232,6 +232,7 @@ void Config::ReadValues() {
ReadSetting("System", Settings::values.init_ticks_override); ReadSetting("System", Settings::values.init_ticks_override);
ReadSetting("System", Settings::values.plugin_loader_enabled); ReadSetting("System", Settings::values.plugin_loader_enabled);
ReadSetting("System", Settings::values.allow_plugin_loader); ReadSetting("System", Settings::values.allow_plugin_loader);
ReadSetting("System", Settings::values.steps_per_hour);
{ {
constexpr const char* default_init_time_offset = "0 00:00:00"; constexpr const char* default_init_time_offset = "0 00:00:00";

View file

@ -319,6 +319,10 @@ init_ticks_type =
# Defaults to 0. # Defaults to 0.
init_ticks_override = init_ticks_override =
# Number of steps per hour reported by the pedometer.
# Defaults to 0.
steps_per_hour =
[Camera] [Camera]
# Which camera engine to use for the right outer camera # Which camera engine to use for the right outer camera
# blank (default): a dummy camera that always returns black image # blank (default): a dummy camera that always returns black image

View file

@ -713,6 +713,7 @@ void Config::ReadSystemValues() {
ReadBasicSetting(Settings::values.init_time_offset); ReadBasicSetting(Settings::values.init_time_offset);
ReadBasicSetting(Settings::values.init_ticks_type); ReadBasicSetting(Settings::values.init_ticks_type);
ReadBasicSetting(Settings::values.init_ticks_override); ReadBasicSetting(Settings::values.init_ticks_override);
ReadBasicSetting(Settings::values.steps_per_hour);
ReadBasicSetting(Settings::values.plugin_loader_enabled); ReadBasicSetting(Settings::values.plugin_loader_enabled);
ReadBasicSetting(Settings::values.allow_plugin_loader); ReadBasicSetting(Settings::values.allow_plugin_loader);
} }
@ -1219,6 +1220,7 @@ void Config::SaveSystemValues() {
WriteBasicSetting(Settings::values.init_time_offset); WriteBasicSetting(Settings::values.init_time_offset);
WriteBasicSetting(Settings::values.init_ticks_type); WriteBasicSetting(Settings::values.init_ticks_type);
WriteBasicSetting(Settings::values.init_ticks_override); WriteBasicSetting(Settings::values.init_ticks_override);
WriteBasicSetting(Settings::values.steps_per_hour);
WriteBasicSetting(Settings::values.plugin_loader_enabled); WriteBasicSetting(Settings::values.plugin_loader_enabled);
WriteBasicSetting(Settings::values.allow_plugin_loader); WriteBasicSetting(Settings::values.allow_plugin_loader);
} }

View file

@ -328,6 +328,8 @@ void ConfigureSystem::SetConfiguration() {
ui->edit_init_ticks_value->setText( ui->edit_init_ticks_value->setText(
QString::number(Settings::values.init_ticks_override.GetValue())); QString::number(Settings::values.init_ticks_override.GetValue()));
ui->spinBox_steps_per_hour->setValue(Settings::values.steps_per_hour.GetValue());
cfg = Service::CFG::GetModule(system); cfg = Service::CFG::GetModule(system);
ReadSystemSettings(); ReadSystemSettings();
@ -460,6 +462,8 @@ void ConfigureSystem::ApplyConfiguration() {
Settings::values.init_ticks_override = Settings::values.init_ticks_override =
static_cast<s64>(ui->edit_init_ticks_value->text().toLongLong()); static_cast<s64>(ui->edit_init_ticks_value->text().toLongLong());
Settings::values.steps_per_hour = static_cast<u16>(ui->spinBox_steps_per_hour->value());
s64 time_offset_time = ui->edit_init_time_offset_time->time().msecsSinceStartOfDay() / 1000; s64 time_offset_time = ui->edit_init_time_offset_time->time().msecsSinceStartOfDay() / 1000;
s64 time_offset_days = ui->edit_init_time_offset_days->value() * 86400; s64 time_offset_days = ui->edit_init_time_offset_days->value() * 86400;
@ -631,8 +635,10 @@ void ConfigureSystem::SetupPerGameUI() {
ui->label_language->setVisible(false); ui->label_language->setVisible(false);
ui->label_country->setVisible(false); ui->label_country->setVisible(false);
ui->label_play_coins->setVisible(false); ui->label_play_coins->setVisible(false);
ui->label_steps_per_hour->setVisible(false);
ui->edit_username->setVisible(false); ui->edit_username->setVisible(false);
ui->spinBox_play_coins->setVisible(false); ui->spinBox_play_coins->setVisible(false);
ui->spinBox_steps_per_hour->setVisible(false);
ui->combo_birthday->setVisible(false); ui->combo_birthday->setVisible(false);
ui->combo_birthmonth->setVisible(false); ui->combo_birthmonth->setVisible(false);
ui->combo_init_clock->setVisible(false); ui->combo_init_clock->setVisible(false);

View file

@ -392,21 +392,35 @@
</property> </property>
</widget> </widget>
</item> </item>
<item row="13" column="0">
<widget class="QLabel" name="label_steps_per_hour">
<property name="text">
<string>Pedometer steps per hour:</string>
</property>
</widget>
</item>
<item row="13" column="1"> <item row="13" column="1">
<widget class="QSpinBox" name="spinBox_steps_per_hour">
<property name="maximum">
<number>9999</number>
</property>
</widget>
</item>
<item row="14" column="1">
<widget class="QCheckBox" name="toggle_system_setup"> <widget class="QCheckBox" name="toggle_system_setup">
<property name="text"> <property name="text">
<string>Run System Setup when Home Menu is launched</string> <string>Run System Setup when Home Menu is launched</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="14" column="0"> <item row="15" column="0">
<widget class="QLabel" name="label_console_id"> <widget class="QLabel" name="label_console_id">
<property name="text"> <property name="text">
<string>Console ID:</string> <string>Console ID:</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="14" column="1"> <item row="15" column="1">
<widget class="QPushButton" name="button_regenerate_console_id"> <widget class="QPushButton" name="button_regenerate_console_id">
<property name="sizePolicy"> <property name="sizePolicy">
<sizepolicy hsizetype="Fixed" vsizetype="Fixed"> <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
@ -422,35 +436,35 @@
</property> </property>
</widget> </widget>
</item> </item>
<item row="15" column="0"> <item row="16" column="0">
<widget class="QLabel" name="label_plugin_loader"> <widget class="QLabel" name="label_plugin_loader">
<property name="text"> <property name="text">
<string>3GX Plugin Loader:</string> <string>3GX Plugin Loader:</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="15" column="1"> <item row="16" column="1">
<widget class="QCheckBox" name="plugin_loader"> <widget class="QCheckBox" name="plugin_loader">
<property name="text"> <property name="text">
<string>Enable 3GX plugin loader</string> <string>Enable 3GX plugin loader</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="16" column="1"> <item row="17" column="1">
<widget class="QCheckBox" name="allow_plugin_loader"> <widget class="QCheckBox" name="allow_plugin_loader">
<property name="text"> <property name="text">
<string>Allow games to change plugin loader state</string> <string>Allow games to change plugin loader state</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="17" column="0"> <item row="18" column="0">
<widget class="QLabel" name="label_nus_download"> <widget class="QLabel" name="label_nus_download">
<property name="text"> <property name="text">
<string>Download System Files from Nitendo servers</string> <string>Download System Files from Nitendo servers</string>
</property> </property>
</widget> </widget>
</item> </item>
<item row="17" column="1"> <item row="18" column="1">
<widget class="QWidget" name="body_nus_download"> <widget class="QWidget" name="body_nus_download">
<layout class="QHBoxLayout" name="horizontalLayout_nus_download"> <layout class="QHBoxLayout" name="horizontalLayout_nus_download">
<item> <item>
@ -692,6 +706,7 @@
<tabstop>combo_init_clock</tabstop> <tabstop>combo_init_clock</tabstop>
<tabstop>edit_init_time</tabstop> <tabstop>edit_init_time</tabstop>
<tabstop>spinBox_play_coins</tabstop> <tabstop>spinBox_play_coins</tabstop>
<tabstop>spinBox_steps_per_hour</tabstop>
<tabstop>button_regenerate_console_id</tabstop> <tabstop>button_regenerate_console_id</tabstop>
</tabstops> </tabstops>
<resources/> <resources/>

View file

@ -448,6 +448,7 @@ struct Values {
Setting<s64> init_ticks_override{0, "init_ticks_override"}; Setting<s64> init_ticks_override{0, "init_ticks_override"};
Setting<bool> plugin_loader_enabled{false, "plugin_loader"}; Setting<bool> plugin_loader_enabled{false, "plugin_loader"};
Setting<bool> allow_plugin_loader{true, "allow_plugin_loader"}; Setting<bool> allow_plugin_loader{true, "allow_plugin_loader"};
Setting<u16> steps_per_hour{0, "steps_per_hour"};
// Renderer // Renderer
SwitchableSetting<GraphicsAPI, true> graphics_api { SwitchableSetting<GraphicsAPI, true> graphics_api {

View file

@ -84,9 +84,8 @@ void Module::Interface::GetStepHistory(Kernel::HLERequestContext& ctx) {
ASSERT_MSG(sizeof(u16) * hours == buffer.GetSize(), ASSERT_MSG(sizeof(u16) * hours == buffer.GetSize(),
"Buffer for steps count has incorrect size"); "Buffer for steps count has incorrect size");
// Stub: set zero steps count for every hour const u16_le steps_per_hour = Settings::values.steps_per_hour.GetValue();
for (u32 i = 0; i < hours; ++i) { for (u32 i = 0; i < hours; ++i) {
const u16_le steps_per_hour = 0;
buffer.Write(&steps_per_hour, i * sizeof(u16), sizeof(u16)); buffer.Write(&steps_per_hour, i * sizeof(u16), sizeof(u16));
} }