相关疑难解决方法(0)

如何使用菜单布局将自定义项添加到NavigationView?

我一直在尝试通过使用NavigationViewAndroid设计支持库中的新类来简化一些导航抽屉代码.如果您只想要左侧的图标和右侧的文本(例如文档中的示例),那么它的效果很好,但是如果我想android.support.v7.widget.SwitchCompat在Google Play电影应用中添加一个自定义视图,那该怎么办?看下面的截图)?

Google Play电影

我已尝试使用该actionLayout属性指定自定义布局文件,如下面的示例代码中所示,但该属性似乎被忽略,因为它不起作用.

res/menu/navigation_drawer.xml

<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <group android:id="@+id/group1"
            android:checkableBehavior="single">
        <item
            android:id="@+id/nav_screen1"
            android:icon="@drawable/ic_list_black_24dp"
            android:title="Screen 1" />
        <item
            android:id="@+id/nav_screen2"
            android:icon="@drawable/ic_search_black_24dp"
            android:title="Screen2"/>
    </group>
    <group  android:id="@+id/group2">
        <item
            android:id="@+id/nav_custom"
            android:icon="@drawable/custom_icon_24dp"
            app:actionLayout="@layout/nav_drawer_switch"
            android:title="Custom item with switch"/>
        <item
            android:id="@+id/nav_settings"
            android:icon="@drawable/ic_settings_black_24dp"
            android:title="Settings"/>
    </group>
</menu>
Run Code Online (Sandbox Code Playgroud)

res/layout/nav_drawer_switch.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <android.support.v7.widget.SwitchCompat
        android:layout_width="fill_parent"
        android:layout_height="match_parent"
        android:text="Custom item with switch"/>
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)

我怎样才能让它发挥作用?理想情况下,我想在仍然使用我的菜单布局的同时添加自定义视图,但如果不使用粗糙的黑客(如利用支持库生成的现有布局)那是不可能的,那么我想知道代码最少的解决方案,仍然值得转换NavigationView.

android navigation-drawer

51
推荐指数
4
解决办法
4万
查看次数

导航视图中的自定义菜单项大小和文本大小

我在导航视图中使用代码来自定义文本和行高的高度,它适用于api21 +但是相同的代码在api 16中不起作用.我怎样才能使它工作?

码:

创建样式并使用它将其应用于NavigationView app:theme

<style name="NavigationViewStyle">
     <item name="android:textSize">20sp</item> <!-- menu item text size-->
     <item name="android:listPreferredItemHeightSmall">40dp</item><!-- menu item height-->
</style>
Run Code Online (Sandbox Code Playgroud)

然后,使用app:theme将此样式应用于NavigationView

<android.support.design.widget.NavigationView
       ...
       ...    
        app:theme="@style/NavigationViewStyle"
       ...
       ...


</android.support.design.widget.NavigationView>
Run Code Online (Sandbox Code Playgroud)

android navigationview

6
推荐指数
1
解决办法
2969
查看次数