Snackbar在按下动作按钮时隐藏了浮动动作

时间:2015-09-17 02:16:44

标签: android material-design floating-action-button android-coordinatorlayout android-snackbar

我正在使用Snack bar和Floating Action按钮。我使用协调器布局使浮动操作按钮在显示快餐栏时显示/移动。问题是我为小吃店保留了一个动作。点击浮动按钮时,Snackbar会弹出,并且浮动操作按钮会向上移动。当我按下零食栏操作项时,浮动操作按钮隐藏在儿童零食栏下面。

如果我连续按下浮动动作按钮,那么浮动动作按钮也会被隐藏。

以下是我的代码。

activity_main.xml中

<RelativeLayout 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"
tools:context="com.example.dev.firsttest.Screen2"
>

<android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/primary_color"></android.support.v7.widget.Toolbar>

<android.support.design.widget.CoordinatorLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/coordinatorlayout">

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/searchfab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|right"
        android:layout_marginBottom="20dp"
        android:layout_marginRight="20dp"
        android:src="@drawable/ic_add_black_24dp"
        app:fabSize="normal">

    </android.support.design.widget.FloatingActionButton>

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

MainActivity

Toolbar toolbar;
FloatingActionButton searchfab;
CoordinatorLayout coordinatorLayout;


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

    toolbar = (Toolbar)findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    coordinatorLayout = (CoordinatorLayout)findViewById(R.id.coordinatorlayout);

    searchfab = (FloatingActionButton)findViewById(R.id.searchfab);
    searchfab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Snackbar.make(coordinatorLayout, "This is Snackbar Demo", Snackbar.LENGTH_LONG).setAction("Click", new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Snackbar.make(coordinatorLayout, "This is Child Snackbar", Snackbar.LENGTH_LONG).show();
                }
            }).show();
        }
    });


}

在Snackbar中按子操作并在浮动操作按钮上连续点击使浮动操作按钮隐藏回Snackbar

感谢您的帮助

谢谢

2 个答案:

答案 0 :(得分:7)

答案在这里:https://github.com/ggajews/coordinatorlayoutwithfabdemo

当小吃栏显示时,它将移动FAB。

答案 1 :(得分:0)

我无法重现您的问题。这是我的代码

View.OnClickListener test1 = new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(getActivity().findViewById(R.id.snackbarPosition), "test 1", Snackbar.LENGTH_LONG)
                        .setAction(R.string.snackbar_action_undo, new View.OnClickListener() {

                            @Override
                            public void onClick(View view) {
                                 Snackbar.make(getActivity().findViewById(R.id.snackbarPosition), "test 2", Snackbar.LENGTH_LONG)
                                        .setActionTextColor(getResources().getColor(R.color.myBlueGreen))
                                        .show();
                            }
                        })
                        .show();
            }
        };

FloatingActionButton button = (FloatingActionButton)streamView.findViewById(R.id.buttonFloat);
button.setOnClickListener(test1); 

XML

<android.support.design.widget.CoordinatorLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:textColor="@android:color/white"
    android:id="@+id/snackbarPosition">

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/buttonFloat"
        android:src="@drawable/ic_content_new"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|right"
        android:layout_marginBottom="20dp"
        android:layout_marginRight="20dp"
        app:backgroundTint="@color/myBlueGreen"

        app:elevation="6dp"
        app:pressedTranslationZ="12dp"
        />

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

添加第二个零食吧&#34; test2&#34;在快餐栏上显示为OnClickListener&#34; test1&#34;,对我来说,取代了快餐栏&#34; test1&#34;通过&#34; test2&#34; (并且不隐藏浮动操作按钮)

此外,在“浮动操作按钮”上单击两次可使快餐栏&#34; test1&#34;眨眼,即出现两次而不是两个小吃一个在彼此之上。浮动操作按钮不会消失。

换句话说,我从未见过一个孩子&#34;在&#34;父母&#34;顶部的小吃吧小吃吧。

我看不出你和我的代码之间的区别。也许尝试复制我的代码,看看它是否能解决你的问题。