Animate drawer icon into arrow on setDisplayHomeAsUpEnabled?

前端 未结 3 695
一个人的身影
一个人的身影 2020-12-07 18:21

I\'m using setDisplayHomeAsUpEnabled in order to show the arrow instead of the drawer \"burger\" icon but it\'s not getting animated or anything. Instead it shows the arrow

相关标签:
3条回答
  • 2020-12-07 18:34

    Since the question was asked, an alternative way has become available. The animated arrow is implemented by the now public class DrawerArrowDrawable which implements Drawable.

    In your code, set the navigation icon as follows:

    DrawerArrowDrawable drawerArrow = new DrawerArrowDrawable(this);
    drawerArrow.setColor(myColor);
    
    toolbar.setNavigationIcon(drawerArrow);
    

    Register an OnBackStackChangedListener and animate the arrow manually:

    @Override
    public void onBackStackChanged() {
        boolean drawer = getSupportFragmentManager().getBackStackEntryCount() == 0;
        ObjectAnimator.ofFloat(drawerArrow, "progress", drawer ? 0 : 1).start();
    }
    
    0 讨论(0)
  • 2020-12-07 18:49

    Sounds like it's working as intended, you can use setDisplayHomeAsUpEnabled to simply enable the home button to be used as a back button, there is no animation.

    If you're using a navigation drawer and want the animation don't use setDisplayHomeAsUpEnabled and for material theme (at least with AppCompat v21) make sure you use ActionBarDrawerToggle from the v7 package.

    The Play Store is a good example. At the top level you have an activity with a nav drawer and a hamburger that animates when you open the drawer. If you tap on an app it opens a new activity that has a back arrow.

    0 讨论(0)
  • 2020-12-07 18:54

    I haven't tested this, but you may be able to achieve this by animating a float between 0 (drawer closed) and 1 (drawer open) and then passing the value into ActionBarDrawerToggle.onDrawerSlide(View, float). I believe that's how the toggle determines what state the animated toggle should be in.

    Something like this should work.

    ValueAnimator anim = ValueAnimator.ofFloat(start, end);
    anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
        @Override
        public void onAnimationUpdate(ValueAnimator valueAnimator) {
            float slideOffset = (Float) valueAnimator.getAnimatedValue();
            toolbarDrawerToggle.onDrawerSlide(drawerLayout, slideOffset);
        }
    });
    anim.setInterpolator(new DecelerateInterpolator());
    // You can change this duration to more closely match that of the default animation.
    anim.setDuration(500);
    anim.start();
    
    0 讨论(0)
提交回复
热议问题