如何在Android中将ArrayList的所有元素显示为Chips

时间:2019-10-03 03:01:44

标签: java android arraylist android-chips

我有一个ArrayList<String>这样的[Angularjs, JavaScript, Css]

在我的适配器中,我从另一个Intent获得了标签ArrayList。我尝试通过以下方法将ArrayList的所有元素显示为 Chip ,但仅得到ArrayList的最后一个元素。我只看到 one 芯片和ArrayList的最后一个元素。

for (String tag: card.getTags()) {
  Log.d(TAG, "tag - " + tag);
  holder.tags.setText(tag);
}

任何人都可以指导,如何更改代码以将ArrayList的所有元素显示为Chips

2 个答案:

答案 0 :(得分:1)

当前,您正在替换tags持有人循环中的forEach。您只有一个持有人,并且不断更新直到循环结束;这就是你最后chip/tag

的原因

如果您指的是MaterialComponents的ChipGroup

ChipGroup chipGroup = new ChipGroup(parentView.getContext());

String[] genres = {"Thriller", "Comedy", "Adventure"};
for(String genre : genres) {
   Chip chip = new Chip(parentView.getContext());
   chip.setText(genre);
   chipGroup.addView(chip);
}

我认为您必须使用RecyclerView,因为我在代码段中看到了持有人。

以下是视图层次结构;我假设您正在努力实现;如果没有,那么您可以使用同一行逻辑在这些部分之间移动

  • RecyclerView
    • 每个项目/视图
      • 标签-使用FlowLayout的多个标签-在视图中添加多个标签

您需要bind在RecyclerView中的每个项目。

@Override
public void onBindViewHolder(final YourViewHolder holder, final int position) {
    ...
    // assuming you have FlowLayout in recyclerview view item
    // do add holder pattern to flowlayout as well
    fillAutoSpacingLayout(card.getTags(), holder.flowLayout);
}

在这里,我使用FlowLayout在每个RecyclerView视图内添加芯片或标签。

在onBindViewHolder中绑定每个项目/视图:

private void fillAutoSpacingLayout(ArrayList<String> tags, FlowLayout flowLayout) {

    for (String tag : tags) {
        TextView textView = buildLabel(tag);
        flowLayout.addView(textView);
    }
}

private TextView buildLabel(String text) {
    TextView textView = new TextView(this);
    textView.setText(text);
    textView.setTextSize(TypedValue.COMPLEX_UNIT_SP, 16);
    textView.setPadding((int)dpToPx(16), (int)dpToPx(8), (int)dpToPx(16), (int)dpToPx(8));
    textView.setBackgroundResource(R.drawable.label_bg);

    return textView;
}

private float dpToPx(float dp){
    return TypedValue.applyDimension(
            TypedValue.COMPLEX_UNIT_DIP, dp, getResources().getDisplayMetrics());
}

此外,您可以在同一行中引用此SO question

答案 1 :(得分:1)

如果您正在谈论Chips

在XML布局中添加一个ChipGroup,您要在其中显示筹码

<com.google.android.material.chip.ChipGroup
 android:id="@+id/chipGroup"
 android:layout_width="match_parent"
 app:chipSpacingVertical="2dp"
 android:layout_height="wrap_content"/>

现在,您可以使用此方法将ArrayList添加为Chip中的ChipGroup

private void addChip(String pItem, ChipGroup pChipGroup) {
    Chip lChip = new Chip(this);
    lChip.setText(pItem);
    lChip.setTextColor(getResources().getColor(R.color.primary_text));
    lChip.setChipBackgroundColor(getResources().getColorStateList(R.color.chip_bg));

    pChipGroup.addView(lChip, pChipGroup.getChildCount() - 1);
  }