android:无法制作多线芯片组

标签 android android-relativelayout androidx android-chips

我在相对布局中有一个芯片组以及一个代码如下所示的 TextView 。

    <RelativeLayout
    ...

    <TextView
        android:layout_width="30dp"
        android:layout_height="wrap_content"
        android:text="TextTitle"
        android:layout_alignParentStart="true"
        android:gravity="left"
        android:layout_marginTop="16dp"
        android:textColor="@android:color/white"
        android:textStyle="bold"
        android:textSize="14sp"
        android:id="@+id/tv"
        android:layout_toLeftOf="@id/cg"
        android:layout_alignBaseline="@id/cg"
        />

       <com.google.android.material.chip.ChipGroup
       android:id="@+id/cg"
       android:layout_width="wrap_content"
       android:layout_height="14dp"
       android:layout_marginTop="20dp"
       android:layout_marginBottom="5dp"
       android:layout_alignParentRight="true"
       android:layout_alignParentEnd="true"
       android:textColor="@android:color/black"
       android:textStyle="bold"
       android:textSize="12sp"
       app:singleSelection="false"
       app:chipSpacingVertical="32dp"
       app:chipSpacingHorizontal="5dp"
       app:singleLine="false"
       />
  </RelativeLayout>

我像下面这样动态地向这个芯片组添加芯片:

Chip chip;

for(int i=0;i<2;i++){
    chip = new Chip(this);
    chip.setText("Text:"+i);
    chip.setChipBackgroundColorResource(android.R.color.darker_gray);
    chip.setTextColor(Color.WHITE);
    mChipGroup.addView(chip);
}

上面将 textview 和 chipgroup 并排放置(芯片位于 textview 的最右边,这是我想要的)。

对于 2 或 3 个芯片,输出如下所示:

enter image description here

但是当我有超过 3 个芯片时,它看起来很糟糕:

enter image description here

我引用了文档并尝试使 chipgroup 多行并在 chipgroup xml 中添加以下内容

   app:chipSpacingVertical="32dp"
   app:chipSpacingHorizontal="5dp"
   app:singleLine="false"

看起来和图2一样。

我需要的是一个带有多行选项的芯片组,其间距与 pic1 中的间距相同,即在 pic1 中,如果芯片数量增加,我希望 Text3 在 Text0 下方,Text4 在 Text1 下方,依此类推!.

我确定我一定遗漏了什么,但不知道是什么。任何帮助都会非常有用。提前致谢!

最佳答案

我更新了@Sajith 的回答,看看它是否可行:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:weightSum="100">

        <TextView
            android:layout_width="0dp"
            android:layout_weight="25"
            android:layout_height="wrap_content"
            android:text="TextTitle"
            android:gravity="left"
            android:layout_marginTop="16dp"
            android:textColor="@android:color/white"
            android:textStyle="bold"
            android:textSize="14sp"
            android:id="@+id/tv" />

        <FrameLayout
            android:layout_width="0dp"
            android:layout_weight="75"
            android:layout_height="wrap_content" >

            <com.google.android.material.chip.ChipGroup
                android:id="@+id/cg"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="end"
                android:layout_marginTop="20dp"
                android:layout_marginBottom="5dp"
                android:textColor="@android:color/black"
                android:textStyle="bold"
                android:textSize="12sp"
                app:singleSelection="false"
                app:chipSpacingVertical="32dp"
                app:chipSpacingHorizontal="5dp"
                app:singleLine="false" />
        </FrameLayout>

    </LinearLayout>
</RelativeLayout>

关于android:无法制作多线芯片组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56244817/

相关文章:

需要使用非内存SD卡的Android应用

java - TLS v1.2 上的 Android 客户端/服务器

android - 将 TextView 在 ImageView 内水平居中,Imageview 旁边还有另一个 View

java - 使用 BroadcastReceiver 更新 ProgressBar

android - 如何启动安卓设备并跳过屏幕锁定

android - 使用 RelativeLayout 重叠 ViewPager 选项卡

android - 相对布局 : Many options if elements are GONE

android - flutter :迁移到 androidx

android - 无法解析所有androidx依赖项

android - 错误 : Failed to resolve: viewpager - how to fix that?