From 63ba8a5ac1de99f948b19c5cd756e7643c4a44cd Mon Sep 17 00:00:00 2001 From: DrKLO Date: Wed, 4 Jun 2014 22:57:11 +0400 Subject: [PATCH] Let swipe back from any place --- TMessagesProj/build.gradle | 2 +- .../java/org/telegram/ui/ChatActivity.java | 3 + .../ui/Views/ActionBar/ActionBarActivity.java | 219 ++++++++++-------- .../ui/Views/ActionBar/BaseFragment.java | 8 +- 4 files changed, 132 insertions(+), 100 deletions(-) diff --git a/TMessagesProj/build.gradle b/TMessagesProj/build.gradle index fadcebab..192c8238 100644 --- a/TMessagesProj/build.gradle +++ b/TMessagesProj/build.gradle @@ -82,7 +82,7 @@ android { defaultConfig { minSdkVersion 8 targetSdkVersion 19 - versionCode 236 + versionCode 237 versionName "1.4.15" } } diff --git a/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java index f8dc297b..239700f5 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java @@ -35,6 +35,7 @@ import android.text.Html; import android.text.TextUtils; import android.text.TextWatcher; import android.text.style.ImageSpan; +import android.util.Log; import android.util.TypedValue; import android.view.Gravity; import android.view.KeyEvent; @@ -542,6 +543,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa clipboard.setPrimaryClip(clip); } } + actionBarLayer.hideActionMode(); } else if (id == delete) { ArrayList ids = new ArrayList(selectedMessagesIds.keySet()); ArrayList random_ids = null; @@ -555,6 +557,7 @@ public class ChatActivity extends BaseFragment implements SizeNotifierRelativeLa } } MessagesController.getInstance().deleteMessages(ids, random_ids, currentEncryptedChat); + actionBarLayer.hideActionMode(); } else if (id == forward) { Bundle args = new Bundle(); args.putBoolean("onlySelect", true); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/ActionBarActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/ActionBarActivity.java index 1e9eeeca..191664c1 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/ActionBarActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/ActionBarActivity.java @@ -12,6 +12,7 @@ import android.animation.Animator; import android.animation.AnimatorSet; import android.animation.ObjectAnimator; import android.app.Activity; +import android.content.Context; import android.content.pm.ActivityInfo; import android.content.res.Configuration; import android.os.Build; @@ -47,6 +48,7 @@ public class ActionBarActivity extends Activity { private Animation openAnimation; private Animation closeAnimation; + private boolean maybeStartTracking = false; private boolean startedTracking = false; private int startedTrackingX; private int prevOrientation = -10; @@ -57,6 +59,24 @@ public class ActionBarActivity extends Activity { private long transitionAnimationStartTime; private boolean inActionMode = false; + private class FrameLayoutTouch extends FrameLayout { + public FrameLayoutTouch(Context context) { + super(context); + } + + @Override + public boolean onInterceptTouchEvent(MotionEvent ev) { + return ((ActionBarActivity)getContext()).onTouchEvent(ev); + //return super.onInterceptTouchEvent(ev); + } + + @Override + public void requestDisallowInterceptTouchEvent(boolean disallowIntercept) { + ((ActionBarActivity)getContext()).onTouchEvent(null); + super.requestDisallowInterceptTouchEvent(disallowIntercept); + } + } + public static ArrayList fragmentsStack = new ArrayList(); protected void onCreateFinish(Bundle savedInstanceState) { @@ -77,7 +97,7 @@ public class ActionBarActivity extends Activity { setTheme(R.style.Theme_TMessages); getWindow().setBackgroundDrawableResource(R.drawable.transparent); - contentView = new FrameLayout(this); + contentView = new FrameLayoutTouch(this); setContentView(contentView, new ViewGroup.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT, FrameLayout.LayoutParams.MATCH_PARENT)); containerViewBack = new FrameLayout(this); @@ -185,65 +205,69 @@ public class ActionBarActivity extends Activity { animationInProgress = false; } - @Override - public boolean dispatchTouchEvent(MotionEvent ev) { - if(android.os.Build.VERSION.SDK_INT >= 11 && !checkTransitionAnimation() && !inActionMode) { - if (ev.getAction() == MotionEvent.ACTION_DOWN && !startedTracking && ev.getX() <= Utilities.dp(6) && fragmentsStack.size() > 1) { - startedTracking = true; + public boolean onTouchEvent(MotionEvent ev) { + if(android.os.Build.VERSION.SDK_INT >= 11 && !checkTransitionAnimation() && !inActionMode && fragmentsStack.size() > 1 && !animationInProgress) { + if (ev != null && ev.getAction() == MotionEvent.ACTION_DOWN && !startedTracking && !maybeStartTracking) { + maybeStartTracking = true; startedTrackingX = (int) ev.getX(); - shadowView.setVisibility(View.VISIBLE); - shadowView.setX(-Utilities.dp(2)); - containerViewBack.setVisibility(View.VISIBLE); - beginTrackingSent = false; + } else if (ev != null && ev.getAction() == MotionEvent.ACTION_MOVE) { + int dx = Math.max(0, (int) (ev.getX() - startedTrackingX)); + if (maybeStartTracking && !startedTracking && dx >= Utilities.dp(10)) { + maybeStartTracking = false; + startedTracking = true; + startedTrackingX = (int) ev.getX(); + shadowView.setVisibility(View.VISIBLE); + shadowView.setX(-Utilities.dp(2)); + containerViewBack.setVisibility(View.VISIBLE); + beginTrackingSent = false; - BaseFragment lastFragment = fragmentsStack.get(fragmentsStack.size() - 2); - actionBar.prepareForMoving(lastFragment.actionBarLayer); - View fragmentView = lastFragment.createView(getLayoutInflater(), null); - ViewGroup parentView = (ViewGroup)fragmentView.getParent(); - if (parentView != null) { - parentView.removeView(fragmentView); - } - containerViewBack.addView(fragmentView); - ViewGroup.LayoutParams layoutParams = fragmentView.getLayoutParams(); - layoutParams.width = FrameLayout.LayoutParams.MATCH_PARENT; - layoutParams.height = FrameLayout.LayoutParams.MATCH_PARENT; - fragmentView.setLayoutParams(layoutParams); - if (fragmentView.getBackground() == null) { - fragmentView.setBackgroundColor(0xffffffff); - } - lastFragment.onResume(); + BaseFragment lastFragment = fragmentsStack.get(fragmentsStack.size() - 2); + actionBar.prepareForMoving(lastFragment.actionBarLayer); + View fragmentView = lastFragment.createView(getLayoutInflater(), null); + ViewGroup parentView = (ViewGroup)fragmentView.getParent(); + if (parentView != null) { + parentView.removeView(fragmentView); + } + containerViewBack.addView(fragmentView); + ViewGroup.LayoutParams layoutParams = fragmentView.getLayoutParams(); + layoutParams.width = FrameLayout.LayoutParams.MATCH_PARENT; + layoutParams.height = FrameLayout.LayoutParams.MATCH_PARENT; + fragmentView.setLayoutParams(layoutParams); + if (fragmentView.getBackground() == null) { + fragmentView.setBackgroundColor(0xffffffff); + } + lastFragment.onResume(); - try { - prevOrientation = getRequestedOrientation(); - WindowManager manager = (WindowManager)getSystemService(Activity.WINDOW_SERVICE); - if (manager != null && manager.getDefaultDisplay() != null) { - int rotation = manager.getDefaultDisplay().getRotation(); - if (rotation == Surface.ROTATION_270) { - if (Build.VERSION.SDK_INT >= 9) { - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE); - } else { + try { + prevOrientation = getRequestedOrientation(); + WindowManager manager = (WindowManager)getSystemService(Activity.WINDOW_SERVICE); + if (manager != null && manager.getDefaultDisplay() != null) { + int rotation = manager.getDefaultDisplay().getRotation(); + if (rotation == Surface.ROTATION_270) { + if (Build.VERSION.SDK_INT >= 9) { + setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE); + } else { + setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); + } + } else if (rotation == Surface.ROTATION_90) { setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); - } - } else if (rotation == Surface.ROTATION_90) { - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); - } else if (rotation == Surface.ROTATION_0) { - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT); - } else { - if (Build.VERSION.SDK_INT >= 9) { - setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT); + } else if (rotation == Surface.ROTATION_0) { + setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT); + } else { + if (Build.VERSION.SDK_INT >= 9) { + setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT); + } } } + } catch (Exception e) { + FileLog.e("tmessages", e); } - } catch (Exception e) { - FileLog.e("tmessages", e); - } - if (velocityTracker == null) { - velocityTracker = VelocityTracker.obtain(); - } else { - velocityTracker.clear(); - } - } else if (startedTracking && !animationInProgress) { - if (ev.getAction() == MotionEvent.ACTION_MOVE) { + if (velocityTracker == null) { + velocityTracker = VelocityTracker.obtain(); + } else { + velocityTracker.clear(); + } + } else if (startedTracking) { if (!beginTrackingSent) { if (getCurrentFocus() != null) { Utilities.hideKeyboard(getCurrentFocus()); @@ -253,60 +277,65 @@ public class ActionBarActivity extends Activity { beginTrackingSent = true; } velocityTracker.addMovement(ev); - int dx = Math.max(0, (int) (ev.getX() - startedTrackingX)); actionBar.moveActionBarByX(dx); containerView.setX(dx); shadowView.setX(dx - Utilities.dp(2)); - } else if (ev.getAction() == MotionEvent.ACTION_CANCEL || ev.getAction() == MotionEvent.ACTION_UP) { - velocityTracker.computeCurrentVelocity(1000); - float x = containerView.getX(); - ArrayList animators = new ArrayList(); - final boolean backAnimation = x < containerView.getMeasuredWidth() / 3.0f && velocityTracker.getXVelocity() < 6000; - float distToMove = 0; - if (!backAnimation) { - distToMove = containerView.getMeasuredWidth() - x; - animators.add(ObjectAnimator.ofFloat(containerView, "x", containerView.getMeasuredWidth())); - animators.add(ObjectAnimator.ofFloat(shadowView, "x", containerView.getMeasuredWidth() - Utilities.dp(2))); - } else { - distToMove = x; - animators.add(ObjectAnimator.ofFloat(containerView, "x", 0)); - animators.add(ObjectAnimator.ofFloat(shadowView, "x", -Utilities.dp(2))); + } + } else if (ev != null && startedTracking && (ev.getAction() == MotionEvent.ACTION_CANCEL || ev.getAction() == MotionEvent.ACTION_UP)) { + velocityTracker.computeCurrentVelocity(1000); + float x = containerView.getX(); + ArrayList animators = new ArrayList(); + final boolean backAnimation = x < containerView.getMeasuredWidth() / 3.0f && velocityTracker.getXVelocity() < 6000; + float distToMove = 0; + if (!backAnimation) { + distToMove = containerView.getMeasuredWidth() - x; + animators.add(ObjectAnimator.ofFloat(containerView, "x", containerView.getMeasuredWidth())); + animators.add(ObjectAnimator.ofFloat(shadowView, "x", containerView.getMeasuredWidth() - Utilities.dp(2))); + } else { + distToMove = x; + animators.add(ObjectAnimator.ofFloat(containerView, "x", 0)); + animators.add(ObjectAnimator.ofFloat(shadowView, "x", -Utilities.dp(2))); + } + actionBar.setupAnimations(animators, backAnimation); + + AnimatorSet animatorSet = new AnimatorSet(); + animatorSet.playTogether(animators); + animatorSet.setDuration((int)(200.0f / containerView.getMeasuredWidth() * distToMove)); + animatorSet.start(); + animationInProgress = true; + animatorSet.addListener(new Animator.AnimatorListener() { + @Override + public void onAnimationStart(Animator animator) { + } - actionBar.setupAnimations(animators, backAnimation); - AnimatorSet animatorSet = new AnimatorSet(); - animatorSet.playTogether(animators); - animatorSet.setDuration((int)(200.0f / containerView.getMeasuredWidth() * distToMove)); - animatorSet.start(); - animationInProgress = true; - animatorSet.addListener(new Animator.AnimatorListener() { - @Override - public void onAnimationStart(Animator animator) { + @Override + public void onAnimationEnd(Animator animator) { + onSlideAnimationEnd(backAnimation); + } - } + @Override + public void onAnimationCancel(Animator animator) { + onSlideAnimationEnd(backAnimation); + } - @Override - public void onAnimationEnd(Animator animator) { - onSlideAnimationEnd(backAnimation); - } + @Override + public void onAnimationRepeat(Animator animator) { - @Override - public void onAnimationCancel(Animator animator) { - onSlideAnimationEnd(backAnimation); - } - - @Override - public void onAnimationRepeat(Animator animator) { - - } - }); + } + }); + velocityTracker.recycle(); + velocityTracker = null; + } else if (ev == null) { + maybeStartTracking = false; + startedTracking = false; + if (velocityTracker != null) { velocityTracker.recycle(); - velocityTracker = null; } } - return startedTracking || super.dispatchTouchEvent(ev); + return startedTracking; } - return super.dispatchTouchEvent(ev); + return false; } @Override diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/BaseFragment.java b/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/BaseFragment.java index cc577693..408cac29 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/BaseFragment.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Views/ActionBar/BaseFragment.java @@ -51,11 +51,11 @@ public class BaseFragment { } fragmentView = null; } - if (actionBarLayer != null) { - actionBarLayer.onDestroy(); - actionBarLayer = null; - } if (parentActivity != null) { + if (actionBarLayer != null) { + actionBarLayer.onDestroy(); + actionBarLayer = null; + } actionBarLayer = parentActivity.getInternalActionBar().createLayer(); } }