Use viewbinding
This commit is contained in:
parent
652d50173e
commit
4cdf6eda2c
1 changed files with 42 additions and 82 deletions
|
@ -7,12 +7,10 @@ import android.app.Dialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.View;
|
import android.view.LayoutInflater;
|
||||||
import android.widget.CheckBox;
|
|
||||||
import android.widget.SeekBar;
|
import android.widget.SeekBar;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import androidx.annotation.IdRes;
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.appcompat.app.AlertDialog;
|
import androidx.appcompat.app.AlertDialog;
|
||||||
|
@ -20,6 +18,7 @@ import androidx.fragment.app.DialogFragment;
|
||||||
import androidx.preference.PreferenceManager;
|
import androidx.preference.PreferenceManager;
|
||||||
|
|
||||||
import org.schabi.newpipe.R;
|
import org.schabi.newpipe.R;
|
||||||
|
import org.schabi.newpipe.databinding.DialogPlaybackParameterBinding;
|
||||||
import org.schabi.newpipe.util.SliderStrategy;
|
import org.schabi.newpipe.util.SliderStrategy;
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
@ -72,18 +71,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
@State
|
@State
|
||||||
boolean skipSilence = DEFAULT_SKIP_SILENCE;
|
boolean skipSilence = DEFAULT_SKIP_SILENCE;
|
||||||
|
|
||||||
private SeekBar tempoSlider;
|
private DialogPlaybackParameterBinding binding;
|
||||||
private TextView tempoCurrentText;
|
|
||||||
private TextView tempoStepDownText;
|
|
||||||
private TextView tempoStepUpText;
|
|
||||||
|
|
||||||
private SeekBar pitchSlider;
|
|
||||||
private TextView pitchCurrentText;
|
|
||||||
private TextView pitchStepDownText;
|
|
||||||
private TextView pitchStepUpText;
|
|
||||||
|
|
||||||
private CheckBox unhookingCheckbox;
|
|
||||||
private CheckBox skipSilenceCheckbox;
|
|
||||||
|
|
||||||
public static PlaybackParameterDialog newInstance(
|
public static PlaybackParameterDialog newInstance(
|
||||||
final double playbackTempo,
|
final double playbackTempo,
|
||||||
|
@ -110,7 +98,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
//////////////////////////////////////////////////////////////////////////*/
|
//////////////////////////////////////////////////////////////////////////*/
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onAttach(final Context context) {
|
public void onAttach(@NonNull final Context context) {
|
||||||
super.onAttach(context);
|
super.onAttach(context);
|
||||||
if (context instanceof Callback) {
|
if (context instanceof Callback) {
|
||||||
callback = (Callback) context;
|
callback = (Callback) context;
|
||||||
|
@ -120,7 +108,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSaveInstanceState(final Bundle outState) {
|
public void onSaveInstanceState(@NonNull final Bundle outState) {
|
||||||
super.onSaveInstanceState(outState);
|
super.onSaveInstanceState(outState);
|
||||||
Icepick.saveInstanceState(this, outState);
|
Icepick.saveInstanceState(this, outState);
|
||||||
}
|
}
|
||||||
|
@ -135,12 +123,12 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
assureCorrectAppLanguage(getContext());
|
assureCorrectAppLanguage(getContext());
|
||||||
Icepick.restoreInstanceState(this, savedInstanceState);
|
Icepick.restoreInstanceState(this, savedInstanceState);
|
||||||
|
|
||||||
final View view = View.inflate(getContext(), R.layout.dialog_playback_parameter, null);
|
binding = DialogPlaybackParameterBinding.inflate(LayoutInflater.from(getContext()));
|
||||||
initUI(view);
|
initUI();
|
||||||
initUIData();
|
initUIData();
|
||||||
|
|
||||||
final AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(requireActivity())
|
final AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(requireActivity())
|
||||||
.setView(view)
|
.setView(binding.getRoot())
|
||||||
.setCancelable(true)
|
.setCancelable(true)
|
||||||
.setNegativeButton(R.string.cancel, (dialogInterface, i) -> {
|
.setNegativeButton(R.string.cancel, (dialogInterface, i) -> {
|
||||||
setAndUpdateTempo(initialTempo);
|
setAndUpdateTempo(initialTempo);
|
||||||
|
@ -163,37 +151,21 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
// Control Views
|
// Control Views
|
||||||
//////////////////////////////////////////////////////////////////////////*/
|
//////////////////////////////////////////////////////////////////////////*/
|
||||||
|
|
||||||
private void initUI(@NonNull final View rootView) {
|
private void initUI() {
|
||||||
// Tempo
|
// Tempo
|
||||||
tempoSlider = Objects.requireNonNull(rootView.findViewById(R.id.tempoSeekbar));
|
setText(binding.tempoMinimumText, PlayerHelper::formatSpeed, MINIMUM_PLAYBACK_VALUE);
|
||||||
tempoCurrentText = Objects.requireNonNull(rootView.findViewById(R.id.tempoCurrentText));
|
setText(binding.tempoMaximumText, PlayerHelper::formatSpeed, MAXIMUM_PLAYBACK_VALUE);
|
||||||
tempoStepUpText = Objects.requireNonNull(rootView.findViewById(R.id.tempoStepUp));
|
|
||||||
tempoStepDownText = Objects.requireNonNull(rootView.findViewById(R.id.tempoStepDown));
|
|
||||||
|
|
||||||
setText(rootView, R.id.tempoMinimumText, PlayerHelper::formatSpeed, MINIMUM_PLAYBACK_VALUE);
|
|
||||||
setText(rootView, R.id.tempoMaximumText, PlayerHelper::formatSpeed, MAXIMUM_PLAYBACK_VALUE);
|
|
||||||
|
|
||||||
// Pitch
|
// Pitch
|
||||||
pitchSlider = Objects.requireNonNull(rootView.findViewById(R.id.pitchSeekbar));
|
setText(binding.pitchMinimumText, PlayerHelper::formatPitch, MINIMUM_PLAYBACK_VALUE);
|
||||||
pitchCurrentText = Objects.requireNonNull(rootView.findViewById(R.id.pitchCurrentText));
|
setText(binding.pitchMaximumText, PlayerHelper::formatPitch, MAXIMUM_PLAYBACK_VALUE);
|
||||||
pitchStepUpText = Objects.requireNonNull(rootView.findViewById(R.id.pitchStepUp));
|
|
||||||
pitchStepDownText = Objects.requireNonNull(rootView.findViewById(R.id.pitchStepDown));
|
|
||||||
|
|
||||||
setText(rootView, R.id.pitchMinimumText, PlayerHelper::formatPitch, MINIMUM_PLAYBACK_VALUE);
|
|
||||||
setText(rootView, R.id.pitchMaximumText, PlayerHelper::formatPitch, MAXIMUM_PLAYBACK_VALUE);
|
|
||||||
|
|
||||||
// Steps
|
// Steps
|
||||||
setupStepTextView(rootView, R.id.stepSizeOnePercent, STEP_1_PERCENT_VALUE);
|
setupStepTextView(binding.stepSizeOnePercent, STEP_1_PERCENT_VALUE);
|
||||||
setupStepTextView(rootView, R.id.stepSizeFivePercent, STEP_5_PERCENT_VALUE);
|
setupStepTextView(binding.stepSizeFivePercent, STEP_5_PERCENT_VALUE);
|
||||||
setupStepTextView(rootView, R.id.stepSizeTenPercent, STEP_10_PERCENT_VALUE);
|
setupStepTextView(binding.stepSizeTenPercent, STEP_10_PERCENT_VALUE);
|
||||||
setupStepTextView(rootView, R.id.stepSizeTwentyFivePercent, STEP_25_PERCENT_VALUE);
|
setupStepTextView(binding.stepSizeTwentyFivePercent, STEP_25_PERCENT_VALUE);
|
||||||
setupStepTextView(rootView, R.id.stepSizeOneHundredPercent, STEP_100_PERCENT_VALUE);
|
setupStepTextView(binding.stepSizeOneHundredPercent, STEP_100_PERCENT_VALUE);
|
||||||
|
|
||||||
// Bottom controls
|
|
||||||
unhookingCheckbox =
|
|
||||||
Objects.requireNonNull(rootView.findViewById(R.id.unhookCheckbox));
|
|
||||||
skipSilenceCheckbox =
|
|
||||||
Objects.requireNonNull(rootView.findViewById(R.id.skipSilenceCheckbox));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private TextView setText(
|
private TextView setText(
|
||||||
|
@ -205,59 +177,47 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
return textView;
|
return textView;
|
||||||
}
|
}
|
||||||
|
|
||||||
private TextView setText(
|
|
||||||
final View rootView,
|
|
||||||
@IdRes final int idRes,
|
|
||||||
final DoubleFunction<String> formatter,
|
|
||||||
final double value
|
|
||||||
) {
|
|
||||||
final TextView textView = rootView.findViewById(idRes);
|
|
||||||
setText(textView, formatter, value);
|
|
||||||
return textView;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupStepTextView(
|
private void setupStepTextView(
|
||||||
final View rootView,
|
final TextView textView,
|
||||||
@IdRes final int idRes,
|
|
||||||
final double stepSizeValue
|
final double stepSizeValue
|
||||||
) {
|
) {
|
||||||
setText(rootView, idRes, PlaybackParameterDialog::getPercentString, stepSizeValue)
|
setText(textView, PlaybackParameterDialog::getPercentString, stepSizeValue)
|
||||||
.setOnClickListener(view -> setAndUpdateStepSize(stepSizeValue));
|
.setOnClickListener(view -> setAndUpdateStepSize(stepSizeValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initUIData() {
|
private void initUIData() {
|
||||||
// Tempo
|
// Tempo
|
||||||
tempoSlider.setMax(QUADRATIC_STRATEGY.progressOf(MAXIMUM_PLAYBACK_VALUE));
|
binding.tempoSeekbar.setMax(QUADRATIC_STRATEGY.progressOf(MAXIMUM_PLAYBACK_VALUE));
|
||||||
setAndUpdateTempo(tempo);
|
setAndUpdateTempo(tempo);
|
||||||
tempoSlider.setOnSeekBarChangeListener(
|
binding.tempoSeekbar.setOnSeekBarChangeListener(
|
||||||
getTempoOrPitchSeekbarChangeListener(this::onTempoSliderUpdated));
|
getTempoOrPitchSeekbarChangeListener(this::onTempoSliderUpdated));
|
||||||
|
|
||||||
registerOnStepClickListener(
|
registerOnStepClickListener(
|
||||||
tempoStepDownText, tempo, -1, this::onTempoSliderUpdated);
|
binding.tempoStepDown, tempo, -1, this::onTempoSliderUpdated);
|
||||||
registerOnStepClickListener(
|
registerOnStepClickListener(
|
||||||
tempoStepUpText, tempo, 1, this::onTempoSliderUpdated);
|
binding.tempoStepUp, tempo, 1, this::onTempoSliderUpdated);
|
||||||
|
|
||||||
// Pitch
|
// Pitch
|
||||||
pitchSlider.setMax(QUADRATIC_STRATEGY.progressOf(MAXIMUM_PLAYBACK_VALUE));
|
binding.pitchSeekbar.setMax(QUADRATIC_STRATEGY.progressOf(MAXIMUM_PLAYBACK_VALUE));
|
||||||
setAndUpdatePitch(pitch);
|
setAndUpdatePitch(pitch);
|
||||||
pitchSlider.setOnSeekBarChangeListener(
|
binding.pitchSeekbar.setOnSeekBarChangeListener(
|
||||||
getTempoOrPitchSeekbarChangeListener(this::onPitchSliderUpdated));
|
getTempoOrPitchSeekbarChangeListener(this::onPitchSliderUpdated));
|
||||||
|
|
||||||
registerOnStepClickListener(
|
registerOnStepClickListener(
|
||||||
pitchStepDownText, pitch, -1, this::onPitchSliderUpdated);
|
binding.pitchStepDown, pitch, -1, this::onPitchSliderUpdated);
|
||||||
registerOnStepClickListener(
|
registerOnStepClickListener(
|
||||||
pitchStepUpText, pitch, 1, this::onPitchSliderUpdated);
|
binding.pitchStepUp, pitch, 1, this::onPitchSliderUpdated);
|
||||||
|
|
||||||
// Steps
|
// Steps
|
||||||
setAndUpdateStepSize(stepSize);
|
setAndUpdateStepSize(stepSize);
|
||||||
|
|
||||||
// Bottom controls
|
// Bottom controls
|
||||||
// restore whether pitch and tempo are unhooked or not
|
// restore whether pitch and tempo are unhooked or not
|
||||||
unhookingCheckbox.setChecked(PreferenceManager
|
binding.unhookCheckbox.setChecked(PreferenceManager
|
||||||
.getDefaultSharedPreferences(requireContext())
|
.getDefaultSharedPreferences(requireContext())
|
||||||
.getBoolean(getString(R.string.playback_unhook_key), true));
|
.getBoolean(getString(R.string.playback_unhook_key), true));
|
||||||
|
|
||||||
unhookingCheckbox.setOnCheckedChangeListener((compoundButton, isChecked) -> {
|
binding.unhookCheckbox.setOnCheckedChangeListener((compoundButton, isChecked) -> {
|
||||||
// save whether pitch and tempo are unhooked or not
|
// save whether pitch and tempo are unhooked or not
|
||||||
PreferenceManager.getDefaultSharedPreferences(requireContext())
|
PreferenceManager.getDefaultSharedPreferences(requireContext())
|
||||||
.edit()
|
.edit()
|
||||||
|
@ -271,7 +231,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
});
|
});
|
||||||
|
|
||||||
setAndUpdateSkipSilence(skipSilence);
|
setAndUpdateSkipSilence(skipSilence);
|
||||||
skipSilenceCheckbox.setOnCheckedChangeListener((compoundButton, isChecked) -> {
|
binding.skipSilenceCheckbox.setOnCheckedChangeListener((compoundButton, isChecked) -> {
|
||||||
skipSilence = isChecked;
|
skipSilence = isChecked;
|
||||||
updateCallback();
|
updateCallback();
|
||||||
});
|
});
|
||||||
|
@ -291,16 +251,16 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
private void setAndUpdateStepSize(final double newStepSize) {
|
private void setAndUpdateStepSize(final double newStepSize) {
|
||||||
this.stepSize = newStepSize;
|
this.stepSize = newStepSize;
|
||||||
|
|
||||||
tempoStepUpText.setText(getStepUpPercentString(newStepSize));
|
binding.tempoStepUp.setText(getStepUpPercentString(newStepSize));
|
||||||
tempoStepDownText.setText(getStepDownPercentString(newStepSize));
|
binding.tempoStepDown.setText(getStepDownPercentString(newStepSize));
|
||||||
|
|
||||||
pitchStepUpText.setText(getStepUpPercentString(newStepSize));
|
binding.pitchStepUp.setText(getStepUpPercentString(newStepSize));
|
||||||
pitchStepDownText.setText(getStepDownPercentString(newStepSize));
|
binding.pitchStepDown.setText(getStepDownPercentString(newStepSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setAndUpdateSkipSilence(final boolean newSkipSilence) {
|
private void setAndUpdateSkipSilence(final boolean newSkipSilence) {
|
||||||
this.skipSilence = newSkipSilence;
|
this.skipSilence = newSkipSilence;
|
||||||
skipSilenceCheckbox.setChecked(newSkipSilence);
|
binding.skipSilenceCheckbox.setChecked(newSkipSilence);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*//////////////////////////////////////////////////////////////////////////
|
/*//////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -333,7 +293,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onTempoSliderUpdated(final double newTempo) {
|
private void onTempoSliderUpdated(final double newTempo) {
|
||||||
if (!unhookingCheckbox.isChecked()) {
|
if (!binding.unhookCheckbox.isChecked()) {
|
||||||
setSliders(newTempo);
|
setSliders(newTempo);
|
||||||
} else {
|
} else {
|
||||||
setAndUpdateTempo(newTempo);
|
setAndUpdateTempo(newTempo);
|
||||||
|
@ -341,7 +301,7 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onPitchSliderUpdated(final double newPitch) {
|
private void onPitchSliderUpdated(final double newPitch) {
|
||||||
if (!unhookingCheckbox.isChecked()) {
|
if (!binding.unhookCheckbox.isChecked()) {
|
||||||
setSliders(newPitch);
|
setSliders(newPitch);
|
||||||
} else {
|
} else {
|
||||||
setAndUpdatePitch(newPitch);
|
setAndUpdatePitch(newPitch);
|
||||||
|
@ -355,14 +315,14 @@ public class PlaybackParameterDialog extends DialogFragment {
|
||||||
|
|
||||||
private void setAndUpdateTempo(final double newTempo) {
|
private void setAndUpdateTempo(final double newTempo) {
|
||||||
this.tempo = newTempo;
|
this.tempo = newTempo;
|
||||||
tempoSlider.setProgress(QUADRATIC_STRATEGY.progressOf(tempo));
|
binding.tempoSeekbar.setProgress(QUADRATIC_STRATEGY.progressOf(tempo));
|
||||||
setText(tempoCurrentText, PlayerHelper::formatSpeed, tempo);
|
setText(binding.tempoCurrentText, PlayerHelper::formatSpeed, tempo);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setAndUpdatePitch(final double newPitch) {
|
private void setAndUpdatePitch(final double newPitch) {
|
||||||
this.pitch = newPitch;
|
this.pitch = newPitch;
|
||||||
pitchSlider.setProgress(QUADRATIC_STRATEGY.progressOf(pitch));
|
binding.pitchSeekbar.setProgress(QUADRATIC_STRATEGY.progressOf(pitch));
|
||||||
setText(pitchCurrentText, PlayerHelper::formatPitch, pitch);
|
setText(binding.pitchCurrentText, PlayerHelper::formatPitch, pitch);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*//////////////////////////////////////////////////////////////////////////
|
/*//////////////////////////////////////////////////////////////////////////
|
||||||
|
|
Loading…
Reference in a new issue