Arhn - архитектура программирования

Материал FAB morphing

Согласно material.io, плавающая кнопка действия может быть преобразована в меню действий, например это. Есть ли способ сделать это, используя только библиотеку материалов (без сторонних библиотек)?

Я попробовал эту библиотеку, но после закрытия меню она ломает потрясающую позицию в соответствии с нижней панелью приложений.

Вот что у меня получилось в результате Потрясающее меню

Код:

Activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <com.google.android.material.appbar.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <androidx.appcompat.widget.Toolbar
            app:layout_scrollFlags="scroll|enterAlways|snap"
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?actionBarSize"/>
    </com.google.android.material.appbar.AppBarLayout>
    <androidx.viewpager.widget.ViewPager
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
    <com.google.android.material.bottomappbar.BottomAppBar
        android:id="@+id/bottomBar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:fabAlignmentMode="end"
        app:backgroundTint="?colorPrimary"
        android:layout_gravity="bottom">
        <com.google.android.material.tabs.TabLayout
            android:id="@+id/tabs"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@android:color/transparent"/>
    </com.google.android.material.bottomappbar.BottomAppBar>
    <com.google.android.material.floatingactionbutton.FloatingActionButton
        app:useCompatPadding="true"
        app:layout_anchor="@id/bottomBar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/fab"/>
    <View
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#53000000"
        android:visibility="invisible"
        android:id="@+id/overlay"/>
    <io.codetail.widget.RevealFrameLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <io.files.view.MenuCardView
            android:id="@+id/menu"
            android:visibility="invisible"
            android:layout_margin="56dp"
            android:layout_gravity="bottom|end"
            android:layout_width="wrap_content"
            app:cardUseCompatPadding="true"
            app:menu="@menu/new_tab_options"
            android:layout_height="wrap_content"/>
    </io.codetail.widget.RevealFrameLayout>
</androidx.coordinatorlayout.widget.CoordinatorLayout>

MainActivity.kt

import android.os.Bundle
import android.view.View
import androidx.appcompat.app.AppCompatActivity
import com.konifar.fab_transformation.FabTransformation
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        overlay.setOnClickListener {
            FabTransformation.with(fab)
                .setOverlay(it)
                .transformFrom(menu)
        }
        fab.setOnClickListener {
            FabTransformation.with(it)
                .setOverlay(overlay)
                .transformTo(menu)
        }
    }

    override fun onBackPressed() {
        if(menu.visibility== View.VISIBLE){
            FabTransformation.with(fab)
                .setOverlay(overlay)
                .transformFrom(menu)
        }else super.onBackPressed()
    }
}

Ответы:


1

Только что нашел решение: используйте com.google.android.material.transformation.FabTransformationSheetBehavior для макета листа и com.google.android.material.transformation.FabTransformationScrimBehavior для просмотра наложения. Для поддержки красивой анимации используйте com.google.android.material.transformation.TransformationChildCard или com.google.android.material.transformation.TransformationChildLayout для корневого представления листа. Чтобы преобразовать fab в лист, установите isExpanded в fab в true, а для обратного преобразования установите isExpanded в false

21.12.2018
  • Я нашел этот официальный сайт - приведенный выше код устарел: github.com/material-components/material-components-android/ 31.07.2020
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..