Android中FlowTagLayout流式布局的使用

何为FlowTagLayout

如果对Java的Swing比较熟悉的话一定不会陌生,就是控件根据ViewGroup的宽,自动的往右添加,如果当前行剩余空间不足,则自动添加到下一行。有点所有的控件都往左飘的感觉,第一行满了,往第二行~所以也叫流式布局。Android并没有提供流式布局,但是某些场合中,流式布局还是非常适合使用的,比如关键字标签,搜索热词列表等

FlowTagLayout

Android流式布局,支持点击、单选、多选等,适合用于产品标签等,用法采用Adapter模式,和ListView、GridView用法一样

特色:


1)填充数据和ListView、GridView用法一样使用Adapter,更新数据直接通过adapter.notifyDataChanged来更新

2)支持点击、单选、多选事件

3)三种模式:FLOW_TAG_CHECKED_NONE、FLOW_TAG_CHECKED_SINGLE、FLOW_TAG_CHECKED_MULTI

4)支持OnTagClickListener单点事件

5)支持OnTagSelectListener单选、多选事件

效果图如图所示:


主要代码如下:

点击事件

// 点击
		mColorTagAdapter = new TagAdapter<>(this);
		mColorFlowTagLayout.setAdapter(mColorTagAdapter);
		mColorFlowTagLayout.setOnTagClickListener(new OnTagClickListener() {
			@Override
			public void onItemClick(FlowTagLayout parent, View view,
					int position) {
				Toast.makeText(MainActivity.this, "单击了一下" + position,
						Toast.LENGTH_SHORT).show();
			}
		});
单选事件

// 单选
		mSizeTagAdapter = new TagAdapter<>(this);		
		mSizeTagAdapter.setSelected(-1);//设置-1是让其初始化适配数据的时候没有默认
		mSizeFlowTagLayout
				.setTagCheckedMode(FlowTagLayout.FLOW_TAG_CHECKED_SINGLE);
		mSizeFlowTagLayout.setAdapter(mSizeTagAdapter);
		mSizeFlowTagLayout.setOnTagSelectListener(new OnTagSelectListener() {

			@Override
			public void onItemSelect(FlowTagLayout parent, int position,
					List<Integer> selectedList) {
				if (selectedList != null && selectedList.size() > 0) {
					StringBuilder sb = new StringBuilder();
					for (int i : selectedList) {
						sb.append(parent.getAdapter().getItem(i));
						sb.append(":");
					}

					Toast.makeText(MainActivity.this, position + sb.toString(),
							Toast.LENGTH_SHORT).show();

				} else {

					Toast.makeText(MainActivity.this, "没有选择标签",
							Toast.LENGTH_SHORT).show();

				}
			}
		});
多选事件:

// 多选
		mMobileTagAdapter = new TagAdapter<>(this);
		mMobileTagAdapter.setSelected(-1);
		mMobileFlowTagLayout
				.setTagCheckedMode(FlowTagLayout.FLOW_TAG_CHECKED_MULTI);

		mMobileFlowTagLayout.setAdapter(mMobileTagAdapter);
		mMobileFlowTagLayout.setOnTagSelectListener(new OnTagSelectListener() {
			@Override
			public void onItemSelect(FlowTagLayout parent, int positon,
					List<Integer> selectedList) {
				if (selectedList != null && selectedList.size() > 0) {
					StringBuilder sb = new StringBuilder();

					for (int i : selectedList) {
						sb.append(parent.getAdapter().getItem(i));
						sb.append(":");
					}
					Toast.makeText(MainActivity.this, sb.toString(),
							Toast.LENGTH_SHORT).show();

				} else {
					Toast.makeText(MainActivity.this, "没有选择标签",
							Toast.LENGTH_SHORT).show();

				}
			}
		});

适配器的布局tag_item.xml如下所示

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
             >
    <TextView
        android:id="@+id/tv_tag"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginTop="10dp"
        android:textColor="@drawable/ss"
        android:background="@drawable/round_rectangle_bg"
        android:paddingBottom="5dp"
        android:paddingLeft="10dp"
        android:paddingRight="10dp"
        android:paddingTop="5dp"
        />

</LinearLayout>
资源文件ss.xml如图所示:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_selected="true" android:color="#ff0000" />
    <item android:state_focused="true" android:color="#ff0000" />
    <item android:state_pressed="true" android:color="#ff0000" />
    <item android:color="#89683B" />

</selector>

