DrawerLayout 重叠片段

Posted

技术标签:

【中文标题】DrawerLayout 重叠片段【英文标题】:drawerLayout overlapping fragments 【发布时间】:2020-11-23 03:42:58 【问题描述】:

这个问题我已经有一段时间了

我相信这是因为 DrawerLayout 的实现不正确,即使我遵循开发者网站来实现它。

我有一个活动,现在有 3 个框架,mangaSearch(mS)(recyclerView)、配置文件、设置 mS 是起始片段,当我进入抽屉菜单并选择配置文件或设置时,片段将绘制在 mS 片段上方。当我按预期回击时,mS 片段再次显示正常。

我在 google/stack 上环顾四周,但没有找到解决此问题的方法,因此我在这里寻求帮助。

更新 我的抽屉里有错误的 ID,我不得不将它们更改为导航 nav_graph 布局中的 ID。

主活动

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.view.GravityCompat;
import androidx.drawerlayout.widget.DrawerLayout;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentManager;
import androidx.navigation.NavController;
import androidx.navigation.Navigation;
import androidx.navigation.ui.AppBarConfiguration;
import androidx.navigation.ui.NavigationUI;

import android.os.Bundle;
import android.view.MenuItem;
import android.widget.Toast;

import com.google.android.material.navigation.NavigationView;

import Classes.LoggedInUser;

public class MainActivity extends AppCompatActivity 

    private DrawerLayout drawer;
    private AppBarConfiguration appBarConfig;

    public static LoggedInUser loggedInUser;
    FragmentManager fm;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        loggedInUser = LoggedInUser.getInstance();
        fm = getSupportFragmentManager();

        androidx.appcompat.widget.Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        drawer = findViewById(R.id.drawer_layout);

        appBarConfig = new AppBarConfiguration.Builder(R.id.nav_graph_manga_book_details,
                R.id.nav_graph_mangas_search_souce, R.id.nav_graph_profile,
                R.id.nav_graph_settings).setDrawerLayout(drawer).build();

        NavController navController = Navigation.findNavController(this, R.id.main_content);

        NavigationView navigationView = findViewById(R.id.nav_view);
        NavigationUI.setupActionBarWithNavController(this, navController, appBarConfig);
        //NavigationUI.setupWithNavController(navigationView, navController);


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

        NavigationUI.setupActionBarWithNavController(this, navController, drawerL);
        NavigationUI.setupWithNavController(navigationView, navController);
        navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() 


                                                             @Override
                                                             public boolean onNavigationItemSelected(@NonNull MenuItem item) 
                                                                 int id = item.getItemId();
                                                                 switch (id) 
                                                                     case R.id.nav_manga_books_source:
                                                                         fm.beginTransaction().replace(R.id.main_content, new MangasSearchFragment(), "mangaBookSource").commit();
                                                                         break;
                                                                     case R.id.nav_user_profile:
                                                                         //check if person is logged in?
                                                                         fm.beginTransaction().replace(R.id.main_content, new ProfileFragment(), "profile").commit();
                                                                         break;

                                                                     case R.id.nav_settings:
                                                                         fm.beginTransaction().replace(R.id.main_content, new SettingsFragment(), "settings").commit();
                                                                         break;
                                                                     case R.id.nav_settings_temp:
                                                                         Toast.makeText(MainActivity.this, "Settings Temp works", Toast.LENGTH_SHORT).show();
                                                                         break;

                                                                 
                                                                 drawer.closeDrawer(GravityCompat.START);
                                                                 return true;

                                                             
                                                         );

    

    @Override
    public boolean onSupportNavigateUp() 
            NavController navController = Navigation.findNavController(this, R.id.main_content);
            return NavigationUI.navigateUp(navController, appBarConfig) || super.onSupportNavigateUp();

    

    @Override
    public void onBackPressed() 
        if (drawer.isDrawerOpen(GravityCompat.START)) 
            drawer.closeDrawer(GravityCompat.START);
        
       else 
            super.onBackPressed();
        
    


布局文件

<androidx.drawerlayout.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_
android:layout_
android:fitsSystemWindows="true"
android:orientation="vertical"
tools:openDrawer="start">

