如何在 Kotlin 中滑动片段时选择 BottomNavigationView 中的项目
How to set items in BottomNavigationView selected when swiping fragments in Kotlin
对于 android 应用程序,我有一个 BottomNavigationView
包含三个项目和相应的片段。使用 ViewPager
我可以在这三个片段之间滑动。 (默认选择是我的 navigationItem2。)
我的问题是我的底部导航中的项目只能在点击时被选中,但不会在滑动时更改选择,而片段在滑动时会按预期更改。
那么我怎样才能实现在滑动时选择项目?
我的MainActivity.kt
class MainActivity : AppCompatActivity() {
private val mOnNavigationItemSelectedListener = BottomNavigationView.OnNavigationItemSelectedListener {item->
when(item.itemId){
R.id.navigationItem1 ->{
replaceFragment(Fragment1())
viewPager.currentItem = 0
return@OnNavigationItemSelectedListener true
}
R.id.navigationItem2 ->{
replaceFragment(Fragment2())
viewPager.currentItem = 1
return@OnNavigationItemSelectedListener true
}
R.id.navigationItem3 ->{
replaceFragment(Fragment3())
viewPager.currentItem = 2
return@OnNavigationItemSelectedListener true
} else -> viewPager.currentItem = 1
}
false
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val pageAdapter = FragmentPagerAdapter(supportFragmentManager)
viewPager.adapter = pageAdapter
bottomNavigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener)
bottomNavigation.selectedItemId = R.id.navigationItem2
我的activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:fitsSystemWindows="true"
android:background="?attr/backgroundcolor"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/fragmentContainer"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintBottom_toTopOf="@+id/bottomNavigation">
</FrameLayout>
</androidx.viewpager.widget.ViewPager>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigation"
app:menu="@menu/bottom_nav_menu"
android:background="@android:color/white"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintVertical_bias="1.0"
app:layout_constraintHorizontal_bias="1.0"/>
</androidx.constraintlayout.widget.ConstraintLayout>
我的FragmentPageAdapter.kt
class FragmentPagerAdapter (fragmentManager: FragmentManager): FragmentPagerAdapter(fragmentManager){
override fun getItem(position: Int): Fragment {
return when (position){
0 -> Fragment1.newInstance()
1 -> Fragment2.newInstance()
2 -> Fragment3.newInstance()
else -> Fragment2.newInstance()
}
}
override fun getCount() = 3
}
您可以使用 ViewPager 的 addOnPageChangeListener 和 onPageSelected 函数来设置当前项。
viewPager!!.addOnPageChangeListener(object : ViewPager.OnPageChangeListener {
override fun onPageScrolled(position: Int, positionOffset: Float, positionOffsetPixels: Int) {
//alerta("menu",position.toString())
}
override fun onPageSelected(position: Int) {
bottomNavigationView!!.getMenu().getItem(position).setChecked(true)
}
override fun onPageScrollStateChanged(state: Int) {
}
})
BottomNavigationView
不是 TabLayout
。
您必须在 ViewPager
.
中实现侦听器
mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
public void onPageScrollStateChanged(int state) {
}
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
public void onPageSelected(int position) {
navigation.getMenu().getItem(position).setChecked(true);
//Here your code
}
});
对于 android 应用程序,我有一个 BottomNavigationView
包含三个项目和相应的片段。使用 ViewPager
我可以在这三个片段之间滑动。 (默认选择是我的 navigationItem2。)
我的问题是我的底部导航中的项目只能在点击时被选中,但不会在滑动时更改选择,而片段在滑动时会按预期更改。
那么我怎样才能实现在滑动时选择项目?
我的MainActivity.kt
class MainActivity : AppCompatActivity() {
private val mOnNavigationItemSelectedListener = BottomNavigationView.OnNavigationItemSelectedListener {item->
when(item.itemId){
R.id.navigationItem1 ->{
replaceFragment(Fragment1())
viewPager.currentItem = 0
return@OnNavigationItemSelectedListener true
}
R.id.navigationItem2 ->{
replaceFragment(Fragment2())
viewPager.currentItem = 1
return@OnNavigationItemSelectedListener true
}
R.id.navigationItem3 ->{
replaceFragment(Fragment3())
viewPager.currentItem = 2
return@OnNavigationItemSelectedListener true
} else -> viewPager.currentItem = 1
}
false
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val pageAdapter = FragmentPagerAdapter(supportFragmentManager)
viewPager.adapter = pageAdapter
bottomNavigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener)
bottomNavigation.selectedItemId = R.id.navigationItem2
我的activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:fitsSystemWindows="true"
android:background="?attr/backgroundcolor"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewPager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/fragmentContainer"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintBottom_toTopOf="@+id/bottomNavigation">
</FrameLayout>
</androidx.viewpager.widget.ViewPager>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigation"
app:menu="@menu/bottom_nav_menu"
android:background="@android:color/white"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintVertical_bias="1.0"
app:layout_constraintHorizontal_bias="1.0"/>
</androidx.constraintlayout.widget.ConstraintLayout>
我的FragmentPageAdapter.kt
class FragmentPagerAdapter (fragmentManager: FragmentManager): FragmentPagerAdapter(fragmentManager){
override fun getItem(position: Int): Fragment {
return when (position){
0 -> Fragment1.newInstance()
1 -> Fragment2.newInstance()
2 -> Fragment3.newInstance()
else -> Fragment2.newInstance()
}
}
override fun getCount() = 3
}
您可以使用 ViewPager 的 addOnPageChangeListener 和 onPageSelected 函数来设置当前项。
viewPager!!.addOnPageChangeListener(object : ViewPager.OnPageChangeListener {
override fun onPageScrolled(position: Int, positionOffset: Float, positionOffsetPixels: Int) {
//alerta("menu",position.toString())
}
override fun onPageSelected(position: Int) {
bottomNavigationView!!.getMenu().getItem(position).setChecked(true)
}
override fun onPageScrollStateChanged(state: Int) {
}
})
BottomNavigationView
不是 TabLayout
。
您必须在 ViewPager
.
mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
public void onPageScrollStateChanged(int state) {
}
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
public void onPageSelected(int position) {
navigation.getMenu().getItem(position).setChecked(true);
//Here your code
}
});