android - 有没有办法以编程方式使用约束布局助手小部件流?
问题描述
我想使用约束布局 androidx.constraintlayout.helper.widget.Flow 小部件,但是当我搜索时,我找不到任何关于以编程方式使用流小部件的示例。如何以编程方式设置 constraint_referenced_ids?
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<androidx.constraintlayout.helper.widget.Flow
android:layout_width="0dp"
android:layout_height="wrap_content"
app:constraint_referenced_ids="text1,text2"
app:flow_horizontalBias="0"
app:flow_horizontalGap="10dp"
app:flow_horizontalStyle="packed"
app:flow_verticalBias="0"
app:flow_wrapMode="chain"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
/>
解决方案
这对我有用:
我的自定义PerkFlow
类:
class PerkFlow(context: Context, attrs: AttributeSet?) : Flow(context, attrs) {
fun setup(
parentView: ViewGroup,
perks: List<String>
) {
val referencedIds = IntArray(perks.size)
for (i in perks.indices) {
val textView = createTextView(context)
textView.text = perks[i]
textView.id = View.generateViewId()
parentView.addView(textView)
referencedIds[i] = textView.id
}
this.referencedIds = referencedIds
}
private fun createTextView(context: Context): TextView {
val textView = TextView(context)
textView.setTextSize(TypedValue.COMPLEX_UNIT_SP, 12F)
textView.setTextColor(context.resources.getColor(R.color.gmm_white))
return textView
}
}
我的xml
:
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
..... (a lot of other code)
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/vendor_details_perks_container"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="24dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/vendor_details_favourite">
<com.perkapp.mobile.views.PerkFlow
android:id="@+id/vendor_details_perks"
android:layout_width="0dp"
android:layout_height="wrap_content"
app:flow_horizontalBias="0"
app:flow_horizontalGap="5dp"
app:flow_horizontalStyle="packed"
app:flow_verticalBias="0"
app:flow_verticalGap="2dp"
app:flow_wrapMode="chain"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
..... (a lot of other code)
</androidx.constraintlayout.widget.ConstraintLayout>
Fragment 中 PerkFlow 的设置:
binding.vendorDetailsPerks.setup(
binding.vendorDetailsPerksContainer,
listOf("apple, banana, blackberries, blueberries, cherries, grapes, lemon, orange, peaches, pear, pineapple, plums, raspberries, strawberries, watermelon ")
)
希望这可以帮助!
还有一件事:如果你再次调用它(在 RecyclerView 项目中,或者新数据到达),不要忘记清除父视图,否则元素将被复制。如果需要,我也可以发送该代码。
推荐阅读
- javascript - React native 返回 Promise 而不是值 Firestore
- ionic3 - 将 Firebase Analytics 与 Ionic 3 集成
- flutter - 更改所选文本的突出显示颜色
- python - 在 Python 中打印队列的内容
- c++ - std::map Why it is not adding key , values in my code
- javascript - JS过滤数组数组
- r - gganimate barchart:替换bar时平滑过渡
- gmail - PHPMailer - 同一页面中的多个电子邮件
- excel - Excel: How do I reference a date when using SUM IF for multiple columns and date rows
- python - /index/ 处的 TypeError -- 'bool' 对象不可调用