开发环境:
data:image/s3,"s3://crabby-images/26227/26227ec8763f699d4b9729b607a2e71600ea0832" alt=""
效果图:
《《《代码在底部》》》
1,新建项目
data:image/s3,"s3://crabby-images/be938/be938a924611a433b50b3bca71d13ebf572d220d" alt=""
data:image/s3,"s3://crabby-images/d99a3/d99a30278e15481778d2d8b56cf80b1e69cbb1b0" alt=""
2,新建若干Fragment,内容一样,改一下显示出来的Text,名字分别为test1Fragment,test2Fragment,test3Fragment,默认TextView的Text属性分别设置为Fragment1内容,Fragment2内容,Fragment3内容,以示区分
data:image/s3,"s3://crabby-images/0cef7/0cef70acbecc84a073ce3d9f5cf4f0fc47844f10" alt=""
data:image/s3,"s3://crabby-images/7a09d/7a09d7e5ce7e47e730a316c1a168cbcc52467f26" alt=""
data:image/s3,"s3://crabby-images/2a577/2a5778ea80cfebde5050f4885afd925333d1680d" alt=""
3,拖拽一个FrameLayout
data:image/s3,"s3://crabby-images/aee8e/aee8eb912a5bc876d5daaf2c6b7187203ad065d5" alt=""
4,拖拽一个BottomNavigationView
data:image/s3,"s3://crabby-images/42ac1/42ac1e8ec9bcc74ef7c343ccd3081796f0c1a684" alt=""
5,调整代码
data:image/s3,"s3://crabby-images/c8f77/c8f774989945f1aa613cfcf94e2bdf370a0ca076" alt=""
6,新建一个菜单资源给BottomNavigationView使用
data:image/s3,"s3://crabby-images/55078/55078801829e57dd9a7adae1e4d5b3913262a3a4" alt=""
data:image/s3,"s3://crabby-images/ea585/ea58539659c4e039add4d287e42bd422908c63c6" alt=""
data:image/s3,"s3://crabby-images/819d6/819d6dbc072f722af18d14ff4806492ff2912efa" alt=""
7,BottomNavigationView和新建的菜单项关联
data:image/s3,"s3://crabby-images/30932/3093229dcf4f7b1d8b81f0aa57d888d26450dd87" alt=""
8,进一步调整代码
data:image/s3,"s3://crabby-images/05cbc/05cbc73dd7b12e7d57705ed8df0dac5d469c24f1" alt=""
9,MainActivity中的代码
data:image/s3,"s3://crabby-images/d7b21/d7b212fe7aba7abfb330cda5d9b0c7ffd7453c2e" alt=""
10,红色部分导入类即可解决
data:image/s3,"s3://crabby-images/eac4d/eac4d1b20f65ca1bc8a5c1c3183d35279538f6c7" alt=""
代码如下:
1,nav_menu.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/navigation_home"
android:icon="@android:drawable/ic_dialog_map"
android:title="Frame1" />
<item
android:id="@+id/navigation_tools"
android:icon="@android:drawable/ic_menu_compass"
android:title="Frame2" />
<item
android:id="@+id/navigation_play"
android:icon="@android:drawable/ic_menu_gallery"
android:title="Frame3" />
</menu>
2,activity_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"
tools:context=".MainActivity"
tools:ignore="ExtraText">
<FrameLayout
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@id/nav_menu"/>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/nav_menu"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
app:menu="@menu/nav_menu"
tools:layout_height="50dp" />
</RelativeLayout>
3,fragment_test1.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".test1Fragment">
<!-- TODO: Update blank fragment layout -->
<TextView
android:id="@+id/text1Fragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:text="Fragment1内容" />
</FrameLayout>
4,MainActivity.java
package com.example.bottomnavigationviewstudy;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.Fragment;
import android.os.Bundle;
import android.view.MenuItem;
import com.google.android.material.bottomnavigation.BottomNavigationView;
import com.google.android.material.navigation.NavigationBarView;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
ArrayList<Fragment> mFragments = new ArrayList<Fragment>();
test1Fragment t1f = new test1Fragment();
test2Fragment t2f = new test2Fragment();
test3Fragment t3f = new test3Fragment();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
BottomNavigationView navView = findViewById(R.id.nav_menu);
mFragments.add(t1f);
mFragments.add(t2f);
mFragments.add(t3f);
//设置默认加载视图
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new test1Fragment()).commit();
// navView 点击事件
navView.setOnItemSelectedListener(new NavigationBarView.OnItemSelectedListener() {
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
String a = (String) item.getTitle();
//判断是哪个item被点击了
switch (a) {
case "Frame2":
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new test2Fragment()).commit();
break;
case "Frame3":
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new test3Fragment()).commit();
break;
default:
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, new test1Fragment()).commit();
break;
}
item.setChecked(true);
return true;
}
});
}
}