Android自定义view之实现带checkbox的Snackbar

本文介绍了如何在Android中实现一个带有Checkbox的Snackbar,详细讲解了从获取Activity根布局到设置Snackbar显示、消失、定位及监听事件的整个过程,提供完整的代码示例。
摘要由CSDN通过智能技术生成

前言

最近项目要求实现一个类似于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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值