Kat*_*une 21 android android-layout coordinator-layout
我已经创建了这样的AppBar布局
<android.support.design.widget.AppBarLayout
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/appbar_layout"
android:layout_height="@dimen/app_bar_height"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:elevation="20dp">
<android.support.design.widget.CollapsingToolbarLayout...>
</android.support.design.widget.AppBarLayout>
Run Code Online (Sandbox Code Playgroud)
它工作并在LinearLayout中投射阴影:
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<include layout="@layout/app_bar_large" />
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)
但是,当我把它放入CoordinatorLayout时,阴影消失了:
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<include layout="@layout/app_bar_large" />
</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)
如何让appbar再次展示它的影子?
ian*_*ake 15
这实际上是一个实现细节CollapsingToolbarLayout,如源代码所示:
if (Math.abs(verticalOffset) == scrollRange) {
// If we have some pinned children, and we're offset to only show those views,
// we want to be elevate
ViewCompat.setElevation(layout, layout.getTargetElevation());
} else {
// Otherwise, we're inline with the content
ViewCompat.setElevation(layout, 0f);
}
Run Code Online (Sandbox Code Playgroud)
在CollapsingToolbarLayout显示非固定元素时删除高程- 默认情况下,只有固定子项可见时才会有高程.
小智 7
原因如上,请尝试解决:
appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
//some other code here
ViewCompat.setElevation(appBarLayout, The Elevation In Px);
}
});
Run Code Online (Sandbox Code Playgroud)
解决方案是使用app:elevation=0dp删除默认标高并设置android:translationZ为您想要的标高。
注意:下面的代码使用最新的 AndroidX / Material 库,如果您使用旧的支持库,则可能无法工作
<com.google.android.material.appbar.AppBarLayout
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:translationZ="8dp"
app:elevation="0dp">
<!--
* `app:elevation=0dp` disables the default shadow that is automatically added on
scroll ; other values e.g. `6dp` are ignored despite what the official doc says
(see below)
* so instead we're using `android:translationZ` to add a shadow with a custom
elevation
-->
Run Code Online (Sandbox Code Playgroud)
AppBarLayout # setTargetElevation()的文档指出,您可以使用该app:elevation属性设置自定义标高值,但对于大于的值,它对我不起作用0dp,因此我将translationZ其用作解决方法。
| 归档时间: |
|
| 查看次数: |
13411 次 |
| 最近记录: |