我正在尝试动态地将几个芯片添加到芯片组中。第一个看起来很好,但其他的看起来不太好。但是当我使用XML时,它工作得很好。
activity_main.xml
<HorizontalScrollView
android:layout_width="350dp"
android:layout_height="wrap_content"
android:scrollbars="none"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toStartOf="@+id/chips_select"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView"
app:layout_constraintVertical_bias="0.51">
<com.google.android.material.chip.ChipGroup
android:id="@+id/chip_group_main"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="8dp"
android:layout_marginTop="2dp"
app:chipSpacingHorizontal="4dp">
<com.google.android.material.chip.Chip
style="@style/ChipTextAppearance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello"
app:chipBackgroundColor="@color/colorAccent"
app:closeIconEnabled="true" />
<com.google.android.material.chip.Chip
style="@style/ChipTextAppearance"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="World"
app:chipBackgroundColor="@color/colorAccent"
app:closeIconEnabled="true" />
</com.google.android.material.chip.ChipGroup>
</HorizontalScrollView>
在MainActivity.java
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Chip chip = new Chip(this);
chip.setText("ABC");
chip.setChipBackgroundColorResource(R.color.colorAccent);
chip.setCloseIconVisible(true);
chip.setTextColor(getResources().getColor(R.color.white));
chip.setTextAppearance(R.style.ChipTextAppearance);
Chip chip2 = new Chip(this);
chip.setText("XYZ");
chip.setChipBackgroundColorResource(R.color.colorAccent);
chip.setCloseIconVisible(true);
chip.setTextColor(getResources().getColor(R.color.white));
chip.setTextAppearance(R.style.ChipTextAppearance);
ChipGroup chipGroup = findViewById(R.id.chip_group_main);
chipGroup.addView(chip);
chipGroup.addView(chip2);
}
style.xml
<resources>
<style name="AppTheme" parent="Theme.MaterialComponents.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="ChipTextAppearance" parent="TextAppearance.MaterialComponents.Chip">
<item name="android:textColor">@android:color/white</item>
<item name="android:textSize">12sp</item>
</style>
</resources>
standalone_chip.xml
<?xml version="1.0" encoding="utf-8"?>
<chip
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
app:chipBackgroundColor="@color/colorAccent"
app:closeIconEnabled="true"
style="@style/ChipTextAppearance"
app:closeIconTint="@android:color/white" />
3条答案
按热度按时间liwlm1x91#
在你的主要活动中,你是这样做的。
请注意,您正在创建一个新的chip示例,即chip2,但您在接下来的几行中对chip而不是chip2示例进行了更改,因此chip2不会受到您之前所做的任何更改的影响。所以为了解决这个问题,像这样修改代码
ogq8wdun2#
是的,可以添加芯片到组与
chipGroup.addView(chip);
请注意,你应该添加id到每个芯片,以便一些功能的组工作完美(例如singleSelection="true"
)fwzugrvs3#
在Kotlin中:
//创建了seaprate方法来创建具有属性的芯片。