<LinearLayout
    android:layout_
    android:layout_
    android:orientation="vertical">

    <androidx.appcompat.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_
        android:layout_
        android:background="@color/colorPrimary"
        android:elevation="4dp"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

    <FrameLayout
        android:id="@+id/fragment_container"
        android:layout_
        android:layout_ >

        <fragment
            android:id="@+id/main_content"
            android:name="androidx.navigation.fragment.NavHostFragment"
            app:navGraph="@navigation/navigation_graph"
            app:defaultNavHost="true"
            android:layout_
            android:layout_ />



    </FrameLayout>

</LinearLayout>

<com.google.android.material.navigation.NavigationView
    android:id="@+id/nav_view"
    android:layout_
    android:layout_
    android:layout_gravity="start"
    app:headerLayout="@layout/nav_header"
    app:menu="@menu/drawer_menu" />




</androidx.drawerlayout.widget.DrawerLayout>

布局drawer_menu

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    tools:showIn="navigation_view">
    <group android:checkableBehavior="single">

        <item
            android:id="@+id/nav_user_profile"
            android:icon="@drawable/ic_user_profile"
            android:title="Profile" />

        <item
            android:id="@+id/nav_manga_books_source"
            android:icon="@drawable/ic_manga_books_of_source"
            android:title="Manga's"/>

        <item
            android:id="@+id/nav_settings"
            android:icon="@drawable/ic_settings"
            android:title="Settings"/>
    </group>
    <item android:title="new group">
        <menu>
            <item
                android:id="@+id/nav_settings_temp"
                android:icon="@drawable/ic_settings"
                android:title="Settings temp" />
        </menu>
    </item>

</menu>

后来有人推荐的添加导航组件。问题已经存在,但这并没有解决它,因为它不是作为修复的,但它可能与 mainActivity 代码相关

<?xml version="1.0" encoding="utf-8"?>
<navigation 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/mobile_navigation"
    app:startDestination="@+id/nav_graph_mangas_search_souce">

    <fragment
        android:id="@+id/nav_graph_mangas_search_souce"
        android:name="com.example.what2watchmangareader.MangasSearchFragment"
        android:label="start fragment"
        tools:layout="@layout/fragment_mangas_to_search" />

    <fragment
        android:id="@+id/nav_graph_profile"
        android:name="com.example.what2watchmangareader.ProfileFragment"
        android:label="profile page"
        tools:layout="@layout/fragment_profile" />


    <fragment
        android:id="@+id/nav_graph_settings"
        android:name="com.example.what2watchmangareader.SettingsFragment"
        android:label="Settings Page"
        tools:layout="@layout/fragment_settings" />

    <fragment
        android:id="@+id/nav_graph_manga_book_details"
        android:name="com.example.what2watchmangareader.MangaBookFragment"
        android:label="Manga detail"
        tools:layout="@layout/fragment_manga_book_info" />

    //Add your other fragments here.
</navigation>

【问题讨论】:

当您使用 NavHostFragment 时,您不应该执行任何 FragmentTransactions(您也根本不需要 setNavigationItemSelectedListener 调用)。当您完全删除该代码时会发生什么? 这将阻止我访问抽屉菜单中选择的片段,因此抽屉菜单保持打开状态,点击菜单(设置/mS/profile)没有任何反应 您的菜单项android:id 是否与导航图中的the documentation 中的项匹配?看起来他们不匹配。 我把drawer_menu里的改成nav_grap导航里的,现在不需要setOnClickListener了,谢谢指点:) 【参考方案1】:

根据documentation,您不需要运行任何FragmentTransactions,也不需要在使用setupWithNavController() 时手动实现OnNavigationItemSelectedListener。相反,您只需在导航图和菜单项之间匹配android:id

【讨论】:

以上是关于DrawerLayout 重叠片段的主要内容,如果未能解决你的问题,请参考以下文章

DrawerLayout 的项目点击 - 啥时候更换片段合适?

Android:在drawerlayout中使用地图膨胀片段时出错

如何在导航控件片段中关闭导航 DrawerLayout onBackPressed

片段中的视频视图与另一个片段重叠

Android在drawerlayout的listview底部添加textview

片段与另一个片段重叠