android fab 点击弹窗,【Android】实现Snackbar弹出时任意View闪躲

简介

Snackbar 是一个底部弹出消息的控件,类似Toast。

基本使用:

Snackbar.make(view, message_text, duration)

.setAction(action_text, click_listener)

.show();

我们知道,在根布局是CoordinatorLayout,并且设置CoordinatorLayout的behavior之后,可以实现Snackbar弹出的时候,fab(浮动按钮)会自动向上移动防止被遮挡。

代码如下:

布局文件

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

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/coordinator_layout"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:background="@color/background_color"

app:layout_behavior="@string/appbar_scrolling_view_behavior"

tools:context=".fragment.TodoFragment">

android:layout_width="match_parent"

android:layout_height="match_parent">

...

android:id="@+id/fab"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="end|bottom"

android:layout_marginEnd="16dp"

android:layout_marginBottom="16dp"

android:adjustViewBounds="false"

android:clickable="true"

app:backgroundTint="@color/blue"

app:fabSize="normal"

app:srcCompat="@drawable/ic_add_d" />

注:我这里用了AndroidX的支持库,如果你没迁移到AndroidX,需要改下控件的引用路径。

然后在activity中调用显示Snackbar:

Snackbar.make(coordinator_layout, "Snackbar弹出信息", Snackbar.LENGTH_SHORT)

.show();

效果(其实这里已经实现了ConstraintLayout的闪躲):

7987293e8397

闪躲效果

实现任意View闪躲

那么如何实现任意View的闪躲呢?

查了一番StackOverflow,发现最佳的实践应该就是实现一个通用的behavior。

废话不多说,直接上代码(Java):

@Keep

public class MoveUpwardBehavior extends CoordinatorLayout.Behavior {

public MoveUpwardBehavior() {

super();

}

public MoveUpwardBehavior(Context context, AttributeSet attrs) {

super(context, attrs);

}

@Override

public boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {

return dependency instanceof Snackbar.SnackbarLayout;

}

@Override

public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {

float translationY = Math.min(0, ViewCompat.getTranslationY(dependency) - dependency.getHeight());

child.setTranslationY(translationY);

return true;

}

// 重写这个方法才能实现滑动清除消息

@Override

public void onDependentViewRemoved(CoordinatorLayout parent, View child, View dependency) {

ViewCompat.animate(child).translationY(0).start();

}

}

然后在布局文件中,在你想要实现闪躲的View上增加这个layout_behavior:

android:layout_width="match_parent"

android:layout_height="match_parent"

app:layout_behavior="net.sarasarasa.lifeup.base.MoveUpwardBehavior">

...

可以在AS里快速获取含完整报名的引用:右键你的类文件,选择Copy Reference。

没错,这样就完成了~测试去吧。

参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值