Initialize the volume seekbar preference max and progress.
When the media stream is set, initialize the preference max and progress with the streams current value. Otherwise, when we initialize the seekbar volumizer, it will first set the seekbar max to 0 and progress to 0, then update with the correct value, which will result in the jank that is seen when the sound settings are displayed. Change-Id: I515c97bbc6ec38bbe92755e3d7cb53bb13ac52d0 Fix: 34035654 Test: make RunSettingsRoboTests
This commit is contained in:
@@ -21,6 +21,7 @@ import android.content.Context;
|
||||
import android.media.AudioManager;
|
||||
import android.net.Uri;
|
||||
import android.preference.SeekBarVolumizer;
|
||||
import android.support.annotation.VisibleForTesting;
|
||||
import android.support.v7.preference.PreferenceViewHolder;
|
||||
import android.text.TextUtils;
|
||||
import android.util.AttributeSet;
|
||||
@@ -51,30 +52,38 @@ public class VolumeSeekBarPreference extends SeekBarPreference {
|
||||
private int mIconResId;
|
||||
private int mMuteIconResId;
|
||||
private boolean mStopped;
|
||||
@VisibleForTesting
|
||||
AudioManager mAudioManager;
|
||||
|
||||
public VolumeSeekBarPreference(Context context, AttributeSet attrs, int defStyleAttr,
|
||||
int defStyleRes) {
|
||||
super(context, attrs, defStyleAttr, defStyleRes);
|
||||
setLayoutResource(R.layout.preference_volume_slider);
|
||||
mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
|
||||
}
|
||||
|
||||
public VolumeSeekBarPreference(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||
super(context, attrs, defStyleAttr);
|
||||
setLayoutResource(R.layout.preference_volume_slider);
|
||||
mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
|
||||
}
|
||||
|
||||
public VolumeSeekBarPreference(Context context, AttributeSet attrs) {
|
||||
super(context, attrs);
|
||||
setLayoutResource(R.layout.preference_volume_slider);
|
||||
mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
|
||||
}
|
||||
|
||||
public VolumeSeekBarPreference(Context context) {
|
||||
super(context);
|
||||
setLayoutResource(R.layout.preference_volume_slider);
|
||||
mAudioManager = (AudioManager) context.getSystemService(Context.AUDIO_SERVICE);
|
||||
}
|
||||
|
||||
public void setStream(int stream) {
|
||||
mStream = stream;
|
||||
setMax(mAudioManager.getStreamMaxVolume(mStream));
|
||||
setProgress(mAudioManager.getStreamVolume(mStream));
|
||||
}
|
||||
|
||||
public void setCallback(Callback callback) {
|
||||
|
Reference in New Issue
Block a user