首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ConstraintLayout按形状设置圆角资源文件不起作用

ConstraintLayout按形状设置圆角资源文件不起作用
EN

Stack Overflow用户
提问于 2020-05-19 01:47:21
回答 1查看 4.1K关注 0票数 5

我遇到了一个奇怪的问题,当我通过shape资源文件设置适配器项角的布局时,它没有工作。

这是我的shape资源文件

代码语言:javascript
运行
复制
<?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>

这是我的适配器项布局。

代码语言:javascript
运行
复制
<?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,用于显示上面的项目布局

代码语言:javascript
运行
复制
<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适配器

代码语言:javascript
运行
复制
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()
            }
        }
    }
}

对这个奇怪的问题有什么想法吗?提前谢谢你!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-19 03:18:54

看起来,即使您正在设置您的ConstraintLayout的背景,它是重叠的ImageView,因此您没有得到您的ConstraintLayout的形状。我建议使用CardView而不是ConstraintLayout。将可绘制设置为CardView的背景,并将所有内容放入CardView中,就像您为ConstraintLayout所做的那样。

我希望这能帮上忙!

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61881906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档