浮动操作按钮不会停留在 SnackBar 的顶部

Posted

技术标签:

【中文标题】浮动操作按钮不会停留在 SnackBar 的顶部【英文标题】:Floating Action Button won't stay on top of SnackBar 【发布时间】:2015-10-26 18:31:55 【问题描述】:

我已经处理这个问题好几天了。我根本无法让 FloatingActionButton 位于 SnackBar 之上。

我看过很多教程..什么都试过了。

我希望有人可以在这里帮助我:

我的布局是:

<android.support.v4.widget.DrawerLayout
    android:id="@+id/drawer_layout"
    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_
    android:layout_
    android:fitsSystemWindows="true">

    <android.support.design.widget.CoordinatorLayout
        android:id="@+id/coordinatorLayout"
        android:layout_
        android:layout_>

        <android.support.design.widget.AppBarLayout
            android:id="@+id/appbar"
            android:layout_
            android:layout_
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_
                android:layout_
                android:background="?attr/colorPrimary"
                app:layout_collapseMode="pin"/>
        </android.support.design.widget.AppBarLayout>

        <!-- Your Scrollable View -->

        <android.support.design.widget.FloatingActionButton
            android:id="@+id/fab"
            android:layout_
            android:layout_
            android:layout_gravity="bottom|right"
            android:layout_marginBottom="20dp"
            android:layout_marginRight="20dp"
            android:src="@drawable/ic_start"
            app:fabSize="normal"/>

    </android.support.design.widget.CoordinatorLayout>
</android.support.v4.widget.DrawerLayout>

我的活动代码是:

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;

public class MainActivity extends AppCompatActivity implements OnClickListener 

    DrawerLayout drawerLayout;
    Toolbar toolbar;
    FloatingActionButton fab;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        setupToolbar();
        setupFab();
    


    @Override
    public boolean onOptionsItemSelected(MenuItem item) 
        switch (item.getItemId()) 
            case android.R.id.home:
                if(drawerLayout != null)
                    drawerLayout.openDrawer(GravityCompat.START);
                return true;
        
        return super.onOptionsItemSelected(item);
    

    private void setupNavigationView()

        drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
    

    private void setupFab()
        fab = (FloatingActionButton) findViewById(R.id.fab);
        if(fab != null)
            fab.setOnClickListener(this);
    
    private void setupToolbar()
        toolbar = (Toolbar) findViewById(R.id.toolbar);
        if(toolbar != null)
            setSupportActionBar(toolbar);

        // Show menu icon
        final ActionBar ab = getSupportActionBar();
        ab.setHomeAsUpIndicator(R.drawable.ic_menu);
        ab.setDisplayHomeAsUpEnabled(true);
    

    @Override
    public void onClick(View view) 

        if(view.getId() == R.id.fab)

            Snackbar
              .make(findViewById(R.id.coordinatorLayout), "This is Snackbar", Snackbar.LENGTH_LONG)
              .setAction("Action", this)
              .show(); // Don�t forget to show!
        
    

结果是这个:

【问题讨论】:

我可以知道您使用的是什么可滚动视图吗? 遵循本指南:inthecheesefactory.com/blog/… 这是一个 ViewPager @Sree14。并且每个片段都有一个recyclerView @FábioCarballo 你找到答案了吗?当我尝试多次单击该按钮时,我遇到了同样的问题。 @SrikarReddy 嘿,对我来说问题出在 proguard 上。 【参考方案1】:

而不是使用 coordinatorLayout,但实际上你需要 FloatingActionButton 的视图:

@Override
public void onClick(View view) 
    if(view.getId() == R.id.fab) 
        Snackbar .make(view, "This is Snackbar", Snackbar.LENGTH_LONG) .setAction("Action", this) .show();
    
 

【讨论】:

【参考方案2】:

将此属性放入您的 FloatingActionButton(FAB):

app:layout_anchor="@id/coordinatorLayout"

这应该将 FAB 与您的 CoordinatorLayout 相关联。

【讨论】:

java.lang.IllegalStateException: View can not be anchored to the the parent CoordinatorLayout

以上是关于浮动操作按钮不会停留在 SnackBar 的顶部的主要内容,如果未能解决你的问题,请参考以下文章

如何像浮动按钮一样在 Snackbar 上方移动视图

如何设置小吃栏和浮动操作按钮之间的距离?

在 ListView 顶部包含浮动操作按钮

Snackbar Toast

颤振在底部表顶部显示 Snackbar

解锁锁定屏幕后如何保持浮动操作按钮固定在我的视图中?