我一直在寻找一种获得“凸起”圆角矩形按钮的方法,而不是使用背景和自定义视图自己完成。我想要这样的按钮:
我以为会这样做:
<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。现在,当活动打开时会出现阴影,但在动画完成时会消失。 ???
答案 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"