web-dev-qa-db-ja.com

ナビゲーションドロワーを使用したJetpackナビゲーションでは、androidxの子フラグメントのmobile_navigation.xmlで指定された戻るボタンとタイトルが表示されません

私はAndroidxで作業しています、Androidナビゲーションドロワー付きのジェットパックナビゲーションは、mobile_navigation.xmlで指定された戻るボタンとタイトルを表示しません、nav_view.setupWithNavController(navController)で試したナビゲーションは機能しません、スタジオ未解決のシンボルが表示されます。プロジェクトに必要な依存関係を追加しました

Gradle.build:

apply plugin: 'com.Android.application'
apply plugin: 'kotlin-Android'
apply plugin: 'kotlin-kapt'
apply plugin: 'kotlin-Android-extensions'

Android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.qbitstream.salesmanagementsystem"
        minSdkVersion 19
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-Android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    def nav_version = "1.0.0-alpha04"
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation 'androidx.appcompat:appcompat:1.0.0-rc01'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.2'
    implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0-rc01'
    implementation 'androidx.legacy:legacy-support-v4:1.0.0-rc01'
    implementation 'com.google.Android.material:material:1.0.0-alpha1'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.1.0-alpha4'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.0-alpha4'
    implementation "Android.Arch.navigation:navigation-fragment:$nav_version" // use -ktx for Kotlin
    implementation "Android.Arch.navigation:navigation-ui:$nav_version" 
    def room_version = "2.0.0-rc01"
    implementation "androidx.room:room-runtime:$room_version"
    kapt "androidx.room:room-compiler:$room_version"
    implementation "androidx.room:room-rxjava2:$room_version"
    implementation "androidx.room:room-guava:$room_version"
    testImplementation "androidx.room:room-testing:$room_version"
    implementation "com.squareup.retrofit2:retrofit:2.3.0"
    implementation "com.squareup.retrofit2:adapter-rxjava2:2.3.0"
    implementation "com.squareup.retrofit2:converter-gson:2.3.0"
    implementation "io.reactivex.rxjava2:rxandroid:2.0.1"
    implementation 'org.jetbrains.anko:anko-common:0.9'

}

これは私のHomeActivityです:

import Android.os.Bundle
import androidx.appcompat.app.ActionBarDrawerToggle
import androidx.appcompat.app.AppCompatActivity
import androidx.core.view.GravityCompat
import androidx.navigation.fragment.NavHostFragment
import androidx.navigation.ui.NavigationUI
import kotlinx.Android.synthetic.main.activity_home.*
import kotlinx.Android.synthetic.main.app_bar_home.*

class HomeActivity : AppCompatActivity() {
private lateinit var  navController:NavController

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_home)
    setSupportActionBar(toolbar)
    val toggle = ActionBarDrawerToggle(this, drawer_layout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close)
    drawer_layout.addDrawerListener(toggle)
    toggle.syncState()
    val Host = supportFragmentManager.findFragmentById(R.id.m_fragment) as NavHostFragment? ?: return
    navController = Host.navController
    NavigationUI.setupWithNavController(nav_view,navController)

}
override fun onBackPressed() {
    if (drawer_layout.isDrawerOpen(GravityCompat.START)) {
        drawer_layout.closeDrawer(GravityCompat.START)
    } else {
        super.onBackPressed()
    }
}
override fun onSupportNavigateUp(): Boolean {
    return NavigationUI.navigateUp(drawer_layout, navController) || super.onSupportNavigateUp()
}

} drawer_menu.xml

<?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/homeFragment"
            Android:icon="@drawable/order"
            Android:title="Home" />
        <item
            Android:id="@+id/salesOrderFragment"
            Android:icon="@drawable/order"
            Android:title="Order" />
        <item
            Android:id="@+id/nav_gallery"
            Android:icon="@drawable/bill"
            Android:title="Bill Collection" />
        <item
            Android:id="@+id/nav_slideshow"
            Android:icon="@drawable/bill"
            Android:title="Sales History" />
        <item
            Android:id="@+id/logoutFragment"
            Android:icon="@drawable/order"
            Android:title="Logout" />
    </group>
</menu>

これはmobile_navigation.xmlです

<?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/main_nav"
    app:startDestination="@+id/homeFragment">

    <fragment
        Android:id="@+id/homeFragment"
        Android:name="com.qbitstream.salesmanagementsystem.ui.home.HomeFragment"
        Android:label="Home"
        tools:layout="@layout/fragment_home"/>
    <fragment
        Android:id="@+id/salesOrderFragment"
        Android:name="com.qbitstream.salesmanagementsystem.ui.order.SalesOrderFragment"
        Android:label="Order"
        tools:layout="@layout/fragment_sales_order" />
    <fragment
        Android:id="@+id/logoutFragment"
        Android:name="com.qbitstream.salesmanagementsystem.LogoutFragment"
        Android:label="fragment_logout"
        tools:layout="@layout/fragment_logout" />
</navigation>
7
Sabin ks

これらの両方の機能を使用する必要があります

NavigationUI.setupWithNavController (toolbar, navController, drawer_layout)
NavigationUI.setupWithNavController(nav_view,navController)
4
Sabin ks

NavigationUI.setupActionBarWithNavController() を使用する必要があります

  • AppCompatActivity.getSupportActionBar()によって返されるActionBarをNavControllerで使用するために設定します。

  • このメソッドを呼び出すことにより、宛先が変更されたときにアクションバーのタイトルが自動的に更新されます(有効なラベルがある場合)。

  • ルート以外の宛先にいる場合、actionBarはUpbuttonも表示します。 navigateUp(DrawerLayout, NavController) を呼び出して、上ボタンを処理します

サンプルコード

Kotlinの場合

_NavigationUI.setupActionBarWithNavController(this, navHost.navController)
_

Javaの場合

_NavigationUI.setupActionBarWithNavController(this, navController.getNavController());
_

[〜#〜]編集[〜#〜]

onSupportNavigateUp()メソッドをオーバーライドすることを忘れないでください

_fun onSupportNavigateUp(): Boolean {
   // return navHost.navController.navigateUp() || super.onSupportNavigateUp()
    return NavigationUI.navigateUp(drawer, navHost.navController) || super.onSupportNavigateUp()
}
_

編集2

ナビゲーションドロワーで使用するには NavigationUI.setupWithNavController() を使用する必要があります

  • このメソッドを呼び出すことにより、宛先が変更されたときにツールバーのタイトルが自動的に更新されます(有効なラベルがある場合)。

Kotlinの場合

_NavigationUI.setupWithNavController(toolbar, navController, drawer_layout)
_

Javaの場合

_NavigationUI.setupWithNavController(toolbar, navController.getNavController(),drawer_layout);
_
2
Nilesh Rathod