mirror of
				https://github.com/oxen-io/session-android.git
				synced 2025-10-25 03:09:05 +00:00 
			
		
		
		
	Fix for toggle behavior during rapid clear/fill cycles.
Fixes #3235 Closes #3239 // FREEBIE
This commit is contained in:
		| @@ -1189,7 +1189,12 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity | ||||
|       calculateCharactersRemaining(); | ||||
|  | ||||
|       if (composeText.getText().length() == 0 || beforeLength == 0) { | ||||
|         updateToggleButtonState(); | ||||
|         composeText.postDelayed(new Runnable() { | ||||
|           @Override | ||||
|           public void run() { | ||||
|             updateToggleButtonState(); | ||||
|           } | ||||
|         }, 50); | ||||
|       } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,8 @@ public class AnimatingToggle extends FrameLayout { | ||||
|  | ||||
|   private static final int SPEED_MILLIS = 200; | ||||
|  | ||||
|   private View current; | ||||
|  | ||||
|   public AnimatingToggle(Context context) { | ||||
|     super(context); | ||||
|   } | ||||
| @@ -30,14 +32,18 @@ public class AnimatingToggle extends FrameLayout { | ||||
|   public void addView(@NonNull View child, int index, ViewGroup.LayoutParams params) { | ||||
|     super.addView(child, index, params); | ||||
|  | ||||
|     if (getChildCount() == 1) child.setVisibility(View.VISIBLE); | ||||
|     else                      child.setVisibility(View.GONE); | ||||
|     if (getChildCount() == 1) { | ||||
|       current = child; | ||||
|       child.setVisibility(View.VISIBLE); | ||||
|     } else { | ||||
|       child.setVisibility(View.GONE); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public void display(View view) { | ||||
|     if (view.getVisibility() == View.VISIBLE) return; | ||||
|     if (view == current) return; | ||||
|  | ||||
|     int oldViewIndex = getVisibleViewIndex(); | ||||
|     int oldViewIndex = getViewIndex(current); | ||||
|     int newViewIndex = getViewIndex(view); | ||||
|  | ||||
|     int sign; | ||||
| @@ -48,14 +54,13 @@ public class AnimatingToggle extends FrameLayout { | ||||
|     TranslateAnimation oldViewAnimation = createTranslation(0.0f, sign * 1.0f); | ||||
|     TranslateAnimation newViewAnimation = createTranslation(sign * -1.0f, 0.0f); | ||||
|  | ||||
|     animateOut(oldViewIndex, oldViewAnimation); | ||||
|     animateIn(newViewIndex, newViewAnimation); | ||||
|     animateOut(current, oldViewAnimation); | ||||
|     animateIn(view, newViewAnimation); | ||||
|  | ||||
|     current = view; | ||||
|   } | ||||
|  | ||||
|   private void animateOut(int viewIndex, TranslateAnimation animation) { | ||||
|     final View view = getChildAt(viewIndex); | ||||
|  | ||||
|     animation.setInterpolator(new FastOutSlowInInterpolator()); | ||||
|   private void animateOut(final View view, TranslateAnimation animation) { | ||||
|     animation.setAnimationListener(new Animation.AnimationListener() { | ||||
|       @Override | ||||
|       public void onAnimationStart(Animation animation) { | ||||
| @@ -74,21 +79,12 @@ public class AnimatingToggle extends FrameLayout { | ||||
|     view.startAnimation(animation); | ||||
|   } | ||||
|  | ||||
|   private void animateIn(int viewIndex, TranslateAnimation animation) { | ||||
|   private void animateIn(View view, TranslateAnimation animation) { | ||||
|     animation.setInterpolator(new FastOutSlowInInterpolator()); | ||||
|     final View view = getChildAt(viewIndex); | ||||
|     view.setVisibility(View.VISIBLE); | ||||
|     view.startAnimation(animation); | ||||
|   } | ||||
|  | ||||
|   private int getVisibleViewIndex() { | ||||
|     for (int i=0;i<getChildCount();i++) { | ||||
|       if (getChildAt(i).getVisibility() == View.VISIBLE) return i; | ||||
|     } | ||||
|  | ||||
|     throw new AssertionError("No visible view?"); | ||||
|   } | ||||
|  | ||||
|   private int getViewIndex(View view) { | ||||
|     for (int i=0;i<getChildCount();i++) { | ||||
|       if (getChildAt(i) == view) return i; | ||||
| @@ -104,6 +100,7 @@ public class AnimatingToggle extends FrameLayout { | ||||
|                                                                    Animation.RELATIVE_TO_SELF, endY); | ||||
|  | ||||
|     translateAnimation.setDuration(SPEED_MILLIS); | ||||
|     translateAnimation.setInterpolator(new FastOutSlowInInterpolator()); | ||||
|  | ||||
|     return translateAnimation; | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Moxie Marlinspike
					Moxie Marlinspike