Merge "[PB8] Add an animation upon status change."

This commit is contained in:
Jean Chalard 2013-04-25 11:04:58 +00:00 committed by Android (Google) Code Review
commit fb34869f5a
3 changed files with 42 additions and 8 deletions

View file

@ -16,9 +16,12 @@
package com.android.inputmethod.dictionarypack; package com.android.inputmethod.dictionarypack;
import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.content.Context; import android.content.Context;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.view.View; import android.view.View;
import android.view.ViewPropertyAnimator;
import android.widget.Button; import android.widget.Button;
import android.widget.FrameLayout; import android.widget.FrameLayout;
@ -115,22 +118,35 @@ public class ButtonSwitcher extends FrameLayout {
} }
private void animateButtonPosition(final int oldStatus, final int newStatus) { private void animateButtonPosition(final int oldStatus, final int newStatus) {
animateButton(getButton(oldStatus), ANIMATION_OUT); final View oldButton = getButton(oldStatus);
animateButton(getButton(newStatus), ANIMATION_IN); final View newButton = getButton(newStatus);
if (null != oldButton && null != newButton) {
// Transition between two buttons : animate out, then in
animateButton(oldButton, ANIMATION_OUT).setListener(
new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(final Animator animation) {
animateButton(newButton, ANIMATION_IN);
}
});
} else if (null != oldButton) {
animateButton(oldButton, ANIMATION_OUT);
} else if (null != newButton) {
animateButton(newButton, ANIMATION_IN);
}
} }
public void setInternalOnClickListener(final OnClickListener listener) { public void setInternalOnClickListener(final OnClickListener listener) {
mOnClickListener = listener; mOnClickListener = listener;
} }
private void animateButton(final View button, final int direction) { private ViewPropertyAnimator animateButton(final View button, final int direction) {
if (null == button) return;
final float outerX = getWidth(); final float outerX = getWidth();
final float innerX = button.getX() - button.getTranslationX(); final float innerX = button.getX() - button.getTranslationX();
if (ANIMATION_IN == direction) { if (ANIMATION_IN == direction) {
button.animate().translationX(0); return button.animate().translationX(0);
} else { } else {
button.animate().translationX(outerX - innerX); return button.animate().translationX(outerX - innerX);
} }
} }
} }

View file

@ -44,6 +44,12 @@ public class DictionaryListInterfaceState {
return state.mOpen; return state.mOpen;
} }
public int getStatus(final String wordlistId) {
final State state = mWordlistToState.get(wordlistId);
if (null == state) return MetadataDbHelper.STATUS_UNKNOWN;
return state.mStatus;
}
public void setOpen(final String wordlistId, final int status) { public void setOpen(final String wordlistId, final int status) {
final State newState; final State newState;
final State state = mWordlistToState.get(wordlistId); final State state = mWordlistToState.get(wordlistId);

View file

@ -191,8 +191,20 @@ public final class WordListPreference extends Preference {
((ViewGroup)view).setLayoutTransition(null); ((ViewGroup)view).setLayoutTransition(null);
final ButtonSwitcher buttonSwitcher = final ButtonSwitcher buttonSwitcher =
(ButtonSwitcher)view.findViewById(R.id.wordlist_button_switcher); (ButtonSwitcher)view.findViewById(R.id.wordlist_button_switcher);
buttonSwitcher.setStatusAndUpdateVisuals(mInterfaceState.isOpen(mWordlistId) ? if (mInterfaceState.isOpen(mWordlistId)) {
getButtonSwitcherStatus(mStatus) : ButtonSwitcher.STATUS_NO_BUTTON); // The button is open.
final int previousStatus = mInterfaceState.getStatus(mWordlistId);
buttonSwitcher.setStatusAndUpdateVisuals(getButtonSwitcherStatus(previousStatus));
if (previousStatus != mStatus) {
// We come here if the status has changed since last time. We need to animate
// the transition.
buttonSwitcher.setStatusAndUpdateVisuals(getButtonSwitcherStatus(mStatus));
mInterfaceState.setOpen(mWordlistId, mStatus);
}
} else {
// The button is closed.
buttonSwitcher.setStatusAndUpdateVisuals(ButtonSwitcher.STATUS_NO_BUTTON);
}
buttonSwitcher.setInternalOnClickListener(mActionButtonClickHandler); buttonSwitcher.setInternalOnClickListener(mActionButtonClickHandler);
view.setOnClickListener(mPreferenceClickHandler); view.setOnClickListener(mPreferenceClickHandler);
} }