首页 > 解决方案 > 在视图底部添加阴影

问题描述

我在这个布局上遇到了很多麻烦。

基本上我有 2 条直线,一条略带灰色,底部有阴影,另一条直线下方只有白色。我的麻烦是将阴影添加到第一个线性的末尾。我尝试了“海拔”,但这就是我现在需要的,因为如果最后 10dp 来自不同的颜色,我希望阴影在线性内,但我没有做对。

在此处输入图像描述

到目前为止,这是我的布局,我想在第一个线性视图中放置一个视图,但效果不佳。

任何想法如何做到这一点?

<?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"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <LinearLayout
        android:layout_weight="1"
        android:gravity="center"
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:background="#f8f8f8"
        android:layout_height="0dp">

        <android.support.v7.widget.CardView
            app:cardCornerRadius="10dp"
            app:cardElevation="10dp"
            android:layout_width="312dp"
            android:layout_height="204dp"
            app:cardBackgroundColor="@android:color/holo_red_light"/> 
    </LinearLayout>


    <LinearLayout
        android:background="#ffffff"
        android:layout_weight="1"
        android:gravity="center"
        android:layout_width="match_parent"
        android:layout_height="0dp">

    </LinearLayout>
</LinearLayout>

标签: androidandroid-layout

解决方案


尝试在linearlayoutcardview所坐的下方使用下面的线。

android:elevation="8dp"

让你的cardElevation部分cardView保持原样。

card_view:cardElevation="10dp"
card_view:cardPreventCornerOverlap="false"

也只是一个建议:

如果您android:layout_weight在两个孩子中使用,请按照@Ming Leung在这里 给出的答案中提到的那样linearLayout放入android:weightSum="2"您的父母linearLayout

有关android:weightSum="2"您的更多信息,请参阅此页面上的答案

页面elevation将帮助您cardview

希望有帮助。


推荐阅读