diff --git a/app/src/main/java/org/schabi/newpipe/player/helper/PlaybackParameterDialog.java b/app/src/main/java/org/schabi/newpipe/player/helper/PlaybackParameterDialog.java index 0fe50096584..2834b93aee0 100644 --- a/app/src/main/java/org/schabi/newpipe/player/helper/PlaybackParameterDialog.java +++ b/app/src/main/java/org/schabi/newpipe/player/helper/PlaybackParameterDialog.java @@ -71,7 +71,6 @@ public class PlaybackParameterDialog extends DialogFragment { private double tempo = DEFAULT_TEMPO; private double pitch = DEFAULT_PITCH; private int semitones = DEFAULT_SEMITONES; - private double stepSize = DEFAULT_STEP; @Nullable private SeekBar tempoSlider; @@ -147,7 +146,6 @@ public void onCreate(@Nullable final Bundle savedInstanceState) { tempo = savedInstanceState.getDouble(TEMPO_KEY, DEFAULT_TEMPO); pitch = savedInstanceState.getDouble(PITCH_KEY, DEFAULT_PITCH); semitones = percentToSemitones(pitch); - stepSize = savedInstanceState.getDouble(STEP_SIZE_KEY, DEFAULT_STEP); } } @@ -159,7 +157,6 @@ public void onSaveInstanceState(final Bundle outState) { outState.putDouble(TEMPO_KEY, getCurrentTempo()); outState.putDouble(PITCH_KEY, getCurrentPitch()); - outState.putDouble(STEP_SIZE_KEY, getCurrentStepSize()); } /*////////////////////////////////////////////////////////////////////////// @@ -203,7 +200,7 @@ private void setupControlViews(@NonNull final View rootView) { togglePitchSliderType(rootView); - setStepSize(stepSize); + setupStepSizeSelector(rootView); } private void togglePitchSliderType(@NonNull final View rootView) { @@ -380,6 +377,10 @@ private void setupAdjustBySemitonesControl(@NonNull final View rootView) { } private void setupStepSizeSelector(@NonNull final View rootView) { + setStepSize(PreferenceManager + .getDefaultSharedPreferences(requireContext()) + .getFloat(getString(R.string.adjustment_step_key), (float) DEFAULT_STEP)); + final TextView stepSizeOnePercentText = rootView.findViewById(R.id.stepSizeOnePercent); final TextView stepSizeFivePercentText = rootView.findViewById(R.id.stepSizeFivePercent); final TextView stepSizeTenPercentText = rootView.findViewById(R.id.stepSizeTenPercent); @@ -438,7 +439,10 @@ private void setupCombinedStepSizeSelector(@NonNull final View rootView) { } private void setStepSize(final double stepSize) { - this.stepSize = stepSize; + PreferenceManager.getDefaultSharedPreferences(requireContext()) + .edit() + .putFloat(getString(R.string.adjustment_step_key), (float) stepSize) + .apply(); if (tempoStepUpText != null) { tempoStepUpText.setText(getStepUpPercentString(stepSize)); @@ -665,10 +669,6 @@ private int getCurrentSemitones() { return semitoneSlider == null ? semitones : semitoneSlider.getProgress() - 12; } - private double getCurrentStepSize() { - return stepSize; - } - private boolean getCurrentSkipSilence() { return skipSilenceCheckbox != null && skipSilenceCheckbox.isChecked(); } diff --git a/app/src/main/res/values/settings_keys.xml b/app/src/main/res/values/settings_keys.xml index ddceec2f1f5..5e9fc22209d 100644 --- a/app/src/main/res/values/settings_keys.xml +++ b/app/src/main/res/values/settings_keys.xml @@ -258,6 +258,7 @@ main_page_content enable_playback_resume enable_playback_state_lists + adjustment_step_key playback_unhook_key playback_speed_key playback_pitch_key