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 内的布局重叠的主要内容,如果未能解决你的问题,请参考以下文章