我是靠谱客的博主 美满眼神,最近开发中收集的这篇文章主要介绍android控制行数标签布局,Android流式布局,支持设置行数、单选、多选等,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

FlowLayout

Android流式布局,支持单选、多选、设置显示行数等,适合用于产品标签等。

新增

支持设置显示的行数

获取布局总行数

特色

以setAdapter形式注入数据

直接设置selector为background即可完成标签选则的切换,类似CheckBox

支持控制选择的Tag数量,比如:单选、多选

支持setOnTagClickListener,当点击某个Tag回调

支持setOnSelectListener,当选择某个Tag后回调

支持adapter.notifyDataChanged

Activity重建(或者旋转)后,选择的状态自动保存

效果图

09fefc99a9e22a7a316396284597fd63.gif

bad63a9ae85889b4faf719e5f375a341.png

用法

repositories {

maven { url "https://jitpack.io" }

}

...

dependencies {

compile 'com.github.djzhao627:FlowLayout:1.0.1'

}

声明

布局文件中声明:

android:id="@+id/id_flowlayout"

zhy:max_select="-1"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:padding="20dp">

支持属性:

max_select:-1为不限制选择数量,>=1的数字为控制选择tag的数量

支持通过state=checked来控制选中和取消,也可以自己在Adapter 的onSelected和unSelected中分别处理显示。

设置数据

mFlowLayout.setAdapter(new TagAdapter(mVals)

{

@Override

public View getView(FlowLayout parent, int position, String s)

{

TextView tv = (TextView) mInflater.inflate(R.layout.tv, mFlowLayout, false);

tv.setText(s);

return tv;

}

});

getView中回调,类似ListView等用法。

对于选中状态

android:drawable="@drawable/checked_bg"

android:state_checked="true">

设置个background,上面一个状态为android:state_checked,另一个为正常。写写布局文件我都嫌慢,怎么能写一堆代码控制效果,设置改个效果,岂不是没时间dota了。

也可以不依赖state_checked,在下面的回调中自行设置:

#Adapter

@Override

public void onSelected(int position, View view) {

super.onSelected(position, view);

}

@Override

public void unSelected(int position, View view) {

super.unSelected(position, view);

}

事件

mFlowLayout.setOnTagClickListener(new TagFlowLayout.OnTagClickListener()

{

@Override

public boolean onTagClick(View view, int position, FlowLayout parent)

{

Toast.makeText(getActivity(), mVals[position], Toast.LENGTH_SHORT).show();

return true;

}

});

点击标签时的回调。

mFlowLayout.setOnSelectListener(new TagFlowLayout.OnSelectListener()

{

@Override

public void onSelected(Set selectPosSet)

{

getActivity().setTitle("choose:" + selectPosSet.toString());

}

});

选择多个标签时的回调。

预先设置Item选中

//预先设置选中

mAdapter.setSelectedList(1,3,5,7,8,9);

//获得所有选中的pos集合

flowLayout.getSelectedList();

最后

以上就是美满眼神为你收集整理的android控制行数标签布局,Android流式布局,支持设置行数、单选、多选等的全部内容,希望文章能够帮你解决android控制行数标签布局,Android流式布局,支持设置行数、单选、多选等所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部