工具栏按钮片段重叠
Toolbar button Fragment Overlapping
我正在使用导航抽屉模板。我还在工具栏中添加按钮。单击该按钮时,图库片段应打开。实际上它正在打开,但是当我也单击抽屉按钮时,它们重叠了。你有什么解决办法吗?
这是我的主要活动:
package com.example.shoptest
class MainActivity : AppCompatActivity() {
var manager = supportFragmentManager
private lateinit var appBarConfiguration: AppBarConfiguration
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val toolbar: Toolbar = findViewById(R.id.toolbar)
setSupportActionBar(toolbar)
toolbar.setTitle("selamalr")
val fab: FloatingActionButton = findViewById(R.id.fab)
fab.setOnClickListener { view ->
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
.setAction("Action", null).show()
}
val drawerLayout: DrawerLayout = findViewById(R.id.drawer_layout)
val navView: NavigationView = findViewById(R.id.nav_view)
val navController = findNavController(R.id.nav_host_fragment)
// Passing each menu ID as a set of Ids because each
// menu should be considered as top level destinations.
appBarConfiguration = AppBarConfiguration(
setOf(
R.id.nav_home, R.id.nav_gallery, R.id.nav_slideshow,
R.id.nav_tools, R.id.nav_share, R.id.nav_send
), drawerLayout
)
setupActionBarWithNavController(navController, appBarConfiguration)
navView.setupWithNavController(navController)
}
override fun onCreateOptionsMenu(menu: Menu): Boolean {
// Inflate the menu; this adds items to the action bar if it is present.
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onSupportNavigateUp(): Boolean {
val navController = findNavController(R.id.nav_host_fragment)
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
}
override fun onOptionsItemSelected(item: MenuItem): Boolean {
when (item.itemId) {
R.id.shop -> {
var galleryFragment = GalleryFragment()
var transaction = manager.beginTransaction()
transaction.replace(R.id.container, galleryFragment, "frag")
transaction.addToBackStack("frag")
transaction.commit()
}
}
return super.onOptionsItemSelected(item)
}
}
这是内容 main.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/container">
</FrameLayout>
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation">
</fragment>
</RelativeLayout>
这是我的屏幕:
你有什么解决办法吗?
您的 RelativeLayout
中有两个视图 FrameLayout
和 Fragment
。仅使用一个容器 <FrameLayout>
来处理所有片段事务。
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/container">
</FrameLayout>
您的代码需要如下所示 ->
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation"/>
</RelativeLayout>
因为在使用导航组件时,您只需要片段视图位于主视图组中。另一个视图只会通过重叠您的另一个视图而造成扭曲。所以只需将其删除。或者,如果你想那么你也可以试试这个 ->
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</RelativeLayout>
如果你想将片段视图转移到其他布局文件,可以使用上面的代码。然后你可以通过调用片段转换函数来替换片段来替换或添加片段。使用适合您的项目的任何东西。
好的。主要问题在于逻辑部分,需要进行一些 UI 更改。
首先进入您的 content_main.xml 文件并在其中进行此更改。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation" />
</androidx.constraintlayout.widget.ConstraintLayout>
然后进入你的 activity_main.xml 文件并添加这个
<?xml version="1.0" encoding="utf-8"?>
<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_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" />
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer" />
</androidx.drawerlayout.widget.DrawerLayout>
最后,主要对 MainActivity.kt 文件进行更改,就像这样 ->
package com.example.parcaburada
import android.os.Bundle
import com.google.android.material.floatingactionbutton.FloatingActionButton
import com.google.android.material.snackbar.Snackbar
import androidx.drawerlayout.widget.DrawerLayout
import com.google.android.material.navigation.NavigationView
import androidx.appcompat.app.AppCompatActivity
import androidx.appcompat.widget.Toolbar
import android.view.Menu
import android.view.MenuItem
import androidx.core.view.GravityCompat
import androidx.navigation.NavController
import androidx.navigation.Navigation
import androidx.navigation.ui.*
class MainActivity : AppCompatActivity(), NavigationView.OnNavigationItemSelectedListener {
private lateinit var mToolbar: Toolbar
private lateinit var mDrawerLayout: DrawerLayout
private lateinit var mNavController: NavController
private lateinit var mNavigationView: NavigationView
private lateinit var mFloatingActionButton: FloatingActionButton
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
setUpNavigation()
}
private fun setUpNavigation() {
//Toolbar
mToolbar = findViewById(R.id.toolbar)
setSupportActionBar(mToolbar)
supportActionBar?.setDisplayHomeAsUpEnabled(true)
supportActionBar?.setDisplayShowHomeEnabled(true)
//Toolbar
//Navigation Drawer
mDrawerLayout = findViewById(R.id.drawer_layout)
mNavigationView = findViewById(R.id.nav_view)
mNavController = Navigation.findNavController(this@MainActivity, R.id.nav_host_fragment)
NavigationUI.setupActionBarWithNavController(this@MainActivity, mNavController, mDrawerLayout)
NavigationUI.setupWithNavController(mNavigationView, mNavController)
mNavigationView.setNavigationItemSelectedListener(this)
//Navigation Drawer
//Floating Action button
mFloatingActionButton = findViewById(R.id.fab)
mFloatingActionButton.setOnClickListener { view ->
Snackbar.make(view, getString(R.string.text_fab_action), Snackbar.LENGTH_LONG)
.setAction(getString(R.string.text_action), null).show()
}
//Floating Action button
}
//Transition between fragments controller
override fun onSupportNavigateUp(): Boolean {
return NavigationUI.navigateUp(mNavController, mDrawerLayout)
}
//Navigation Drawer Controller
override fun onNavigationItemSelected(menuItem: MenuItem): Boolean {
menuItem.isChecked = true
mDrawerLayout.closeDrawers()
when (menuItem.itemId) {
R.id.nav_home -> navigateToFragment(R.id.nav_home)
R.id.nav_gallery -> navigateToFragment(R.id.nav_gallery)
R.id.nav_slideshow -> navigateToFragment(R.id.nav_slideshow)
R.id.nav_tools -> navigateToFragment(R.id.nav_tools)
R.id.nav_share -> navigateToFragment(R.id.nav_share)
R.id.nav_send -> navigateToFragment(R.id.nav_send)
}
return true
}
//Back button
override fun onBackPressed() {
if (mDrawerLayout.isDrawerOpen(GravityCompat.START)) {
mDrawerLayout.closeDrawer(GravityCompat.END)
} else {
super.onBackPressed()
}
}
//Toolbar icon controller
override fun onCreateOptionsMenu(menu: Menu): Boolean {
// Inflate the menu; this adds items to the action bar if it is present.
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onOptionsItemSelected(item: MenuItem): Boolean {
when (item.itemId) {
R.id.shop -> navigateToFragment(R.id.nav_gallery)
}
return super.onOptionsItemSelected(item)
}
//Toolbar icon controller
//Custom method to navigate to fragments
private fun navigateToFragment(fragmentName: Int): Boolean {
mNavController.navigate(fragmentName)
return true
}
}
完成了。一切都会顺利运行。谢谢。
我正在使用导航抽屉模板。我还在工具栏中添加按钮。单击该按钮时,图库片段应打开。实际上它正在打开,但是当我也单击抽屉按钮时,它们重叠了。你有什么解决办法吗?
这是我的主要活动:
package com.example.shoptest
class MainActivity : AppCompatActivity() {
var manager = supportFragmentManager
private lateinit var appBarConfiguration: AppBarConfiguration
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val toolbar: Toolbar = findViewById(R.id.toolbar)
setSupportActionBar(toolbar)
toolbar.setTitle("selamalr")
val fab: FloatingActionButton = findViewById(R.id.fab)
fab.setOnClickListener { view ->
Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
.setAction("Action", null).show()
}
val drawerLayout: DrawerLayout = findViewById(R.id.drawer_layout)
val navView: NavigationView = findViewById(R.id.nav_view)
val navController = findNavController(R.id.nav_host_fragment)
// Passing each menu ID as a set of Ids because each
// menu should be considered as top level destinations.
appBarConfiguration = AppBarConfiguration(
setOf(
R.id.nav_home, R.id.nav_gallery, R.id.nav_slideshow,
R.id.nav_tools, R.id.nav_share, R.id.nav_send
), drawerLayout
)
setupActionBarWithNavController(navController, appBarConfiguration)
navView.setupWithNavController(navController)
}
override fun onCreateOptionsMenu(menu: Menu): Boolean {
// Inflate the menu; this adds items to the action bar if it is present.
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onSupportNavigateUp(): Boolean {
val navController = findNavController(R.id.nav_host_fragment)
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
}
override fun onOptionsItemSelected(item: MenuItem): Boolean {
when (item.itemId) {
R.id.shop -> {
var galleryFragment = GalleryFragment()
var transaction = manager.beginTransaction()
transaction.replace(R.id.container, galleryFragment, "frag")
transaction.addToBackStack("frag")
transaction.commit()
}
}
return super.onOptionsItemSelected(item)
}
}
这是内容 main.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/container">
</FrameLayout>
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation">
</fragment>
</RelativeLayout>
这是我的屏幕:
你有什么解决办法吗?
您的 RelativeLayout
中有两个视图 FrameLayout
和 Fragment
。仅使用一个容器 <FrameLayout>
来处理所有片段事务。
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/container">
</FrameLayout>
您的代码需要如下所示 ->
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation"/>
</RelativeLayout>
因为在使用导航组件时,您只需要片段视图位于主视图组中。另一个视图只会通过重叠您的另一个视图而造成扭曲。所以只需将其删除。或者,如果你想那么你也可以试试这个 ->
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</RelativeLayout>
如果你想将片段视图转移到其他布局文件,可以使用上面的代码。然后你可以通过调用片段转换函数来替换片段来替换或添加片段。使用适合您的项目的任何东西。
好的。主要问题在于逻辑部分,需要进行一些 UI 更改。 首先进入您的 content_main.xml 文件并在其中进行此更改。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/app_bar_main">
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/mobile_navigation" />
</androidx.constraintlayout.widget.ConstraintLayout>
然后进入你的 activity_main.xml 文件并添加这个
<?xml version="1.0" encoding="utf-8"?>
<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_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" />
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer" />
</androidx.drawerlayout.widget.DrawerLayout>
最后,主要对 MainActivity.kt 文件进行更改,就像这样 ->
package com.example.parcaburada
import android.os.Bundle
import com.google.android.material.floatingactionbutton.FloatingActionButton
import com.google.android.material.snackbar.Snackbar
import androidx.drawerlayout.widget.DrawerLayout
import com.google.android.material.navigation.NavigationView
import androidx.appcompat.app.AppCompatActivity
import androidx.appcompat.widget.Toolbar
import android.view.Menu
import android.view.MenuItem
import androidx.core.view.GravityCompat
import androidx.navigation.NavController
import androidx.navigation.Navigation
import androidx.navigation.ui.*
class MainActivity : AppCompatActivity(), NavigationView.OnNavigationItemSelectedListener {
private lateinit var mToolbar: Toolbar
private lateinit var mDrawerLayout: DrawerLayout
private lateinit var mNavController: NavController
private lateinit var mNavigationView: NavigationView
private lateinit var mFloatingActionButton: FloatingActionButton
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
setUpNavigation()
}
private fun setUpNavigation() {
//Toolbar
mToolbar = findViewById(R.id.toolbar)
setSupportActionBar(mToolbar)
supportActionBar?.setDisplayHomeAsUpEnabled(true)
supportActionBar?.setDisplayShowHomeEnabled(true)
//Toolbar
//Navigation Drawer
mDrawerLayout = findViewById(R.id.drawer_layout)
mNavigationView = findViewById(R.id.nav_view)
mNavController = Navigation.findNavController(this@MainActivity, R.id.nav_host_fragment)
NavigationUI.setupActionBarWithNavController(this@MainActivity, mNavController, mDrawerLayout)
NavigationUI.setupWithNavController(mNavigationView, mNavController)
mNavigationView.setNavigationItemSelectedListener(this)
//Navigation Drawer
//Floating Action button
mFloatingActionButton = findViewById(R.id.fab)
mFloatingActionButton.setOnClickListener { view ->
Snackbar.make(view, getString(R.string.text_fab_action), Snackbar.LENGTH_LONG)
.setAction(getString(R.string.text_action), null).show()
}
//Floating Action button
}
//Transition between fragments controller
override fun onSupportNavigateUp(): Boolean {
return NavigationUI.navigateUp(mNavController, mDrawerLayout)
}
//Navigation Drawer Controller
override fun onNavigationItemSelected(menuItem: MenuItem): Boolean {
menuItem.isChecked = true
mDrawerLayout.closeDrawers()
when (menuItem.itemId) {
R.id.nav_home -> navigateToFragment(R.id.nav_home)
R.id.nav_gallery -> navigateToFragment(R.id.nav_gallery)
R.id.nav_slideshow -> navigateToFragment(R.id.nav_slideshow)
R.id.nav_tools -> navigateToFragment(R.id.nav_tools)
R.id.nav_share -> navigateToFragment(R.id.nav_share)
R.id.nav_send -> navigateToFragment(R.id.nav_send)
}
return true
}
//Back button
override fun onBackPressed() {
if (mDrawerLayout.isDrawerOpen(GravityCompat.START)) {
mDrawerLayout.closeDrawer(GravityCompat.END)
} else {
super.onBackPressed()
}
}
//Toolbar icon controller
override fun onCreateOptionsMenu(menu: Menu): Boolean {
// Inflate the menu; this adds items to the action bar if it is present.
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onOptionsItemSelected(item: MenuItem): Boolean {
when (item.itemId) {
R.id.shop -> navigateToFragment(R.id.nav_gallery)
}
return super.onOptionsItemSelected(item)
}
//Toolbar icon controller
//Custom method to navigate to fragments
private fun navigateToFragment(fragmentName: Int): Boolean {
mNavController.navigate(fragmentName)
return true
}
}
完成了。一切都会顺利运行。谢谢。