Merge "Fix janky scrolling for Gestures Settings." into nyc-mr1-dev

This commit is contained in:
Doris Ling
2016-07-19 20:30:12 +00:00
committed by Android (Google) Code Review
2 changed files with 70 additions and 48 deletions

View File

@@ -17,22 +17,16 @@ package com.android.settings.gestures;
import android.content.ContentResolver; import android.content.ContentResolver;
import android.content.Context; import android.content.Context;
import android.content.res.TypedArray; import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.Color;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.PorterDuff;
import android.graphics.SurfaceTexture; import android.graphics.SurfaceTexture;
import android.media.MediaMetadataRetriever; import android.media.MediaMetadataRetriever;
import android.media.MediaPlayer; import android.media.MediaPlayer;
import android.net.Uri; import android.net.Uri;
import android.support.v14.preference.SwitchPreference; import android.support.v14.preference.SwitchPreference;
import android.support.v7.preference.PreferenceViewHolder; import android.support.v7.preference.PreferenceViewHolder;
import android.view.MotionEvent;
import android.view.View; import android.view.View;
import android.view.Surface; import android.view.Surface;
import android.view.TextureView; import android.view.TextureView;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.LinearLayout;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.util.Log; import android.util.Log;
@@ -52,6 +46,7 @@ public final class GesturePreference extends SwitchPreference {
private MediaMetadataRetriever mMediaMetadata; private MediaMetadataRetriever mMediaMetadata;
private boolean mAnimationAvailable; private boolean mAnimationAvailable;
private boolean mPreviewReady; private boolean mPreviewReady;
private boolean mScrolling;
public GesturePreference(Context context, AttributeSet attrs) { public GesturePreference(Context context, AttributeSet attrs) {
super(context, attrs); super(context, attrs);
@@ -69,6 +64,23 @@ public final class GesturePreference extends SwitchPreference {
.build(); .build();
mMediaMetadata = new MediaMetadataRetriever(); mMediaMetadata = new MediaMetadataRetriever();
mMediaMetadata.setDataSource(mContext, mVideoPath); mMediaMetadata.setDataSource(mContext, mVideoPath);
mMediaPlayer = MediaPlayer.create(mContext, mVideoPath);
if (mMediaPlayer != null) {
mMediaPlayer.setOnSeekCompleteListener(new MediaPlayer.OnSeekCompleteListener() {
@Override
public void onSeekComplete(MediaPlayer mp) {
mPreviewReady = true;
mMediaPlayer.setOnSeekCompleteListener(null);
}
});
mMediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
@Override
public void onPrepared(MediaPlayer mediaPlayer) {
mediaPlayer.setLooping(true);
}
});
}
mAnimationAvailable = true; mAnimationAvailable = true;
} catch (Exception e) { } catch (Exception e) {
Log.w(TAG, "Animation resource not found. Will not show animation."); Log.w(TAG, "Animation resource not found. Will not show animation.");
@@ -111,25 +123,9 @@ public final class GesturePreference extends SwitchPreference {
@Override @Override
public void onSurfaceTextureAvailable(SurfaceTexture surfaceTexture, int width, public void onSurfaceTextureAvailable(SurfaceTexture surfaceTexture, int width,
int height) { int height) {
mMediaPlayer = MediaPlayer.create(mContext, mVideoPath);
if (mMediaPlayer != null) { if (mMediaPlayer != null) {
mMediaPlayer.setSurface(new Surface(surfaceTexture)); mMediaPlayer.setSurface(new Surface(surfaceTexture));
mMediaPlayer.setOnSeekCompleteListener( mMediaPlayer.seekTo(0);
new MediaPlayer.OnSeekCompleteListener() {
@Override
public void onSeekComplete(MediaPlayer mp) {
mPreviewReady = true;
mMediaPlayer.setOnSeekCompleteListener(null);
}
});
mMediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
@Override
public void onPrepared(MediaPlayer mediaPlayer) {
mediaPlayer.seekTo(0);
mediaPlayer.setLooping(true);
}
});
} }
} }
@@ -140,12 +136,6 @@ public final class GesturePreference extends SwitchPreference {
@Override @Override
public boolean onSurfaceTextureDestroyed(SurfaceTexture surfaceTexture) { public boolean onSurfaceTextureDestroyed(SurfaceTexture surfaceTexture) {
imageView.setVisibility(View.VISIBLE);
if (mMediaPlayer != null) {
mMediaPlayer.stop();
mMediaPlayer.reset();
mMediaPlayer.release();
}
return false; return false;
} }
@@ -153,6 +143,12 @@ public final class GesturePreference extends SwitchPreference {
public void onSurfaceTextureUpdated(SurfaceTexture surfaceTexture) { public void onSurfaceTextureUpdated(SurfaceTexture surfaceTexture) {
if (mPreviewReady && imageView.getVisibility() == View.VISIBLE) { if (mPreviewReady && imageView.getVisibility() == View.VISIBLE) {
imageView.setVisibility(View.GONE); imageView.setVisibility(View.GONE);
} else if (mScrolling) {
mScrolling = false;
if (mMediaPlayer != null && mMediaPlayer.isPlaying()) {
mMediaPlayer.pause();
playButton.setVisibility(View.VISIBLE);
}
} }
} }
}); });
@@ -161,8 +157,19 @@ public final class GesturePreference extends SwitchPreference {
@Override @Override
public void onDetached() { public void onDetached() {
if (mMediaMetadata != null) {
mMediaMetadata.release(); mMediaMetadata.release();
}
if (mMediaPlayer != null) {
mMediaPlayer.stop();
mMediaPlayer.reset();
mMediaPlayer.release();
}
super.onDetached(); super.onDetached();
} }
void setScrolling(boolean scrolling) {
mScrolling = scrolling;
}
} }

