【问题标题】:Adding a view to a drawer layout in navigation drawer将视图添加到导航抽屉中的抽屉布局
【发布时间】:2016-05-11 11:01:26
【问题描述】:

我有一个带有导航视图的抽屉布局,其中填充了菜单项,我想在菜单项下方的抽屉底部包含一个图像,那里有空白但难以实现,我已经尝试过添加 imageview 但它把它放在抽屉后面而不是我希望的地方。我的另一个想法是使用像页眉这样的页脚,但这对我不起作用!谢谢

<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">

    <include
        layout="@layout/app_bar_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.NavigationView
        app:theme="@style/NavigationDrawerStyle"
        android:id="@+id/nav_view"
        android:layout_width="400dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:itemTextColor="#FFE300"
        app:headerLayout="@layout/nav_header_main"
        app:menu="@menu/activity_main_drawer"
        android:background="@drawable/side_nav_bar"/>


</android.support.v4.widget.DrawerLayout>

布局

<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <group android:checkableBehavior="single">
        <item
            android:id="@+id/first_one"
            android:icon="@drawable/ic_menu_book"
            android:title="To Begin" />

        <item
            android:id="@+id/second_one"
            android:icon="@drawable/nav"
            android:title="Continue" />

        <item
            android:id="@+id/more_stories"
            android:icon="@drawable/navtwo"
            android:title="More Stories" />


        <item
            android:id="@+id/nav_manage"
            android:icon="@drawable/rsz_win"
            android:title="Help" />

        <item
            android:id="@+id/newone"
            android:icon="@drawable/rsz_win"
            android:title="add something here" />
    </group>

    <item android:title="Communicate">

        <menu>
            <item
                android:id="@+id/nav_share"
                android:icon="@drawable/shareicon"
                android:title="Share"/>
            <item
                android:id="@+id/nav_send"
                android:icon="@drawable/send"
                android:title="Send" />
        </menu>
    </item>
</menu>

【问题讨论】:

标签: java android navigation-drawer android-xml navigationview


【解决方案1】:

试试这个

 <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:layout_gravity="start"
        >

    <android.support.design.widget.NavigationView
        android:id="@+id/nav_view"
        android:layout_width="400dp"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true"
        app:itemTextColor="#FFE300"
        app:menu="@menu/test_menu"
/>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/ic_launcher"/>
    </LinearLayout>

【讨论】:

  • 它是迄今为止最接近我所追求的东西,但并不完全在那里!除非我缩短抽屉,否则图像视图在抽屉外面并且无法正确显示
  • 好的,您可以为线性布局添加与具有高度匹配父级的导航视图相同的背景颜色,希望这会有所帮助
  • 我刚刚做了,效果很好,但是因为 imageview 不在抽屉里,菜单项下面还有空间!这会是一个快速解决方案吗?我认为重力不会对菜单项起作用,但会尝试
【解决方案2】:

2 个解决方案

1.在您的布局中添加您的 ImageView 作为 visibility = gone 并在需要时将其更改为可见。

见下文:

<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">

    <include
        layout="@layout/app_bar_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.NavigationView
        app:theme="@style/NavigationDrawerStyle"
        android:id="@+id/nav_view"
        android:layout_width="400dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:itemTextColor="#FFE300"
        app:headerLayout="@layout/nav_header_main"
        app:menu="@menu/activity_main_drawer"
        android:background="@drawable/side_nav_bar"/>


        <ImageView
            android:id="@+id/ivLogo"
            android:layout_width="100dp"
            android:layout_marginTop="30dp"
            android:visibility="gone"       
            android:layout_height="wrap_content"
            android:src="@drawable/YOUR_IMAGE" />


</android.support.v4.widget.DrawerLayout>

在您的 java 代码中:

Imageview ivLogo = (Imageview) findViewById(R.id.ivLogo);
ivLogo.setVisibility(View.VISIBLE);

2。从您的 java 代码中动态添加 ImageView。

 DrawerLayout drawer_layout = (DrawerLayout) findViewById(R.id.drawer_layout);

 Imageview ivLogo = new Imageview(this);
   // set your image, position, size...
 drawer_layout.addview(ivLogo); // add the view 

希望对你有帮助!

【讨论】:

  • 感谢您的帮助,第一步对我不起作用,因为它将图像放在导航抽屉后面而不是抽屉中!将尝试第二种方法
猜你喜欢
  • 1970-01-01
  • 2017-01-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多