前言
最近项目要求实现一个类似于snackbar功能,但是又不完全是snackbar的插件,本来想在Google提供的snackbar里面进行更改,但是这样太麻烦了,于是自己动手实现了一个snackbar。先看下效果图:
1.要解决的问题
1.弹框里面除了文字提示之外还有一个按钮,这个按钮是一个checkbox,分为选择状态和非选择状态。 2.弹框底部还有一个布局,弹框要在底部布局之上。 3.弹框消失的时间。 4.当有虚拟键的时候,弹框应该在虚拟键之上。
2、分析与实现
当在任何一个activity中时,自定义的Snackbar应该在activity 布局的上面显示,如下图所示:
绿色部分是自定义的snackbar的布局,红色部分是activity布局,部分已经被snackbar遮挡。要实现上面的效果,就要获取到当前activity的布局,流程很简单:
1、获取activity的根布局:
Window window=(Activity) context).getWindow();//获取当前activity的window
ViewGroup decorView= (ViewGroup) window.getDecorView();//获取activity的跟布局
activity的view的原理可以看下面的图:
activity的顶级布局是DecorView,其中DecorView类由PhoneWindow所持有,Phonewindow由Activity持有,所以上面获取DecorView时要通过Activity获取window,再由window获取得到。其中DecorView中包括一个TitleVIew和ContentView,ContenView中的布局是通过在Activity中的setContentView()来设置的。 因为自定义的snackbar要放在整个activity的根布局之上,因此就是将snackbar的view加到DecorView上,而不是ContentView上面。
2、获取snackbar的view
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
//parent是上面的获取的activity的跟布局
View snackbarView= inflater.inflate(R.layout.layout_mobile_notify_snackbar, parent, false);
//R.layout.layout_mobile_notify_snackbar snackbar的布局
layout_mobile_notify_snackbar.xml布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="78dp"
android:layout_gravity="bottom"
android:gravity="center_vertical"
android:orientation="vertical">
<ImageView
android:layout_width="match_parent"
android:layout_height="30dp"
android:background="@drawable/diffussion_background"
/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="48dp"
android:layout_gravity="bottom"
android:background="@color/white"
android:gravity="center_vertical"
android:orientation="hori