Библиотека поддержки дизайна Android: FloatingActionButon (FAB) правильно отображается в более ранних версиях Android и неправильно в Lollipop

Я добавил библиотеку поддержки дизайна Android. Я тестирую приложение с двумя эмуляторами: Lollipop и Jellybean. Версия Jellybean правильно отображает FAB. В версии Lollipop FAB не имеет высоты или полей. Любые предложения по устранению этой проблемы?

Ниже я разместил сообщение о макете, активности и двух изображениях, показывающих разницу. Если вам нужно больше кода, дайте мне знать, и я опубликую его.

Примечание. Я удалил большую часть кода, не относящегося к вопросу.

Макет

<android.support.design.widget.CoordinatorLayout
    android:id="@+id/mainLayout"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:card_view="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=".MainActivity">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="56dp"
            android:background="@color/primary"
            app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>

        <ImageView
            android:id="@+id/imShadow"
            android:layout_width="match_parent"
            android:layout_height="10dp"
            android:layout_below="@+id/toolbar"
            android:background="@drawable/toolbar_shadow"
            android:orientation="vertical"/>
    </RelativeLayout>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end|bottom"
        android:src="@mipmap/ic_search"/>

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

Активность

public class MainActivity extends AppCompatActivity {

    private Toolbar toolbarMain;

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


        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        final CoordinatorLayout coordinatorLayout = (CoordinatorLayout) findViewById(R.id.mainLayout);

        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Snackbar.make(coordinatorLayout, "Hello World!", Snackbar.LENGTH_LONG).setAction("Action", new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {

                    }
                }).show();
            }
        });

    }

    private void iniToolbarMain() {
        toolbarMain = (Toolbar) findViewById(R.id.toolbar);
        toolbarMain.inflateMenu(R.menu.menu_main);
        toolbarMain.setTitle("Hello World");
        toolbarMain.setNavigationIcon(R.mipmap.ic_menu);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        int id = item.getItemId();
        if (id == R.id.action_search) {
            handleToolbar.handleToolBar(search, toolbarMain, MainActivity.this);
            etSearch.requestFocus();
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

Мармелад

введите здесь описание изображения

Леденец

введите здесь описание изображения


person Eugene H    schedule 30.05.2015    source источник
comment
Кто-то не поленился и провел достаточно обширное тестирование упомянутого поведения FAB; code.google.com/p/android/issues/detail?id= 175185 .   -  person harism    schedule 31.05.2015


Ответы (2)


Добавьте поля right и bottom в XML виджета android.support.design.widget.FloatingActionButton. Если вы хотите настроить высоту FAB, просто используйте атрибут app:elevation.

Превосходный XML:

<android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="20dp"
    android:layout_marginRight="20dp"
    android:layout_gravity="bottom|right"
    android:src="@mipmap/ic_search"
    app:fabSize="normal"/>
person Ferdous Ahamed    schedule 27.03.2017

person    schedule
comment
borderWith действительно решает проблему с высотой. - person wujek; 03.06.2015
comment
Просто небольшой указатель, в рекомендациях говорится, что маржа FAB должна быть 16dp, а не 8 :-) - person Suleiman19; 05.06.2015
comment
borderWith=0dp также исправлена ​​проблема с тем, что FAB был квадратным, а не круглым на устройствах Jelly Bean. - person user1354603; 16.06.2015
comment
У кого-нибудь есть объяснение? - person Alex.F; 17.06.2015