通过在navigationView中按id重新加载navigationView内容

时间:2019-10-13 12:20:38

标签: java navigationview

我目前正在开发一个应用,该应用中我想通过按下同一navigationView标头中的图片来更改navigationView的下部。

我的navigationView带有标头布局和下部的另一个布局。 标头包含一些图片。每个图片的下半部都应采用不同的布局。

我准备了几个不同的菜单,分别对应不同的类别。每个菜单都以不同的布局集成在一起,具有唯一的ID。

目前,navigationView打开时会显示首页类别,但我不知道如何按图片来重新加载下部。

这是mainActivity中onCreate

中代码的一部分
        //ACTIONBAR
    Toolbar mToolbar = findViewById(R.id.toolbar);
    setSupportActionBar(mToolbar);
    assert getSupportActionBar() != null;
    getSupportActionBar().setTitle("");

    //NAVIGATION VIEW
    DrawerLayout drawer = findViewById(R.id.drawer_layout);
    NavigationView navigationView = findViewById(R.id.nav_view_home);
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, mToolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
    drawer.addDrawerListener(toggle);
    toggle.syncState();
    navigationView.setNavigationItemSelectedListener(this);

看到,nav_view_home ID已加载,并且通过按此navigationView标题中的图片,我希望看到下部发生变化。现在,我准备了使用相同标题制作的不同的navigationView: -nav_view_movie -nav_view_music -...

家庭抽屉布局的代码

<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/activity_soundsorganisation"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.NavigationView
        android:id="@+id/nav_view_home"
        android:layout_width="250dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:theme="@style/NavigationTheme"
        android:fitsSystemWindows="true"
        android:background="#6b6b6b"
        app:headerLayout="@layout/format_soundsorganisationdrawerheader"
        app:menu="@menu/categorie_menu"
        app:itemTextColor="@drawable/nav_view_item_textcolor"
        app:itemBackground="@drawable/nav_view_item_background" >

    <include layout="@layout/format_soundsorganisationdrawerheader" />

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

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

电影抽屉布局的代码

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

<android.support.design.widget.NavigationView
    android:id="@+id/nav_view_home"
    android:layout_width="250dp"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:theme="@style/NavigationTheme"
    android:fitsSystemWindows="true"
    android:background="#6b6b6b"
    app:headerLayout="@layout/format_soundsorganisationdrawerheader"
    app:menu="@menu/categorie_menu"
    app:itemTextColor="@drawable/nav_view_item_textcolor"
    app:itemBackground="@drawable/nav_view_item_background" >

<include layout="@layout/format_soundsorganisationdrawerheader" />

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

navigationView布局的标题代码

    <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#303030"
    android:gravity="center"
    android:orientation="horizontal"
    android:theme="@style/ThemeOverlay.AppCompat.Dark">

    <ImageView
        android:id="@+id/imageView_pic_movie"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:contentDescription="@string/nav_header_desc"
        android:paddingEnd="10dp"
        android:paddingStart="10dp"
        app:srcCompat="@drawable/pic_movie" />

    <ImageView
        android:id="@+id/imageView_pic_audio"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:contentDescription="@string/nav_header_desc"
        android:paddingEnd="10dp"
        android:paddingStart="10dp"
        app:srcCompat="@drawable/pic_audio" />
</LinearLayout>

因此,如您所见,主页布局由标头和categorie_menu组成。目前,我尝试使用具有相同标题的另一个布局和另一个名为imageView_pic_movie的菜单,但没有成功时,按下具有categorie_menu_movie id的图片时重新加载完整的布局。

也许这是不可能的,或者这也不是最好的方法?也许还有另一种使用相同布局的方法,只是重新加载菜单而不是全部布局?

无论如何,我不明白我该怎么做。

能帮我吗?

1 个答案:

答案 0 :(得分:0)

好的,所以我的做法似乎是个糟糕的主意。经过研究,似乎可以为菜单中的项目或组使用可见的true或false。

因此,仅需执行onClick方法并在单击图片或其他图片时将组设置为可见或不可见。

来源:Change NavigationView items when user is logged