将动态视图添加到特定的RecyclerView.Adapter

时间:2019-06-28 09:43:16

标签: android android-recyclerview android-databinding

我目前正在测试我的代码,以了解RecyclerView.Adapter需要在其中显示其他信息的情况。使用下面onBindViewHolder中的代码,我能够完成这项工作。

TableRow row = new TableRow(mCtx);
row.setLayoutParams(new TableLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
row.setOrientation(LinearLayout.VERTICAL);

TextView lbl = new TextView(mCtx);
lbl.setText("Desc1");

TextView lbl2 = new TextView(mCtx);
lbl2.setText("54.77");

row.addView(lbl);
row.addView(lbl2);

holder.binding.tblTicketItemDetails.addView(row);

总是在OnBindViewHolder内部调用该代码,以模拟每个项目中都包含其他信息。如果我通过按Button继续创建项目,则每个项目的附加信息都会增加。

使用DataBinding时如何定位特定适配器的布局?

这是我用于RecyclerView.Adapter的布局。

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

    <data>
        <variable
            name="ticket_item"
            type="com.example.com.TicketItem" />
    </data>

    <android.support.constraint.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <TableRow
            android:id="@+id/tableRow6"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginTop="8dp"
            android:weightSum="2"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent">

            <TextView
                android:id="@+id/lblTicketItemName"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:padding="8dp"
                android:text="@{ticket_item.description}"
                android:textColor="@color/black"
                android:textSize="18sp"
                android:textStyle="bold"
                tools:text="Test Text" />

            <TextView
                android:id="@+id/lblTicketItemPrice"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:gravity="end"
                android:padding="8dp"
                android:text="@{ticket_item.price}"
                android:textColor="@color/black"
                android:textSize="18sp"
                android:textStyle="bold"
                tools:text="Test Text" />
        </TableRow>

        <TableLayout
            android:id="@+id/tblTicketItemDetails"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginBottom="8dp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/tableRow6">

        </TableLayout>

    </android.support.constraint.ConstraintLayout>
</layout>

如果需要,我想在TableRow中添加2个TextView中的tblTicketItemDetails。做这个的最好方式是什么?如果使用DataBinding时无法执行此操作,那么我将切换到旧方法。

1 个答案:

答案 0 :(得分:1)

我通常使用Databinding添加这样的动态视图:

@BindingAdapter({"addDynamicView", "position"})
public static void addDynamicView(TableLayout layout, TicketItem item, int position) {
   // LayoutInflater inflater = LayoutInflater.from(layout.getContext()); // if you need layout inflater
    for (int i = 0; i <= position; i++) { // loop to whatever condition you have
        TextView lbl = new TextView(layout.getContext());
        lbl.setText("Desc1");
        layout.addView(lbl);
    }
}

在xml中修改TableLayout,

 <TableLayout
            android:id="@+id/tblTicketItemDetails"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginBottom="8dp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/tableRow6"
            app:addDynamicView = "@{ticket_item}"
            app:position = "@{position}">

在xml中声明一个新变量,

<variable
            name="position"
            type="int" />

将位置从Java发送到xml

holder.binding.setVariable(BR.position, position);

holder.binding.setPosition(position);