android - 通过形状资源文件设置圆角的 ConstraintLayout 不起作用
问题描述
shape
我遇到了一个奇怪的问题,当我通过资源文件设置用于适配器项角的布局时它不起作用。
这是我的shape
资源文件
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
<corners android:radius="8dp" />
</shape>
这是我的适配器项目布局
<?xml version="1.0" encoding="utf-8"?>
<layout 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">
<data>
<import type="android.view.View.OnClickListener" />
<import type="android.view.View" />
<import type="com.zhixin.wedeep.homepage.data.model.BriefComposition" />
<variable
name="clickListener"
type="OnClickListener" />
<variable
name="composition"
type="BriefComposition" />
</data>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="108dp"
android:layout_height="150dp"
android:background="@drawable/homepage_shape_recommend_composition_background"
android:gravity="center"
android:onClick="@{clickListener}"
android:orientation="vertical">
<TextView
android:id="@+id/text_view_label_is_new"
android:layout_width="36dp"
android:layout_height="22dp"
android:text="@string/homepage_new"
android:textColor="@color/color_white"
android:textSize="@dimen/font_size_10"
android:visibility='@{composition.tag == "NEW" ? View.VISIBLE : View.INVISIBLE}'
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:text="新上" />
<ImageView
android:id="@+id/image_view_cover"
imageFromUrl="@{composition.cover}"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="centerCrop"
tools:src="@drawable/gt3_new_bind_logo" />
<LinearLayout
android:id="@+id/linear_layout_text_area"
android:layout_width="match_parent"
android:layout_height="42dp"
android:orientation="vertical"
android:paddingStart="5dp"
app:layout_constraintBottom_toBottomOf="parent"
tools:ignore="RtlSymmetry">
<TextView
android:id="@+id/text_view_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:maxLines="1"
android:text="@{composition.title}"
android:textColor="@color/color_white"
android:textSize="@dimen/font_size_13"
tools:text="助眠脑波" />
<TextView
android:id="@+id/text_view_duration"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="1dp"
android:text="@{composition.duration}"
android:textColor="@color/color_white"
android:textSize="@dimen/font_size_10"
tools:text="5-30min" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
这是我RecylerView
用于显示上述项目布局
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recycler_view_recommendation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:layout_marginStart="15dp"
android:layout_marginEnd="15dp"
app:layoutManager="androidx.recyclerview.widget.GridLayoutManager"
app:spanCount="3"
tools:itemCount="6"
tools:listitem="@layout/homepage_item_recommend_composition" />
这是我的RecylerView
适配器
class RecommendCompositionsAdapter : ListAdapter<BriefComposition, RecommendCompositionsAdapter.ViewHolder>(BriefCompositionDiffCallback()) {
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
return ViewHolder(HomepageItemRecommendCompositionBinding.inflate(
LayoutInflater.from(parent.context), parent, false))
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
val briefComposition = getItem(position)
briefComposition?.let {
holder.apply {
itemView.tag = it
bind(createOnClickListener(it.id), it)
}
}
}
private fun createOnClickListener(id: String): View.OnClickListener {
return View.OnClickListener {
ARouter.getInstance().build(RouterConstant.PATH_AUDIO_PLAYER).withString(AudioPlayerActivity.KEY_ID, id).navigation()
}
}
class ViewHolder(private val binding: HomepageItemRecommendCompositionBinding)
: RecyclerView.ViewHolder(binding.root) {
fun bind(listener: View.OnClickListener, item: BriefComposition
) {
binding.apply {
clickListener = listener
composition = item
// from View
executePendingBindings()
}
}
}
}
对这个奇怪的问题有什么想法吗?先感谢您!
解决方案
看起来即使您正在设置背景ConstraintLayout
,它也会被 重叠,ImageView
因此您没有得到您ConstraintLayout
所拥有的形状。我建议使用 aCardView
而不是ConstraintLayout
. 将可绘制对象设置为您的背景,CardView
并将所有内容都放在您的内部,CardView
就像您为ConstraintLayout
.
我希望这会有所帮助!
推荐阅读
- node.js - 监控 NodeJS API
- javascript - 具有服务器端处理的 DataTable
- python - 使用 Python 请求修复 SSL 证书错误
- linker - PIC32 Bootloader 应用链接描述文件引导部分
- python - 试图证明我的 Python Battleship 游戏是白痴
- amazon-web-services - 从 CLI 将 Auto-Scaling 策略附加到 ECS 服务
- c++ - 宝宝起名人气节目
- android - Exoplayer 的渲染器的解码器不符合所选轨道的格式
- google-cloud-platform - 如何使用/实现创建的 Google Cloud API
- php - 从 div 标签上传多个文件 PHP