欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

BottomSheetDialog(design包的一个组件)

程序员文章站 2022-05-31 15:57:55
...
这是design包的一个组件,底部弹出框效果如下。当里面的布局内容过多时(比如一个有多个项的列表),只会显示一部分,然后上滑显示全部。
BottomSheetDialog(design包的一个组件)BottomSheetDialog(design包的一个组件)

首先导入design包。compile 'com.android.support:support-vector-drawable:25.3.1'

写一个布局,也就是BottomSheetDialog要显示的的view。dialog.xml.
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ListView
        android:id="@+id/list"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</LinearLayout>
然后在要显示BottomSheetDialog的活动中实例化一个BottomSheetDialog,并且setContentView加载这个布局
 public void showdialog(){
        final BottomSheetDialog dialog=new BottomSheetDialog(context);
        View dialogview = LayoutInflater.from(context).inflate(R.layout.dialog,null);
        ListView listView= (ListView) dialogview.findViewById(R.id.list);

        LinkedList<String> s=new LinkedList<String>();
        for(int i=0;i<13;i++){
            s.add("item"+i);
        }
        final MyAdapter myAdapter=new MyAdapter(s,context);
        listView.setAdapter(myAdapter);
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Toast.makeText(context,myAdapter.getItem(position).toString(),Toast.LENGTH_SHORT).show();
            }
        });

        dialog.setContentView(dialogview);
        dialog.show();
    }
然后在让他在要显示的地方调用这个showdialog就可以了。