Bar*_*urg 7 animation android android-actionbar
我发现很多关于如何禁用Android ActionBar动画的问题.我有完全相反的问题.我想要动画,但它应该开箱即用吗?
我认为问题在于我的自定义工具栏:
<android.support.design.widget.AppBarLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="wrap_content"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar_parent"
android:layout_width="match_parent"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar android:id="@+id/toolbar"
android:layout_width="match_parent" android:layout_height="@dimen/menu_height"
android:minHeight="@dimen/menu_height"
android:background="@color/backgroundColor" app:popupTheme="@style/AppTheme.PopupOverlay"
android:theme="@style/ToolbarColoredBackArrow"/>
</android.support.design.widget.AppBarLayout>
Run Code Online (Sandbox Code Playgroud)
我在mij活动中设置如下:
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
Run Code Online (Sandbox Code Playgroud)
工具栏工作正常,但我调用这些方法之一时没有动画:
protected void hideActionBar(){
ActionBar ab = getSupportActionBar();
if (ab.isShowing()) {
ab.hide();
}
}
protected void showActionBar(){
ActionBar ab = getSupportActionBar();
if (!ab.isShowing()) {
ab.show();
}
}
Run Code Online (Sandbox Code Playgroud)
这是什么原因?
Vik*_*ram 17
请放弃我上面的评论.我对此做了一些研究,上面的建议并不重要.
打电话时setSupportActionBar(Toolbar),会发生以下情况:
public void setSupportActionBar(Toolbar toolbar) {
....
ToolbarActionBar tbab = new ToolbarActionBar(toolbar, ((Activity) mContext).getTitle(),
mAppCompatWindowCallback);
mActionBar = tbab;
....
}
Run Code Online (Sandbox Code Playgroud)
所以,后续调用getSupportActionBar()返回一个实例ToolbarActionBar.看看这个类如何实现我们感兴趣的功能:
setShowHideAnimationEnabled(boolean):正如你所说,这种方法没有区别.
@Override
public void setShowHideAnimationEnabled(boolean enabled) {
// This space for rent; no-op.
}
Run Code Online (Sandbox Code Playgroud)
show():仅使操作栏可见 - 没有动画支持.
@Override
public void show() {
// TODO: Consider a better transition for this.
// Right now use no automatic transition so that the app can supply one if desired.
mDecorToolbar.setVisibility(View.VISIBLE);
}
Run Code Online (Sandbox Code Playgroud)
hide():仅使操作栏可见 - 再次,没有动画支持.
@Override
public void hide() {
// TODO: Consider a better transition for this.
// Right now use no automatic transition so that the app can supply one if desired.
mDecorToolbar.setVisibility(View.GONE);
}
Run Code Online (Sandbox Code Playgroud)
评论show()并hide()暗示开发人员应提供动画过渡.也许,这样的事情:
protected void hideActionBar(){
final ActionBar ab = getSupportActionBar();
if (ab != null && ab.isShowing()) {
if(mToolbar != null) {
mToolbar.animate().translationY(-112).setDuration(600L)
.withEndAction(new Runnable() {
@Override
public void run() {
ab.hide();
}
}).start();
} else {
ab.hide();
}
}
}
protected void showActionBar(){
ActionBar ab = getSupportActionBar();
if (ab != null && !ab.isShowing()) {
ab.show();
if(mToolbar != null) {
mToolbar.animate().translationY(0).setDuration(600L).start();
}
}
}
Run Code Online (Sandbox Code Playgroud)
该mToolbar.animate().....部分是从内存中编写的 - 语法可能不正确:(.您还可以添加.alpha(0(during hide) or 1(during show))以使转换看起来更好.
执行:
现在应该清楚的是,getSupportActionBar().show() & hide()不关心你对Toolbar这些方法调用你做了什么.此外,您的活动内部Toolbar将被视为任何其他View内容.记住这些要点,问题归结为 - 我们如何设置隐藏(以及稍后显示)的动画View.由于我们需要将Activity内容与隐藏(或显示)一起滑动Toolbar,我建议以下实现.请注意,这只是一个基本的普通程序.你可以肯定地微调这个,或者提出一个完全不同的(更好的阅读)动画过渡:
// holds the original Toolbar height.
// this can also be obtained via (an)other method(s)
int mToolbarHeight, mAnimDuration = 600/* milliseconds */;
ValueAnimator mVaActionBar;
void hideActionBar() {
// initialize `mToolbarHeight`
if (mToolbarHeight == 0) {
mToolbarHeight = mToolbar.getHeight();
}
if (mVaActionBar != null && mVaActionBar.isRunning()) {
// we are already animating a transition - block here
return;
}
// animate `Toolbar's` height to zero.
mVaActionBar = ValueAnimator.ofInt(mToolbarHeight , 0);
mVaActionBar.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
// update LayoutParams
((AppBarLayout.LayoutParams)mToolbar.getLayoutParams()).height
= (Integer)animation.getAnimatedValue();
mToolbar.requestLayout();
}
});
mVaActionBar.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationEnd(Animator animation) {
super.onAnimationEnd(animation);
if (getSupportActionBar() != null) { // sanity check
getSupportActionBar().hide();
}
}
});
mVaActionBar.setDuration(mAnimDuration);
mVaActionBar.start();
}
void showActionBar() {
if (mVaActionBar != null && mVaActionBar.isRunning()) {
// we are already animating a transition - block here
return;
}
// restore `Toolbar's` height
mVaActionBar = ValueAnimator.ofInt(0 , mToolbarHeight);
mVaActionBar.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
// update LayoutParams
((AppBarLayout.LayoutParams)mToolbar.getLayoutParams()).height
= (Integer)animation.getAnimatedValue();
mToolbar.requestLayout();
}
});
mVaActionBar.addListener(new AnimatorListenerAdapter() {
@Override
public void onAnimationStart(Animator animation) {
super.onAnimationStart(animation);
if (getSupportActionBar() != null) { // sanity check
getSupportActionBar().show();
}
}
});
mVaActionBar.setDuration(mAnimDuration);
mVaActionBar.start();
}
Run Code Online (Sandbox Code Playgroud)
在你的评论中,你提到过I do see an animation now but the space still gets reserved for the toolbar until ab.hide() happens.对我来说,这意味着你正在使用AppBarLayout托管Toolbar.如果不是这样,请告诉我,我们会解决一些问题.
最后,将根据以下内容调度对这些方法的调用:
if (getSupportActionBar().isShowing()) {
hideActionBar();
} else {
showActionBar();
}
Run Code Online (Sandbox Code Playgroud)
如果您使用默认动画隐藏或显示,请尝试以下操作:
添加android:animateLayoutChanges="true"您的父母toolbar在这种情况下AppBarLayout
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay"
android:animateLayoutChanges="true">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay"
/>
</android.support.design.widget.AppBarLayout>
Run Code Online (Sandbox Code Playgroud)
切换hide和 代码show
final ActionBar actionBar = getSupportActionBar();
if (actionBar != null) {
if (actionBar.isShowing()) {
actionBar.hide();
} else {
actionBar.show();
}
}
Run Code Online (Sandbox Code Playgroud)
您可以在xml中使用以下代码,即,当您调用hide/show时,工具栏父级可以为其设置动画.
android:animateLayoutChanges="true"
Run Code Online (Sandbox Code Playgroud)
或这个
藏
toolbarParent.animate().translationY(-toolbarHeight).setInterpolator(new AccelerateInterpolator(2)).start();
Run Code Online (Sandbox Code Playgroud)
显示
toolbarParent.animate().translationY(0).setInterpolator(new DecelerateInterpolator(2)).start();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8622 次 |
| 最近记录: |