CardView 内的布局重叠

Posted

技术标签:

【中文标题】CardView 内的布局重叠【英文标题】:Layouts inside CardView are overlapping 【发布时间】:2020-05-05 17:37:18 【问题描述】:

我正在尝试为我的应用设计卡片布局。目前我已经创建了如下布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:id="@+id/layout"
    android:layout_
    android:layout_
    android:background="#E4E8F8"
    android:orientation="vertical"
    android:padding="10dp"
    android:visibility="visible"
    tools:context=".MainActivity"
    tools:visibility="visible">

    <androidx.cardview.widget.CardView

        android:id="@+id/current1"
        android:layout_
        android:layout_
        app:cardBackgroundColor="#ffffe0">

        <LinearLayout
            android:id="@+id/card_head2"
            android:layout_
            android:layout_
            android:layout_marginStart="5dp"
            android:layout_marginLeft="5dp"
            android:layout_marginTop="10dp"
            android:orientation="horizontal"
            android:weightSum="3">

            <ImageView
                android:id="@+id/imageView1"
                android:layout_
                android:layout_
                android:adjustViewBounds="true"
                android:baselineAligned="false"
                android:contentDescription="@string/todo"
                app:srcCompat="@drawable/ic_map" />


            <TextView
                android:id="@+id/textView1"
                android:layout_
                android:layout_
                android:gravity="center"
                android:text="@string/map"
                android:textColor="#0F0F0F"
                android:textSize="15sp"
                android:textStyle="bold" />

            <ImageView
                android:id="@+id/imageView2"
                android:layout_
                android:layout_
                android:adjustViewBounds="true"
                android:baselineAligned="false"
                android:contentDescription="@string/todo"
                app:srcCompat="@drawable/ic_calendar" />


            <TextView
                android:id="@+id/textView2"
                android:layout_
                android:layout_
                android:gravity="center"
                android:text="@string/date"
                android:textColor="#0F0F0F"
                android:textSize="15sp"
                android:textStyle="bold" />

            <ImageView
                android:id="@+id/imageView3"
                android:layout_
                android:layout_
                android:adjustViewBounds="true"
                android:baselineAligned="false"
                android:contentDescription="@string/todo"
                app:srcCompat="@drawable/ic_watch" />

            <TextView
                android:id="@+id/textView3"
                android:layout_
                android:layout_
                android:gravity="center"
                android:text="@string/time"
                android:textColor="#0F0F0F"
                android:textSize="15sp"
                android:textStyle="bold" />

        </LinearLayout>

    </androidx.cardview.widget.CardView>


</LinearLayout>

当我尝试在创建的水平线性布局下方添加另一个水平线性布局时,新创建的水平布局与卡片内现有的水平布局重叠。

我想做的是这个(我通过按住鼠标按钮将布局保持在现有布局下方来截取这张图片):

但是当我释放鼠标按钮时,布局会自动调整并与现有布局重叠,如下所示:

请帮我创建布局。

【问题讨论】:

【参考方案1】:

您需要一个具有垂直方向的LinearLayout 作为CardView 的根,以便能够以垂直方式堆叠LinearLayouts

<androidx.cardview.widget.CardView
        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:id="@+id/current1"
        android:layout_
        android:layout_margin="10dp"
        android:layout_
        app:cardBackgroundColor="#ffffe0">
<!--You need a root layout of your CardView-->
<LinearLayout
        android:layout_
        android:layout_
        android:orientation="vertical">

    <LinearLayout
            android:id="@+id/card_head2"
            android:layout_
            android:layout_
            android:layout_marginStart="5dp"
            android:layout_marginLeft="5dp"
            android:layout_marginTop="10dp"
            android:orientation="horizontal"
            android:weightSum="3">

    </LinearLayout>

    <LinearLayout
            android:layout_
            android:layout_/>
</LinearLayout>
</androidx.cardview.widget.CardView>

【讨论】:

让我通过添加垂直布局来检查。 我需要有关元素 ID 的帮助。如何访问我的父 ID,以便我可以给孩子一个 ID 作为 childID[i] = parentID+eID[i] 以便在两个不同的布局中分隔 ID,其中 parentID 不同且 eID[i] 相同。 请提出一个单独的问题,提供更多信息。谢谢:)

以上是关于CardView 内的布局重叠的主要内容,如果未能解决你的问题,请参考以下文章

RecyclerView 结合 CardView 使用

CardView 内的工具栏,用于创建弹出菜单(溢出图标)

CardView 内的 TabLayout

卡片布局CardView

CardView布局的使用

带圆角的 CardView 内的 ImageView 绘制不正确