资源文件round_rextangle_bg.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
     <item android:state_pressed="true"  >
        <shape android:shape="rectangle">
            
            <corners android:radius="10dp" />
            <stroke android:width="1dp" android:color="#ff0000"  />
        </shape>
    </item>
    <item android:state_selected="true"  >
        <shape android:shape="rectangle">
           
            <corners android:radius="10dp" />
            <stroke android:width="1dp" android:color="#ff0000"  />
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle">
            <solid android:color="#fff" />
            <corners android:radius="10dp" />
            <stroke android:width="1dp" android:color="#89683B"  />
        </shape>
    </item>

</selector>
FlowTagLayout在GitHub上有具体的Demo,地址为 http://www.open-open.com/lib/view/home/1445518079367

此篇文章的FlowTagLayout的Demo地址为(此demo是用Eclipse编写,studio不能直接运行):http://download.csdn.net/detail/shihuiyun/9598749
有需要是可以下载下来看看



  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Android布局是一种常用的布局,它可以根据内容的大小和数量自动调整控件的位置和大小,使得界面能够自适应屏幕的宽度。通常在需要展示多个标签、图片或文字等的场景下使用布局的特点是将内容按照先后顺序从左到右排列,当一行的宽度不足以容纳下一个控件时,会自动换行。这种布局能够节省空间,提高界面的可读性和美观性。 在Android,可以使用FlowLayout这个第三方库来实现布局使用FlowLayout的步骤如下:首先在项目的build.gradle文件添加依赖,然后在布局文件将根布局设置为FlowLayout,并在其添加需要展示的控件,可以通过调整控件的属性来定义布局的样和排列方布局可以动态调整控件的位置和大小,可以通过设置权重来控制每个控件在水平方向上的占比,也可以设置边距来调整控件之间的间隔。另外,布局还可以为每个控件设置点击事件和长按事件,方便实现更丰富的交互效果。 总之,布局是一种灵活且强大的布局,可以有效地解决多个控件在界面上排列不下或排列不美观的问题,同时也能够提高界面的可读性和用户体验。在开发Android应用时,如果遇到需要展示多个标签、图片或文字等的场景,布局是一个很好的选择。 ### 回答2: Android布局是一种灵活的布局,用于在屏幕上动态自适应地显示一系列视图。它能够根据子视图的大小和屏幕大小自动调整子视图的位置和宽度。这种布局适用于显示不规则大小的子视图,尤其适用于显示标签、图片、标签云等。 Android布局可以通过使用LinearLayout或GridLayout来实现。在LinearLayout,可以设置orientation属性为horizontal或vertical来实现水平或垂直布局。在GridLayout,可以通过设置列数来控制每行显示的子视图数量。 Android布局的优点是可以根据屏幕的大小和方向自动调整子视图的布局,使得页面在不同设备上都能够良好地显示。同时,它也提供了更好的用户体验,因为用户可以在不同屏幕上以不同的方查看和交互。 然而,Android布局也存在一些限制。由于其自适应特性,子视图的大小和位置可能会受到限制。此外,较复杂的布局可能会导致性能问题,因为在布局过程需要进行多次测量和计算。因此,在使用布局时,需要谨慎处理子视图的大小和数量,以提高性能并避免布局过于复杂。 总结来说,Android布局是一种灵活而自适应的布局,适用于显示不规则大小的子视图。它可以根据屏幕的大小和方向自动调整子视图的布局,并提供更好的用户体验。然而,需要注意处理子视图的大小和数量,以提高性能并避免布局过于复杂。 ### 回答3: Android布局(Flow Layout)是一种动态适应屏幕宽度的布局,主要用于解决在屏幕上按行排列多个子视图的问题。 在传统的线性布局,如果视图超出屏幕宽度,就会自动换行,但是每一行只会放置一个子视图。而在布局,子视图会根据屏幕宽度自动换行,并且每一行可以放置多个子视图,适应屏幕不同宽度的设备。 布局使用非常方便,只需要将子视图添加到布局即可。它提供了一些属性来控制子视图在布局的排列方,比如子视图之间的间距、子视图的对齐方等。此外,布局还可以通过设置权重属性,实现子视图的均匀分布或者按比例分布。 布局在一些场景下非常有用,比如在标签云、瀑布展示等需要动态调整子视图排列的情况下。相比于其他布局布局可以更好地利用屏幕空间,提高用户体验。 总之,Android布局是一种动态适应屏幕宽度的布局,可以方便地排列多个子视图,并提供了一些属性来控制子视图的排列方和样。它的使用简单灵活,适用于多种场景,可以有效地提高用户界面的可用性和美观性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值