Android L提升普通按钮

时间:2014-11-21 21:12:27

标签: android button android-5.0-lollipop

我一直在寻找一种获得“凸起”圆角矩形按钮的方法,而不是使用背景和自定义视图自己完成。我想要这样的按钮:

我以为会这样做:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MyActivity">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Enter the Danger Zone"
        android:id="@+id/btn"
        android:elevation="8dp" <!-- Here -->
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginBottom="16dp"/>

</RelativeLayout>

但这没有任何作用。按钮看起来一样。 WTF?

是的,我正在使用最新的SDK等等。

编辑: 所以我添加了一个translationZ。现在,当活动打开时会出现阴影,但在动画完成时会消失。 ???

2 个答案:

答案 0 :(得分:1)

尝试添加状态列表动画:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item
    android:state_enabled="true"
    android:state_pressed="true">
    <set>
        <objectAnimator
            android:duration="@android:integer/config_shortAnimTime"
            android:propertyName="translationZ"
            android:valueTo="8dp"
            android:valueType="floatType" />
    </set>
</item>
<item>
    <set>
        <objectAnimator
            android:duration="@android:integer/config_shortAnimTime"
            android:propertyName="translationZ"
            android:valueTo="2dp"
            android:valueType="floatType" />
    </set>
</item>
</selector>

答案 1 :(得分:0)

我有一个类似的问题,我认为是由于错误地夸大了布局,但似乎添加了clipToPadding就可以了。 必须将其设置为包含要投射阴影的视图的父ViewGroup。

<YourParentLayout
...
android:clipToPadding="false"
...

如果您的视图没有背景,请使用android:outlineProvider="bounds"