锚定材质浮动操作按钮

问题描述 投票:0回答:1

layout_anchor 无法与材质操作按钮一起使用。是否有其他正确的方法将其锚定到布局。我浏览了 Fab 文档材料设计浮动操作按钮但我找不到任何合适的方法来锚定按钮。

下面的代码之前可以正常工作,但是随着 SDK 更新,它无法正常工作。 layout_anchor 属性使按钮消失,但可以在 XML 编辑器中看到按钮与 UI 的边距一起存在。

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
    android:id="@+id/settings"
    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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context=".SatActivity">

    <com.google.android.material.appbar.AppBarLayout
        android:id="@+id/app_barsettings"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:minHeight="@dimen/app_bar_height"
        android:fitsSystemWindows="true"
        android:theme="@style/AppTheme.AppBarOverlay">

        <com.google.android.material.appbar.CollapsingToolbarLayout
            android:id="@+id/toolbar_layout_settings"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleGravity="bottom"
            android:background="@drawable/side_nav_bar"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <androidx.appcompat.widget.Toolbar
                android:id="@+id/toolbar_settings"
                android:layout_width="match_parent"
                android:background="@android:color/transparent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/AppTheme.PopupOverlay"/>

        </com.google.android.material.appbar.CollapsingToolbarLayout>
    </com.google.android.material.appbar.AppBarLayout>

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/fab_log_out"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/fab_margin"
        app:layout_anchorGravity="bottom|end"
        app:layout_anchor="@id/app_bar_layout_settings"
        android:src="@drawable/ic_light_logout"/>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

这是 Gradle 文件

compileSdkVersion 29
buildToolsVersion "29.0.3"
defaultConfig {
    minSdkVersion 22
    targetSdkVersion 29
    versionCode 1
    versionName '1.0.0'
}
android android-layout material-design floating-action-button
1个回答
0
投票

尝试在主题.xml 中将

Material3
更改为
MaterialComponents

© www.soinside.com 2019 - 2024. All rights reserved.