在项目中一般都会用到流式布局
布局文件
<com.zhy.view.flowlayout.TagFlowLayout android:id="@+id/id_flowlayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#3A4559" android:paddingLeft="15dp" android:paddingRight="15dp" zhy:max_select="-1"></com.zhy.view.flowlayout.TagFlowLayout>
代码设置适配器
private TagAdapter<GetScreeningUnitsByOrganizationUnitCodeResponse> tagScreenAdapter; id查找,因为我是用在dialog中的,所以在dialog中查找 TagFlowLayout id_flow_layout_screen = bottomScreenDialog.findViewById(R.id.id_flowlayout_screen);
item_organization_tag为标签列表的item布局 布局文件如下:
<?xml version="1.0" encoding="utf-8"?> <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:paddingLeft="3dp" android:layout_marginRight="8dp" android:layout_marginTop="8dp" android:layout_marginBottom="8dp" android:paddingRight="3dp" android:background="@drawable/bg_ffffff_4radius_1_stroke" android:layout_width="wrap_content" android:minWidth="40dp" android:layout_height="40dp" android:gravity="center" android:id="@+id/organization_tag_tv" android:textColor="@color/white" ></TextView>
创建适配器时需要创建集合数据tagScreenResultBeanList集合数据,集合中存放的对象GetScreeningUnitsByOrganizationUnitCodeResponse
tagScreenAdapter = new TagAdapter<GetScreeningUnitsByOrganizationUnitCodeResponse>(tagScreenResultBeanList) { @Override public View getView(FlowLayout parent, int position, GetScreeningUnitsByOrganizationUnitCodeResponse o) { //can use viewHolder TextView tv = (TextView) LayoutInflater.from(SearchPatientActivity.this).inflate(R.layout.item_organization_tag, parent, false); if ((o != null)) { tv.setText(o.getDisplayName()); } return tv; } }; id_flow_layout_screen.setAdapter(tagScreenAdapter);//设置适配器 //当数据改变时,适配器要执行刷新操作 tagScreenAdapter.notifyDataChanged();
//下面是设置标签点击事件 点击事件处理 screenTagClick(position);自己写的点击事件处理 id_flow_layout_screen.setOnTagClickListener(new TagFlowLayout.OnTagClickListener() { @Override public boolean onTagClick(View view, int position, FlowLayout parent) { screenTagClick(position); return true; } });