流式布局FlowLayout使用

博客探讨了如何使用谷歌Design Support Library中的FlowLayout实现流式布局,并提及该库中其他有用控件,推荐查看相关帖子以了解更多。

原先用的是三方的流式布局,后来发现google自己也有,效果是一样的。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.google.android.material.internal.FlowLayout
        android:id="@+id/llOrderTags"
        app:lineSpacing="6dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

    </com.google.android.material.internal.FlowLayout>
</LinearLayout>
private fun getTextView(rightMargin:Float = 10f):TextView{
        var textView = TextView(context)
        textView.apply {
            setTextSize(TypedValue.COMPLEX_UNIT_SP,11f)
            setPadding(Utils.dp2px(context,3f))
            setTextColor(ContextCompat.getColor(context,R.color.white))
            var params = ViewGroup.MarginLayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
            params.rightMargin = Utils.dp2px(context,rightMargin)
            layoutParams = params
        }
        return textView;
    }


holder.getView<FlowLayout>(R.id.llOrderTags).removeAllViews()
        var orderTags:List<String>? = row.orderTags?.filter { it != "分期" && it != "全款"}
        if (orderTags.isNullOrEmpty().not()) {
            var textView:TextView
            orderTags?.forEach {
                textView = getTextView()
                textView.background = ContextCompat.getDrawable(context,R.drawable.shape_textview_whitecolor_border)
                textView.setTextColor(ContextCompat.getColor(context,R.color.font_color_blank))
                textView.text = it
                holder.getView<FlowLayout>(R.id.llOrderTags).addView(textView)
            }
        }

其实Design Support Librar里面还有好多好的控件,可以看一下下面帖子,说的也不错,挺全:

Android Material Design简单使用 - 简书

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值