2018-06-03

MaterialDesign之自定义Snackbar

老规矩,先上图

2018-06-03_第1张图片
截屏_20180603_130433.jpg

大家都知道这是由floatingactionbutton+snackbar组合实现的,其实网上都会说snackbar和toast一样是一个轻量级的用户交互控件,所以自定义布局没啥意义,那么到底可不可以实现呢?答案是肯定的,而且很easy。

floatbtn = view.findViewById(R.id.item_introduct_fab);
        floatbtn.setOnClickListener(new View.OnClickListener() {
            @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
            @Override
            public void onClick(View v) {
                initMySnackbar(v);

            }
        });
 private void initMySnackbar(View v) {
        //初始化一个snackbar
        Snackbar snackbar = Snackbar.make(v,"",Snackbar.LENGTH_LONG);
        //修改snackbar的背景颜色
        snackbar.getView().setBackgroundColor(getResources().getColor(R.color.gray_100));
        //获取snackbar的源布局
        Snackbar.SnackbarLayout layout = (Snackbar.SnackbarLayout) snackbar.getView();
        //隐藏源布局的控件
        TextView textView = (TextView) layout.findViewById(android.support.design.R.id.snackbar_text);
        textView.setVisibility(View.INVISIBLE);
        //获取自定义view
        View snackView = LayoutInflater.from(getContext()).inflate(R.layout.my_snackbar, null);
        ImageView qqshare = snackView.findViewById(R.id.my_snackbar_qqshare);
        qqshare.setOnClickListener(this);
        ImageView zoneshare = snackView.findViewById(R.id.my_snackbar_zoneshare);
        zoneshare.setOnClickListener(this);
        ImageView wechatshare = snackView.findViewById(R.id.my_snackbar_wechatshare);
        wechatshare.setOnClickListener(this);
        ImageView sinashare = snackView.findViewById(R.id.my_snackbar_sinashare);
        sinashare.setOnClickListener(this);
        //添加自定义布局到SnackbarLayout
        layout.addView(snackView, 0);
        //显示snackbar
        snackbar.show();
    }

Snackbar.SnackbarLayout,它是一个水平LinearLayout对象,其子对象是一个TextView和一个Button。我们只需隐藏的TextView,并将您的视图添加到Snackbar.SnackbarLayout。

以上就是如何自定义snackbar的所有代码了,如有帮助请点个赞吧!!!

如有问题,欢迎留言讨论!!!

你可能感兴趣的:(2018-06-03)