Add static preview images to gesture settings. am: 12e4bebabf
am: df7b815980
am: fccee6adae
Change-Id: Ia745f80fa47a7316cb462918f900de001b1ecf03
This commit is contained in:
0
res/drawable-nodpi/gesture_ambient_lift
Normal file
0
res/drawable-nodpi/gesture_ambient_lift
Normal file
0
res/drawable-nodpi/gesture_ambient_tap
Normal file
0
res/drawable-nodpi/gesture_ambient_tap
Normal file
0
res/drawable-nodpi/gesture_double_tap
Normal file
0
res/drawable-nodpi/gesture_double_tap
Normal file
0
res/drawable-nodpi/gesture_fingerprint_swipe
Normal file
0
res/drawable-nodpi/gesture_fingerprint_swipe
Normal file
0
res/drawable-nodpi/gesture_twist
Normal file
0
res/drawable-nodpi/gesture_twist
Normal file
@@ -74,6 +74,7 @@
|
|||||||
android:id="@+id/gesture_image"
|
android:id="@+id/gesture_image"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
|
android:scaleType="fitXY"
|
||||||
android:background="@color/gestures_setting_background_color"/>
|
android:background="@color/gestures_setting_background_color"/>
|
||||||
|
|
||||||
<ImageView
|
<ImageView
|
||||||
|
@@ -139,6 +139,7 @@
|
|||||||
<!-- For GesturePreference -->
|
<!-- For GesturePreference -->
|
||||||
<declare-styleable name="GesturePreference">
|
<declare-styleable name="GesturePreference">
|
||||||
<attr name="animation" format="reference" />
|
<attr name="animation" format="reference" />
|
||||||
|
<attr name="preview" format="reference" />
|
||||||
</declare-styleable>
|
</declare-styleable>
|
||||||
|
|
||||||
<!-- For AspectRatioFrameLayout -->
|
<!-- For AspectRatioFrameLayout -->
|
||||||
|
@@ -23,30 +23,35 @@
|
|||||||
android:key="gesture_swipe_down_fingerprint"
|
android:key="gesture_swipe_down_fingerprint"
|
||||||
android:title="@string/fingerprint_swipe_for_notifications_title"
|
android:title="@string/fingerprint_swipe_for_notifications_title"
|
||||||
android:summary="@string/fingerprint_swipe_for_notifications_summary"
|
android:summary="@string/fingerprint_swipe_for_notifications_summary"
|
||||||
settings:animation="@raw/gesture_fingerprint_swipe"/>
|
settings:animation="@raw/gesture_fingerprint_swipe"
|
||||||
|
settings:preview="@drawable/gesture_fingerprint_swipe"/>
|
||||||
|
|
||||||
<com.android.settings.gestures.GesturePreference
|
<com.android.settings.gestures.GesturePreference
|
||||||
android:key="gesture_double_tap_power"
|
android:key="gesture_double_tap_power"
|
||||||
android:title="@string/double_tap_power_for_camera_title"
|
android:title="@string/double_tap_power_for_camera_title"
|
||||||
android:summary="@string/double_tap_power_for_camera_summary"
|
android:summary="@string/double_tap_power_for_camera_summary"
|
||||||
settings:animation="@raw/gesture_double_tap"/>
|
settings:animation="@raw/gesture_double_tap"
|
||||||
|
settings:preview="@drawable/gesture_double_tap"/>
|
||||||
|
|
||||||
<com.android.settings.gestures.GesturePreference
|
<com.android.settings.gestures.GesturePreference
|
||||||
android:key="gesture_double_twist"
|
android:key="gesture_double_twist"
|
||||||
android:title="@string/double_twist_for_camera_mode_title"
|
android:title="@string/double_twist_for_camera_mode_title"
|
||||||
android:summary="@string/double_twist_for_camera_mode_summary"
|
android:summary="@string/double_twist_for_camera_mode_summary"
|
||||||
settings:animation="@raw/gesture_twist"/>
|
settings:animation="@raw/gesture_twist"
|
||||||
|
settings:preview="@drawable/gesture_twist"/>
|
||||||
|
|
||||||
<com.android.settings.gestures.GesturePreference
|
<com.android.settings.gestures.GesturePreference
|
||||||
android:key="gesture_double_tap_screen"
|
android:key="gesture_double_tap_screen"
|
||||||
android:title="@string/ambient_display_title"
|
android:title="@string/ambient_display_title"
|
||||||
android:summary="@string/ambient_display_summary"
|
android:summary="@string/ambient_display_summary"
|
||||||
settings:animation="@raw/gesture_ambient_tap"/>
|
settings:animation="@raw/gesture_ambient_tap"
|
||||||
|
settings:preview="@drawable/gesture_ambient_tap"/>
|
||||||
|
|
||||||
<com.android.settings.gestures.GesturePreference
|
<com.android.settings.gestures.GesturePreference
|
||||||
android:key="gesture_pick_up"
|
android:key="gesture_pick_up"
|
||||||
android:title="@string/ambient_display_pickup_title"
|
android:title="@string/ambient_display_pickup_title"
|
||||||
android:summary="@string/ambient_display_pickup_summary"
|
android:summary="@string/ambient_display_pickup_summary"
|
||||||
settings:animation="@raw/gesture_ambient_lift"/>
|
settings:animation="@raw/gesture_ambient_lift"
|
||||||
|
settings:preview="@drawable/gesture_ambient_lift"/>
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
@@ -14,18 +14,12 @@
|
|||||||
|
|
||||||
package com.android.settings.gestures;
|
package com.android.settings.gestures;
|
||||||
|
|
||||||
import android.app.LoaderManager;
|
|
||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Loader;
|
|
||||||
import android.content.res.TypedArray;
|
import android.content.res.TypedArray;
|
||||||
import android.graphics.Bitmap;
|
|
||||||
import android.graphics.drawable.BitmapDrawable;
|
|
||||||
import android.graphics.SurfaceTexture;
|
import android.graphics.SurfaceTexture;
|
||||||
import android.media.MediaMetadataRetriever;
|
|
||||||
import android.media.MediaPlayer;
|
import android.media.MediaPlayer;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
|
||||||
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.View;
|
import android.view.View;
|
||||||
@@ -36,15 +30,13 @@ import android.util.AttributeSet;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.utils.AsyncLoader;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Preference item for a gesture with a switch to signify if it should be enabled.
|
* Preference item for a gesture with a switch to signify if it should be enabled.
|
||||||
* This shows the title and description of the gesture along with an animation showing how to do
|
* This shows the title and description of the gesture along with an animation showing how to do
|
||||||
* the gesture
|
* the gesture
|
||||||
*/
|
*/
|
||||||
public final class GesturePreference extends SwitchPreference implements
|
public final class GesturePreference extends SwitchPreference {
|
||||||
LoaderManager.LoaderCallbacks<Bitmap> {
|
|
||||||
private static final String TAG = "GesturePreference";
|
private static final String TAG = "GesturePreference";
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
|
|
||||||
@@ -53,7 +45,7 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
private boolean mAnimationAvailable;
|
private boolean mAnimationAvailable;
|
||||||
private boolean mVideoReady;
|
private boolean mVideoReady;
|
||||||
private boolean mScrolling;
|
private boolean mScrolling;
|
||||||
private BitmapDrawable mPreviewImage;
|
private int mPreviewResource;
|
||||||
|
|
||||||
public GesturePreference(Context context, AttributeSet attrs) {
|
public GesturePreference(Context context, AttributeSet attrs) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
@@ -71,6 +63,10 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
mMediaPlayer = MediaPlayer.create(mContext, mVideoPath);
|
mMediaPlayer = MediaPlayer.create(mContext, mVideoPath);
|
||||||
if (mMediaPlayer != null && mMediaPlayer.getDuration() > 0) {
|
if (mMediaPlayer != null && mMediaPlayer.getDuration() > 0) {
|
||||||
setLayoutResource(R.layout.gesture_preference);
|
setLayoutResource(R.layout.gesture_preference);
|
||||||
|
|
||||||
|
mPreviewResource = attributes.getResourceId(
|
||||||
|
R.styleable.GesturePreference_preview, 0);
|
||||||
|
|
||||||
mMediaPlayer.setOnSeekCompleteListener(new MediaPlayer.OnSeekCompleteListener() {
|
mMediaPlayer.setOnSeekCompleteListener(new MediaPlayer.OnSeekCompleteListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onSeekComplete(MediaPlayer mp) {
|
public void onSeekComplete(MediaPlayer mp) {
|
||||||
@@ -103,6 +99,7 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
|
|
||||||
final TextureView video = (TextureView) holder.findViewById(R.id.gesture_video);
|
final TextureView video = (TextureView) holder.findViewById(R.id.gesture_video);
|
||||||
final ImageView imageView = (ImageView) holder.findViewById(R.id.gesture_image);
|
final ImageView imageView = (ImageView) holder.findViewById(R.id.gesture_image);
|
||||||
|
imageView.setImageResource(mPreviewResource);
|
||||||
final ImageView playButton = (ImageView) holder.findViewById(R.id.gesture_play_button);
|
final ImageView playButton = (ImageView) holder.findViewById(R.id.gesture_play_button);
|
||||||
|
|
||||||
video.setOnClickListener(new View.OnClickListener() {
|
video.setOnClickListener(new View.OnClickListener() {
|
||||||
@@ -138,9 +135,6 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onSurfaceTextureDestroyed(SurfaceTexture surfaceTexture) {
|
public boolean onSurfaceTextureDestroyed(SurfaceTexture surfaceTexture) {
|
||||||
if (mPreviewImage != null && imageView.getDrawable() == null) {
|
|
||||||
imageView.setImageDrawable(mPreviewImage);
|
|
||||||
}
|
|
||||||
imageView.setVisibility(View.VISIBLE);
|
imageView.setVisibility(View.VISIBLE);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -159,10 +153,6 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if (mPreviewImage != null) {
|
|
||||||
imageView.setImageDrawable(mPreviewImage);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -179,63 +169,10 @@ public final class GesturePreference extends SwitchPreference implements
|
|||||||
mScrolling = scrolling;
|
mScrolling = scrolling;
|
||||||
}
|
}
|
||||||
|
|
||||||
void loadPreview(LoaderManager manager, int id) {
|
|
||||||
if (mAnimationAvailable) {
|
|
||||||
Loader<Bitmap> loader = manager.initLoader(id, Bundle.EMPTY, this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void onViewVisible() {
|
void onViewVisible() {
|
||||||
if (mVideoReady && mMediaPlayer != null && !mMediaPlayer.isPlaying()) {
|
if (mVideoReady && mMediaPlayer != null && !mMediaPlayer.isPlaying()) {
|
||||||
mMediaPlayer.seekTo(0);
|
mMediaPlayer.seekTo(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class PreviewRetriever extends AsyncLoader<Bitmap> {
|
|
||||||
private Uri mVideoPath;
|
|
||||||
|
|
||||||
public PreviewRetriever(Context context, Uri videoPath) {
|
|
||||||
super(context);
|
|
||||||
mVideoPath = videoPath;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Bitmap loadInBackground() {
|
|
||||||
MediaMetadataRetriever mediaMetadata = new MediaMetadataRetriever();
|
|
||||||
try {
|
|
||||||
mediaMetadata.setDataSource(getContext(), mVideoPath);
|
|
||||||
return mediaMetadata.getFrameAtTime(0);
|
|
||||||
} catch (Exception e) {
|
|
||||||
Log.w(TAG, "Unable to get animation preview.");
|
|
||||||
} finally {
|
|
||||||
mediaMetadata.release();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDiscardResult(final Bitmap result) {
|
|
||||||
if (result != null && !result.isRecycled()) {
|
|
||||||
result.recycle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Loader<Bitmap> onCreateLoader(int id, Bundle args) {
|
|
||||||
return new PreviewRetriever(mContext, mVideoPath);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoadFinished(final Loader<Bitmap> loader, final Bitmap bitmap) {
|
|
||||||
if (bitmap != null) {
|
|
||||||
mPreviewImage = new BitmapDrawable(mContext.getResources(), bitmap);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLoaderReset(Loader<Bitmap> loader) {
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -56,11 +56,6 @@ public class GestureSettings extends SettingsPreferenceFragment implements
|
|||||||
private static final String PREF_KEY_SWIPE_DOWN_FINGERPRINT = "gesture_swipe_down_fingerprint";
|
private static final String PREF_KEY_SWIPE_DOWN_FINGERPRINT = "gesture_swipe_down_fingerprint";
|
||||||
private static final String PREF_KEY_DOUBLE_TAP_SCREEN = "gesture_double_tap_screen";
|
private static final String PREF_KEY_DOUBLE_TAP_SCREEN = "gesture_double_tap_screen";
|
||||||
private static final String DEBUG_DOZE_COMPONENT = "debug.doze.component";
|
private static final String DEBUG_DOZE_COMPONENT = "debug.doze.component";
|
||||||
private static final int PREF_ID_DOUBLE_TAP_POWER = 0;
|
|
||||||
private static final int PREF_ID_DOUBLE_TWIST = 1;
|
|
||||||
private static final int PREF_ID_PICK_UP = 2;
|
|
||||||
private static final int PREF_ID_SWIPE_DOWN_FINGERPRINT = 3;
|
|
||||||
private static final int PREF_ID_DOUBLE_TAP_SCREEN = 4;
|
|
||||||
|
|
||||||
private List<GesturePreference> mPreferences;
|
private List<GesturePreference> mPreferences;
|
||||||
|
|
||||||
@@ -75,7 +70,7 @@ public class GestureSettings extends SettingsPreferenceFragment implements
|
|||||||
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);
|
||||||
addPreference(PREF_KEY_DOUBLE_TAP_POWER, cameraDisabled == 0, PREF_ID_DOUBLE_TAP_POWER);
|
addPreference(PREF_KEY_DOUBLE_TAP_POWER, cameraDisabled == 0);
|
||||||
} else {
|
} else {
|
||||||
removePreference(PREF_KEY_DOUBLE_TAP_POWER);
|
removePreference(PREF_KEY_DOUBLE_TAP_POWER);
|
||||||
}
|
}
|
||||||
@@ -84,21 +79,20 @@ public class GestureSettings extends SettingsPreferenceFragment implements
|
|||||||
boolean dozeEnabled = isDozeAvailable(context);
|
boolean dozeEnabled = isDozeAvailable(context);
|
||||||
if (dozeEnabled && isPickupAvailable(context)) {
|
if (dozeEnabled && isPickupAvailable(context)) {
|
||||||
int pickup = Secure.getInt(getContentResolver(), Secure.DOZE_PULSE_ON_PICK_UP, 1);
|
int pickup = Secure.getInt(getContentResolver(), Secure.DOZE_PULSE_ON_PICK_UP, 1);
|
||||||
addPreference(PREF_KEY_PICK_UP, pickup != 0, PREF_ID_PICK_UP);
|
addPreference(PREF_KEY_PICK_UP, pickup != 0);
|
||||||
} else {
|
} else {
|
||||||
removePreference(PREF_KEY_PICK_UP);
|
removePreference(PREF_KEY_PICK_UP);
|
||||||
}
|
}
|
||||||
if (dozeEnabled && isDoubleTapAvailable(context)) {
|
if (dozeEnabled && isDoubleTapAvailable(context)) {
|
||||||
int doubleTap = Secure.getInt(getContentResolver(), Secure.DOZE_PULSE_ON_DOUBLE_TAP, 1);
|
int doubleTap = Secure.getInt(getContentResolver(), Secure.DOZE_PULSE_ON_DOUBLE_TAP, 1);
|
||||||
addPreference(PREF_KEY_DOUBLE_TAP_SCREEN, doubleTap != 0, PREF_ID_DOUBLE_TAP_SCREEN);
|
addPreference(PREF_KEY_DOUBLE_TAP_SCREEN, doubleTap != 0);
|
||||||
} else {
|
} else {
|
||||||
removePreference(PREF_KEY_DOUBLE_TAP_SCREEN);
|
removePreference(PREF_KEY_DOUBLE_TAP_SCREEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fingerprint slide for notifications
|
// Fingerprint slide for notifications
|
||||||
if (isSystemUINavigationAvailable(context)) {
|
if (isSystemUINavigationAvailable(context)) {
|
||||||
addPreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT, isSystemUINavigationEnabled(context),
|
addPreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT, isSystemUINavigationEnabled(context));
|
||||||
PREF_ID_SWIPE_DOWN_FINGERPRINT);
|
|
||||||
} else {
|
} else {
|
||||||
removePreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT);
|
removePreference(PREF_KEY_SWIPE_DOWN_FINGERPRINT);
|
||||||
}
|
}
|
||||||
@@ -107,7 +101,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);
|
||||||
addPreference(PREF_KEY_DOUBLE_TWIST, doubleTwistEnabled != 0, PREF_ID_DOUBLE_TWIST);
|
addPreference(PREF_KEY_DOUBLE_TWIST, doubleTwistEnabled != 0);
|
||||||
} else {
|
} else {
|
||||||
removePreference(PREF_KEY_DOUBLE_TWIST);
|
removePreference(PREF_KEY_DOUBLE_TWIST);
|
||||||
}
|
}
|
||||||
@@ -234,11 +228,10 @@ public class GestureSettings extends SettingsPreferenceFragment implements
|
|||||||
R.bool.config_gesture_double_tap_settings_enabled);
|
R.bool.config_gesture_double_tap_settings_enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addPreference(String key, boolean enabled, int id) {
|
private void addPreference(String key, boolean enabled) {
|
||||||
GesturePreference preference = (GesturePreference) findPreference(key);
|
GesturePreference preference = (GesturePreference) findPreference(key);
|
||||||
preference.setChecked(enabled);
|
preference.setChecked(enabled);
|
||||||
preference.setOnPreferenceChangeListener(this);
|
preference.setOnPreferenceChangeListener(this);
|
||||||
preference.loadPreview(getLoaderManager(), id);
|
|
||||||
mPreferences.add(preference);
|
mPreferences.add(preference);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user