Как иметь несколько элементов в строке для MaterialDrawer? - PullRequest
0 голосов
/ 07 июля 2019

Я использую отличную библиотеку MaterialDrawer , чтобы добавить блок навигации в мое приложение.Пока это работает очень хорошо, но мне интересно, есть ли способ добавить несколько элементов в строку.Например, чтобы показать несколько связанных настроек, можно переключать их.

Я просмотрел документацию библиотеки и средство отслеживания проблем на Github, но не смог найти ничего релевантного.

1 Ответ

0 голосов
/ 07 июля 2019

Можно создать свой собственный макет внутри NavigationView в DrawerLayout.Например, следующий код имеет 4 строки с 3 элементами в каждой строке.

<android.support.v4.widget.DrawerLayout
        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:id="@+id/drawer_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fitsSystemWindows="true"
        tools:openDrawer="start">
    <android.support.design.widget.NavigationView
            android:id="@+id/nav_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="#AAFFAA"
            android:fitsSystemWindows="false"
            android:layout_gravity="end">
        <GridLayout
                android:columnCount="3"
                android:rowCount="4"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:columnOrderPreserved="true"
                android:rowOrderPreserved="true">
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="sin"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="cos"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="tan"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="ln"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="log"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="!"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="\u03c0"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="e"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="^"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="("/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text=")"/>
            <TextView
                    android:layout_columnWeight="1"
                    android:layout_rowWeight="1"
                    android:layout_gravity="fill_horizontal"
                    android:gravity="center"
                    android:textSize="18sp"
                    android:text="\u221a"/>

        </GridLayout>
    </android.support.design.widget.NavigationView>
</android.support.v4.widget.DrawerLayout>

В документации MaterialDrawer указано, что можно использовать Custom DrawerLayoutРеализация , но я никогда не делал этого раньше, поэтому я не могу предоставить образец для этого в данный момент.

...