View File

@@ -28,7 +28,6 @@ import android.provider.Settings.Secure;
import android.support.v7.preference.Preference; import android.support.v7.preference.Preference;
import android.support.v7.widget.RecyclerView; import android.support.v7.widget.RecyclerView;
import android.text.TextUtils; import android.text.TextUtils;
import android.util.Log;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
@@ -59,42 +58,35 @@ public class GestureSettings extends SettingsPreferenceFragment implements
private static final String ARG_SCROLL_TO_PREFERENCE = "gesture_scroll_to_preference"; private static final String ARG_SCROLL_TO_PREFERENCE = "gesture_scroll_to_preference";
private int mScrollPosition = -1; private int mScrollPosition = -1;
private List<GesturePreference> mPreferences;
@Override @Override
public void onCreate(Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.gesture_settings); addPreferencesFromResource(R.xml.gesture_settings);
Context context = getActivity(); Context context = getActivity();
mPreferences = new ArrayList();
// Double tap power for camera // Double tap power for camera
if (isCameraDoubleTapPowerGestureAvailable(getResources())) { if (isCameraDoubleTapPowerGestureAvailable(getResources())) {
int cameraDisabled = Secure.getInt( int cameraDisabled = Secure.getInt(
getContentResolver(), Secure.CAMERA_DOUBLE_TAP_POWER_GESTURE_DISABLED, 0); getContentResolver(), Secure.CAMERA_DOUBLE_TAP_POWER_GESTURE_DISABLED, 0);
GesturePreference preference = addPreference(PREF_KEY_DOUBLE_TAP_POWER, cameraDisabled == 0);
(GesturePreference) findPreference(PREF_KEY_DOUBLE_TAP_POWER);
preference.setChecked(cameraDisabled == 0);
preference.setOnPreferenceChangeListener(this);
} else { } else {
removePreference(PREF_KEY_DOUBLE_TAP_POWER); removePreference(PREF_KEY_DOUBLE_TAP_POWER);
} }
// Ambient Display // Ambient Display
if (isDozeAvailable(context)) { if (isDozeAvailable(context)) {
GesturePreference preference =
(GesturePreference) findPreference(PREF_KEY_PICK_UP_AND_NUDGE);
int dozeEnabled = Secure.getInt(getContentResolver(), Secure.DOZE_ENABLED, 1); int dozeEnabled = Secure.getInt(getContentResolver(), Secure.DOZE_ENABLED, 1);
preference.setChecked(dozeEnabled != 0); addPreference(PREF_KEY_PICK_UP_AND_NUDGE, dozeEnabled != 0);
preference.setOnPreferenceChangeListener(this);
} else { } else {
removePreference(PREF_KEY_PICK_UP_AND_NUDGE); removePreference(PREF_KEY_PICK_UP_AND_NUDGE);
} }
// Fingerprint slide for notifications // Fingerprint slide for notifications
if (isSystemUINavigationAvailable(context)) { if (isSystemUINavigationAvailable(context)) {
GesturePreference preference = addPreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT, isSystemUINavigationEnabled(context));
(GesturePreference) findPreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT);
preference.setChecked(isSystemUINavigationEnabled(context));
preference.setOnPreferenceChangeListener(this);
} else { } else {
removePreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT); removePreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT);
} }
@@ -103,10 +95,7 @@ public class GestureSettings extends SettingsPreferenceFragment implements
if (isDoubleTwistAvailable(context)) { if (isDoubleTwistAvailable(context)) {
int doubleTwistEnabled = Secure.getInt( int doubleTwistEnabled = Secure.getInt(
getContentResolver(), Secure.CAMERA_DOUBLE_TWIST_TO_FLIP_ENABLED, 1); getContentResolver(), Secure.CAMERA_DOUBLE_TWIST_TO_FLIP_ENABLED, 1);
GesturePreference preference = addPreference(PREF_KEY_DOUBLE_TWIST, doubleTwistEnabled != 0);
(GesturePreference) findPreference(PREF_KEY_DOUBLE_TWIST);
preference.setChecked(doubleTwistEnabled != 0);
preference.setOnPreferenceChangeListener(this);
} else { } else {
removePreference(PREF_KEY_DOUBLE_TWIST); removePreference(PREF_KEY_DOUBLE_TWIST);
} }
@@ -128,9 +117,28 @@ public class GestureSettings extends SettingsPreferenceFragment implements
public View onCreateView(LayoutInflater inflater, ViewGroup container, public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) { Bundle savedInstanceState) {
View view = super.onCreateView(inflater, container, savedInstanceState); View view = super.onCreateView(inflater, container, savedInstanceState);
RecyclerView listview = getListView();
if (mScrollPosition >= 0) { if (mScrollPosition >= 0) {
getListView().scrollToPosition(mScrollPosition); listview.scrollToPosition(mScrollPosition);
} }
listview.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
if (newState == RecyclerView.SCROLL_STATE_DRAGGING) {
for (GesturePreference pref : mPreferences) {
pref.setScrolling(true);
}
} else if (newState == RecyclerView.SCROLL_STATE_IDLE) {
for (GesturePreference pref : mPreferences) {
pref.setScrolling(false);
}
}
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
}
});
return view; return view;
} }
@@ -203,6 +211,13 @@ public class GestureSettings extends SettingsPreferenceFragment implements
return false; return false;
} }
private void addPreference(String key, boolean enabled) {
GesturePreference preference = (GesturePreference) findPreference(key);
preference.setChecked(enabled);
preference.setOnPreferenceChangeListener(this);
mPreferences.add(preference);
}
public static final Indexable.SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER = public static final Indexable.SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
new BaseSearchIndexProvider() { new BaseSearchIndexProvider() {
@Override @Override