Mar*_*Bro 8 android floating-action-button snackbar android-snackbar android-coordinatorlayout
我有一个CoordinatorLayout支持FloatingActionButton我想要显示Snackbar..
<android.support.design.widget.CoordinatorLayout
android:id="@+id/rootView"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
...
</RelativeLayout>
<android.support.design.widget.FloatingActionButton
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"/>
</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)
现在我正在展示Snackbar
Snackbar.make(mRootView, "Something went wrong", Snackbar.LENGHT_SHORT)
.show();
Run Code Online (Sandbox Code Playgroud)
当它显示时,FAB向上滑动,当它(在LENGHT_SHORT之后)消失时,FAB向下滑动,一切正常.
但是,如果我将Snackbar向外滑动,FAB会在没有幻灯片动画的情况下向下移动.它只是闪现到它的初始位置.
有趣的是,如果Snackbar有两条线(无论是否有动作)并被轻扫,FAB会使用通常的幻灯片动画正确地动画回到它的位置.
这是一个bug android.support.design.widget.CoordinatorLayout
还是android.support.design.widget.FloatingActionButton?有什么解决方法吗?
我最近遇到了同样的问题,我最终为 FAB 创建了一个自定义布局行为类,以便在小吃栏滑开时执行动画。
创建这个类:
public class SnackbarAwareBehavior extends CoordinatorLayout.Behavior<View> {
private static final int ANIMATION_DURATION = 180;
public SnackbarAwareBehavior() {
super();
}
public SnackbarAwareBehavior(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean layoutDependsOn(@NonNull CoordinatorLayout parent, @NonNull View child, @NonNull View dependency) {
return dependency instanceof Snackbar.SnackbarLayout;
}
@Override
public boolean onDependentViewChanged(@NonNull CoordinatorLayout parent, @NonNull View child, @NonNull View dependency) {
if (dependency.getVisibility() == View.VISIBLE) {
// Change the translation of the FAB only if the snackbar is visible
child.setTranslationY(dependency.getTranslationY() - getTranslationYBottom(dependency));
return true;
}
return false;
}
@Override
public void onDependentViewRemoved(@NonNull CoordinatorLayout parent, @NonNull View child, @NonNull View dependency) {
if (dependency.getVisibility() == View.VISIBLE) {
child.setTranslationY(0f);
} else {
// Execute the animation only if the snackbar has been swiped away, i.e. when it's not visible
ValueAnimator animator = new ValueAnimator();
animator.setFloatValues(child.getTranslationY(), 0f);
animator.setInterpolator(FAST_OUT_SLOW_IN_INTERPOLATOR);
animator.setDuration(ANIMATION_DURATION);
animator.addUpdateListener(animation -> child.setTranslationY((float) animation.getAnimatedValue()));
animator.start();
}
}
private int getTranslationYBottom(View view) {
// Get the translation position of the snackbar when it's hidden.
// Method taken from BaseTransientBottomBar.Behavior class.
int translationY = view.getHeight();
ViewGroup.LayoutParams layoutParams = view.getLayoutParams();
if (layoutParams instanceof ViewGroup.MarginLayoutParams) {
translationY += ((ViewGroup.MarginLayoutParams) layoutParams).bottomMargin;
}
return translationY;
}
}
Run Code Online (Sandbox Code Playgroud)
然后在你的布局中:
<android.support.design.widget.FloatingActionButton
...
app:layout_behavior="your.package.SnackbarAwareBehavior">
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
498 次 |
| 最近记录: |