欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android流式布局FlowLayout詳解

 更新時(shí)間:2020年09月23日 07:50:28   作者:ZhengJiaoCsdn  
這篇文章主要為大家詳細(xì)介紹了Android流式布局FlowLayout的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

在我們的項(xiàng)目中大部分都是單選效果,為了防止用到多選,demo中也實(shí)現(xiàn)了多選;

FlowLayout大家不用研究怎么實(shí)現(xiàn)的,只要會(huì)使用就好;

就好比谷歌提供的ListView條目點(diǎn)擊事件一樣,只要會(huì)用就好,沒必要研究個(gè)所以然;大家在用的時(shí)候直接從demo中復(fù)制到項(xiàng)目中即可;

大家可以將FlowLayout理解為一個(gè)線性布局;將準(zhǔn)備好的一個(gè)個(gè)子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> 

布局文件非常簡(jiǎn)單,沒什么好說的,下面看下代碼實(shí)現(xiàn):
大致分為三步:

//第一步:初始化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設(shè)置子view的點(diǎn)擊事件 
   checkBox.setOnClickListener(new View.OnClickListener() { 
    @Override 
    public void onClick(View v) { 
     ToastUtil.show(context, names[finalX]); 
     //遍歷FlowLayout中的所有view,如果是當(dāng)前選中的view,設(shè)置為選中狀態(tài),其他設(shè)置為未選中狀態(tài) 
     refreshCheckBox(names[finalX]); 
    } 
   }); 
   //3.3將子view添加到FlowLayout中 
   flowLayout.addView(checkBox); 
  } 

從代碼中可以看到,子view使用的是CheckBox,背景和文字顏色都是使用的狀態(tài)選擇器,大家可以根據(jù)自己項(xiàng)目中的需求隨意更改:

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> 

單選到此結(jié)束,大家可能感覺多選比單選要難,其實(shí)多選比單選還要簡(jiǎn)單,以上代碼只需去除子view點(diǎn)擊事件refreshCheckBox()方法即可實(shí)現(xiàn)多選;

點(diǎn)擊打開鏈接免費(fèi)下載源碼

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論