android fab 动画,android - 轻扫单行Snackbar时,FAB没有动画

我有一个支持CoordinatorLayout的FloatingActionButton,我想在其中显示Snackbar ..

android:id="@+id/rootView"

xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:layout_width="match_parent"

android:layout_height="match_parent">

...

android:id="@+id/fab_add_field"

xmlns:app="http://schemas.android.com/apk/res-auto"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="end|bottom"

android:layout_margin="@dimen/margin_default"

android:layout_marginBottom="@dimen/profile_floating_margin_bottom"

android:layout_marginRight="@dimen/profile_floating_margin_right"

android:clickable="true"

android:src="@drawable/icon_plus"

app:backgroundTint="@color/brand_green"

app:borderWidth="0dp"

app:elevation="@dimen/fac_icon_elevation"/>

现在,我正在显示像这样的 snackbar

Snackbar.make(mRootView, "Something went wrong", Snackbar.LENGHT_SHORT)

.show();

显示时,FAB向上滑动,当它消失后(在LENGHT_SHORT之后),FAB向下滑动,一切正常。

但是,如果我将Snackbar滑动了一下,FAB将向下移动而没有幻灯片动画。它只是闪烁到其初始位置。

有趣的是,如果Snackbar有两行(无论是否有 Action )并被扫除,则FAB会使用通常的幻灯片动画正确地动画回到其位置。

那是android.support.design.widget.CoordinatorLayout中的错误吗

或android.support.design.widget.FloatingActionButton?任何解决方法?

最佳答案

Kotlin解决方案,不使用基于Matteo Destro's post的ValueAnimator:class SnackBarAwareBehavior : CoordinatorLayout.Behavior {

companion object {

private const val DURATION = 180

}

constructor() : super() {}

constructor(context: Context, attrs: AttributeSet) : super(context, attrs) {}

override fun layoutDependsOn(

parent: CoordinatorLayout,

child: View,

dependency: View

): Boolean {

return dependency is Snackbar.SnackbarLayout

}

override fun onDependentViewChanged(

parent: CoordinatorLayout,

child: View,

dependency: View

): Boolean {

if (dependency.visibility == View.VISIBLE) {

moveChildUp(child, dependency.height + dependency.marginBottom)

return true

}

return false

}

override fun onDependentViewRemoved(parent: CoordinatorLayout, child: View, dependency: View) {

moveChildToInitialPosition(child)

}

private fun moveChildUp(child: View, translation: Int) {

child.animate()

.translationY((-translation).toFloat())

.setInterpolator(DecelerateInterpolator())

.setDuration(DURATION.toLong())

.start()

}

private fun moveChildToInitialPosition(child: View) {

child.animate()

.translationY(0f)

.setInterpolator(AccelerateInterpolator())

.setDuration(DURATION.toLong())

.start()

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值