Android流式布局FlowLayout詳解
現在商城類的APP幾乎都要用到流式布局來實現選擇屬性功能,在我的demo中是通過FlowLayout工具類實現流式布局
使用起來非常簡單,十幾行代碼就可以實現;

在我們的項目中大部分都是單選效果,為了防止用到多選,demo中也實現了多選;
FlowLayout大家不用研究怎么實現的,只要會使用就好;
就好比谷歌提供的ListView條目點擊事件一樣,只要會用就好,沒必要研究個所以然;大家在用的時候直接從demo中復制到項目中即可;
大家可以將FlowLayout理解為一個線性布局;將準備好的一個個子view添加到FlowLayout中即可;
首先看下布局文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" xmlns:app="http://schemas.android.com/apk/res-auto"> <!-- app:horizontal_spacing="8dp" 每列之間的距離 app:vertical_spacing="8dp" 每行之間的距離 --> <www.fl.com.flowlayouttext.view.FlowLayout android:id="@+id/flowlayout" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:paddingBottom="14dp" android:paddingLeft="21dp" android:paddingRight="14dp" app:horizontal_spacing="8dp" app:vertical_spacing="8dp"/> </LinearLayout>
布局文件非常簡單,沒什么好說的,下面看下代碼實現:
大致分為三步:
//第一步:初始化FlowLayout
flowLayout= (FlowLayout) findViewById(R.id.flowlayout);
//第二步:移除FlowLayout中的所有子布局
flowLayout.removeAllViews();
//第三步:循環(huán)創(chuàng)建子View,添加到FlowLayout中
for (int x=0;x<names.length;x++){
//3.1初始化子view
CheckBox checkBox= (CheckBox) View.inflate(context,R.layout.item_flowlayout,null);
checkBox.setText(names[x]);
final int finalX = x;
//3.2設置子view的點擊事件
checkBox.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
ToastUtil.show(context, names[finalX]);
//遍歷FlowLayout中的所有view,如果是當前選中的view,設置為選中狀態(tài),其他設置為未選中狀態(tài)
refreshCheckBox(names[finalX]);
}
});
//3.3將子view添加到FlowLayout中
flowLayout.addView(checkBox);
}
從代碼中可以看到,子view使用的是CheckBox,背景和文字顏色都是使用的狀態(tài)選擇器,大家可以根據自己項目中的需求隨意更改:
item_flowlayout.xml
<?xml version="1.0" encoding="utf-8"?> <CheckBox xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:button="@null" android:textSize="15sp" android:paddingLeft="5dp" android:paddingRight="5dp" android:background="@drawable/item_bg_select" android:textColor="@drawable/text_color" android:paddingTop="3dp" android:paddingBottom="3dp"> </CheckBox>
單選到此結束,大家可能感覺多選比單選要難,其實多選比單選還要簡單,以上代碼只需去除子view點擊事件refreshCheckBox()方法即可實現多選;
點擊打開鏈接免費下載源碼
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
使用Android Studio實現為系統(tǒng)級的app簽名
這篇文章主要介紹了使用Android Studio實現為系統(tǒng)級的app簽名,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
關于Android中點擊通知欄的通知啟動Activity問題解決
這篇文章主要介紹了關于解決Android中點擊通知欄的通知啟動Activity問題的相關資料,文中介紹的非常詳細,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03
【Android 基礎】詳解Animation 動畫介紹和實現
這篇文章主要介紹了【Android 基礎】詳解Animation 動畫介紹和實現 ,對于想要學習android開發(fā)的同學具有一定的參考價值,有需要的可以了解一下。2016-12-12

