Android底部导航栏实现(1)

//将四个的Fragment隐藏

private void hideFragments(FragmentTransaction transaction) {

if (mFrag1 != null) {

transaction.hide(mFrag1);

}

if (mFrag2 != null) {

transaction.hide(mFrag2);

}

if (mFrag3 != null) {

transaction.hide(mFrag3);

}

if (mFrag4 != null) {

transaction.hide(mFrag4);

}

}

在本例子中,就是使用FragmentManager来管理多个Fragment,通过show()方法显示当前所在的Fragment页面,hide方法将其他页面隐藏。

Fragment实现底部导航栏代码实现


MainActivity.class :核心Activity

ass MainActivity extends FragmentActivity implements OnClickListener {

//声明四个Tab的布局文件

private LinearLayout mTab1;

private LinearLayout mTab2;

private LinearLayout mTab3;

private LinearLayout mTab4;

//声明四个Tab的ImageButton

private ImageButton mImg1;

private ImageButton mImg2;

private ImageButton mImg3;

private ImageButton mImg4;

//声明四个Tab分别对应的Fragment

private Fragment mFrag1;

private Fragment mFrag2;

private Fragment mFrag3;

private Fragment mFrag4;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(R.layout.activity_main);

initViews();//初始化控件

initEvents();//初始化事件

selectTab(0);//默认选中第一个Tab

}

private void initEvents() {

//初始化四个Tab的点击事件

mTab1.setOnClickListener(this);

mTab2.setOnClickListener(this);

mTab3.setOnClickListener(this);

mTab4.setOnClickListener(this);

}

private void initViews() {

//初始化四个Tab的布局文件

mTab1 = (LinearLayout) findViewById(R.id.id_tab1);

mTab2 = (LinearLayout) findViewById(R.id.id_tab2);

mTab3 = (LinearLayout) findViewById(R.id.id_tab3);

mTab4 = (LinearLayout) findViewById(R.id.id_tab4);

//初始化四个ImageButton

mImg1 = (ImageButton) findViewById(R.id.id_tab_img1);

mImg2 = (ImageButton) findViewById(R.id.id_tab_img2);

mImg3 = (ImageButton) findViewById(R.id.id_tab_img3);

mImg4 = (ImageButton) findViewById(R.id.id_tab_img4);

}

//处理Tab的点击事件

@Override

public void onClick(View v) {

resetImgs(); //先将四个ImageButton置为灰色

switch (v.getId()) {

case R.id.id_tab1:

selectTab(0);

break;

case R.id.id_tab2:

selectTab(1);

break;

case R.id.id_tab3:

selectTab(2);

break;

case R.id.id_tab4:

selectTab(3);

break;

}

}

//进行选中Tab的处理

private void selectTab(int i) {

//获取FragmentManager对象

FragmentManager manager = getSupportFragmentManager();

//获取FragmentTransaction对象

FragmentTransaction transaction = manager.beginTransaction();

//先隐藏所有的Fragment

hideFragments(transaction);

switch (i) {

//当选中点击的是第一页的Tab时

case 0:

//设置第一页的ImageButton为绿色

mImg1.setImageResource(R.mipmap.icon1);

//如果第一页对应的Fragment没有实例化,则进行实例化,并显示出来

if (mFrag1 == null) {

mFrag1 = new Fragment();

transaction.add(R.id.id_content, mFrag1);

} else {

//如果第一页对应的Fragment已经实例化,则直接显示出来

transaction.show(mFrag1);

}

break;

case 1:

mImg2.setImageResource(R.mipmap.icon1);

if (mFrag2 == null) {

mFrag2 = new pageFragment2();

transaction.add(R.id.id_content, mFrag2);

} else {

transaction.show(mFrag2);

}

break;

case 2:

mImg3.setImageResource(R.mipmap.icon1);

if (mFrag3 == null) {

mFrag3 = new pageFragment3();

transaction.add(R.id.id_content, mFrag3);

} else {

transaction.show(mFrag3);

}

break;

case 3:

mImg4.setImageResource(R.mipmap.icon1);

if (mFrag4 == null) {

mFrag4 = new Fragment();

transaction.add(R.id.id_content, mFrag4);

} else {

transaction.show(mFrag4);

}

break;

}

//不要忘记提交事务

transaction.commit();

}

//将四个的Fragment隐藏

private void hideFragments(FragmentTransaction transaction) {

if (mFrag1 != null) {

transaction.hide(mFrag1);

}

if (mFrag2 != null) {

transaction.hide(mFrag2);

}

if (mFrag3 != null) {

transaction.hide(mFrag3);

}

if (mFrag4 != null) {

transaction.hide(mFrag4);

}

}

//将四个ImageButton置为灰色

private void resetImgs() {

mImg1.setImageResource(R.mipmap.icon2);

mImg2.setImageResource(R.mipmap.icon2);

mImg3.setImageResource(R.mipmap.icon2);

mImg4.setImageResource(R.mipmap.icon2);

}

}

底部按钮颜色变化是使用两形状一样张颜色不一样图片来回切换实现的。将当前显示的页面对应按钮设置成绿色图片。其他设置成灰色。

在这里插入图片描述

四个页面对应的Fragment

pageFragment1,pageFragment2,pageFragment3.class ,pageFragment4.class

lic class pageFragment1 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.tab1, container, false);

return view;

}

}

class pageFragment2 extends Fragment {

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.tab2, container, false);

TextView txt = (TextView) view.findViewById(R.id.txt2);

txt.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

Log.d(“dd”,“dddd”);

Toast.makeText(getActivity(), “当前页面:2”, Toast.LENGTH_SHORT).show();

}

});

return view;

}

}

public class pageFragment3 extends Fragment {

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.tab3, container, false);

return view;

}

}

public class pageFragment4 extends Fragment {

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.tab4, container, false);

return view;

}

}

布局文件:

activity_main.xml

<LinearLayout

xmlns:android=“http://schemas.android.com/apk/res/android”

android:orientation=“vertical”

android:layout_width=“match_parent”

android:layout_height=“match_parent”>

<FrameLayout

android:id=“@+id/id_content”

android:layout_width=“match_parent”

android:layout_height=“0dp”

android:layout_weight=“1”>

底部导航栏布局:

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

android:layout_width=“match_parent”

android:layout_height=“55dp”

android:gravity=“center”

android:orientation=“horizontal”>

<LinearLayout

android:layout_width=“0dp”

android:layout_height=“wrap_content”

android:layout_weight=“1”

android:id=“@+id/id_tab1”

android:gravity=“center”

android:orientation=“vertical”>

<ImageButton

android:id=“@+id/id_tab_img1”

android:clickable=“false”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:src=“@mipmap/icon1”

android:background=“#00000000”/>

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:textColor=“#A6A6A6”

android:text=“页面1”/>

<LinearLayout

android:id=“@+id/id_tab2”

android:layout_width=“0dp”

android:layout_height=“wrap_content”

android:layout_weight=“1”

android:gravity=“center”

android:orientation=“vertical”>

<ImageButton

android:id=“@+id/id_tab_img2”

android:clickable=“false”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:src=“@mipmap/icon2”

android:background=“#00000000”/>

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:textColor=“#A6A6A6”

android:text=“页面2”/>

<LinearLayout

android:id=“@+id/id_tab3”

android:layout_width=“0dp”

android:layout_height=“wrap_content”

android:layout_weight=“1”

android:gravity=“center”

android:orientation=“vertical”>

<ImageButton

android:id=“@+id/id_tab_img3”

android:clickable=“false”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:src=“@mipmap/icon2”

android:background=“#00000000”/>

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:textColor=“#A6A6A6”

android:text=“页面3”/>

<LinearLayout

android:id=“@+id/id_tab4”

android:layout_width=“0dp”

android:layout_height=“wrap_content”

android:layout_weight=“1”

android:gravity=“center”

android:orientation=“vertical”>

<ImageButton

android:id=“@+id/id_tab_img4”

android:clickable=“false”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:src=“@mipmap/icon2”

android:background=“#00000000”/>

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:textColor=“#A6A6A6”

android:text=“页面4”/>

Fragment对应布局

四个都一样:

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

android:orientation=“vertical”

android:layout_width=“match_parent”

android:layout_height=“match_parent”>

<TextView android:id=“@+id/txt1”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:gravity=“center”

android:textSize=“30sp”

android:background=“@drawable/xiaomai1”

/>

style文件:

使用ViewPager实现底部导航栏

=============================================================================

使用Fragment有个局限,切换页面的方式只能通过点击底部的导航栏按钮切换,在平时的手机应用使用中也经常可以见到直接左右滑动页面就可以切换页面,而且看起来更加方便,所以下一种方式就是使用ViewPager来实现可以对页面滑动切换。

效果展示


viewpager实现效果

相关概念介绍


ViewPager简介

官方文档

在这里插入图片描述

ViewPager是android扩展包androidX包中的类,旧版的是在v4包中,ViewPager就是一个简单的页面切换组件,可以往里面填充多个View,然后可以左右滑动,从而切换不同的View。ViewPager类直接继承了ViewGroup类,所以它是一个容器类,可以在其中添加其他的view类。和ListView,GridView一样,也需要一个Adapter(适配器)将View和ViewPager进行绑定,而ViewPager则有一个特定的Adapter——PagerAdapter。

PagerAdapter简介

PagerAdapter需要重写下面的四个方法:

这只是官方建议,实际上只需重写getCount()和isViewFromObject()就可以了

getCount():获得viewpager中有多少个view

destroyItem():移除一个给定位置的页面。适配器有责任从容器中删除这个视图。这是为了确保finishUpdate(viewGroup)返回时视图能够被移除。

instantiateItem():

①将给定位置的view添加到ViewGroup(容器)中,创建并显示出来。

②返回一个代表新增页面的Object(key),通常都是直接返回view本身就可以了。

isViewFromObject():

判断instantiateItem(ViewGroup, int)函数所返回来的Key与一个页面视图是否是代表的同一个视图(即它俩是否是对应的,对应的表示同一个View),通常直接写return view == object!

以实现代码中的PagerAdapter为示例:

//初始化ViewPager的适配器

mAdpater = new PagerAdapter() {

//放回页面数量

@Override

public int getCount() {

return mTabs.size();

}

@Override

public boolean isViewFromObject(View view, Object object) {

return view == object;

}

@Override

public Object instantiateItem(ViewGroup container, int position) {

View view = mTabs.get(position);

container.addView(view);

return view;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

// super.destroyItem(container, position, object);

container.removeView(mTabs.get(position));

}

};

//设置ViewPager的适配器

mViewpager.setAdapter(mAdpater);

viewpagert实现底部导航栏代码实现


核心:MainActivity.class

public class MainActivity extends Activity implements OnClickListener {

//声明ViewPager

private ViewPager mViewpager;

//声明四个Tab

private Intent mTab1;

private Intent mTab2;

private Intent mTab3;

private Intent mTab4;

//声明四个ImageButton

private ImageButton mImg1;

private ImageButton mImg2;

private ImageButton mImg3;

private ImageButton mImg4;

//声明ViewPager的适配器

private PagerAdapter mAdpater;

//用于装载四个Tab的List

private List mTabs = new ArrayList();

private LocalActivityManager manager;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

//去掉TitleBar

requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(R.layout.activity_main);

//初始化控件

mViewpager = (ViewPager) findViewById(R.id.id_viewpager);

manager = new LocalActivityManager(this, true);

manager.dispatchCreate(savedInstanceState);

mTab1 = new Intent(MainActivity.this, pageActivity1.class);

View tab01 = manager.startActivity(“view1”, mTab1).getDecorView();

mTab2 = new Intent(MainActivity.this, pageActivity2.class);

View tab02 = manager.startActivity(“view2”, mTab2).getDecorView();

mTab3 = new Intent(MainActivity.this, pageActivity3.class);

View tab03 = manager.startActivity(“view3”, mTab3).getDecorView();

mTab4 = new Intent(MainActivity.this, pageActivity4.class);

View tab04 = manager.startActivity(“view4”, mTab4).getDecorView();

mImg1 = (ImageButton) findViewById(R.id.id_tab_img1);

mImg2 = (ImageButton) findViewById(R.id.id_tab_img2);

mImg3 = (ImageButton) findViewById(R.id.id_tab_img3);

mImg4 = (ImageButton) findViewById(R.id.id_tab_img4);

//获取到四个Tab

LayoutInflater inflater = LayoutInflater.from(this);

View tab1 = inflater.inflate(R.layout.tab1, null);

View tab2 = inflater.inflate(R.layout.tab2, null);

View tab3 = inflater.inflate(R.layout.tab3, null);

View tab4 = inflater.inflate(R.layout.tab4, null);

//将四个Tab添加到集合中

mTabs.add(tab01);

mTabs.add(tab02);

mTabs.add(tab03);

mTabs.add(tab04);

initDatas();//初始化数据

initEvents();//初始化事件

}

private void initEvents() {

//设置四个Tab的点击事件

mImg1.setOnClickListener(this);

mImg2.setOnClickListener(this);

mImg3.setOnClickListener(this);

mImg4.setOnClickListener(this);

//添加ViewPager的切换Tab的监听事件

mViewpager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

@Override

public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

}

@Override

public void onPageSelected(int position) {

//获取ViewPager的当前Tab

int currentItem = mViewpager.getCurrentItem();

//将所以的ImageButton设置成灰色

resetImgs();

//将当前Tab对应的ImageButton设置成绿色

switch (currentItem) {

case 0:

mImg1.setImageResource(R.mipmap.icon1);

break;

case 1:

mImg2.setImageResource(R.mipmap.icon1);

break;

case 2:

mImg3.setImageResource(R.mipmap.icon1);

break;

case 3:

mImg4.setImageResource(R.mipmap.icon1);

break;

}

}

@Override

public void onPageScrollStateChanged(int state) {

}

});

}

private void initDatas() {

//初始化ViewPager的适配器

mAdpater = new PagerAdapter() {

//放回页面数量

@Override

public int getCount() {

return mTabs.size();

}

@Override

public boolean isViewFromObject(View view, Object object) {

return view == object;

}

@Override

public Object instantiateItem(ViewGroup container, int position) {

View view = mTabs.get(position);

container.addView(view);

return view;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

// super.destroyItem(container, position, object);

container.removeView(mTabs.get(position));

}

};

//设置ViewPager的适配器

mViewpager.setAdapter(mAdpater);

}

//初始化控件

private void initViews() {

}

@Override

public void onClick(View v) {

//先将四个ImageButton都设置成灰色

resetImgs();

switch (v.getId()) {

case R.id.id_tab_img1:

//设置viewPager的当前Tab

mViewpager.setCurrentItem(0);

//将当前Tab对应的ImageButton设置成绿色

mImg1.setImageResource(R.mipmap.icon1);

break;

case R.id.id_tab_img2:

mViewpager.setCurrentItem(1);

mImg2.setImageResource(R.mipmap.icon1);

break;

case R.id.id_tab_img3:

mViewpager.setCurrentItem(2);

mImg3.setImageResource(R.mipmap.icon1);

break;

case R.id.id_tab_img4:

mViewpager.setCurrentItem(3);

mImg4.setImageResource(R.mipmap.icon1);

break;

}

}

//将四个ImageButton设置成灰色

private void resetImgs () {

mImg1.setImageResource(R.mipmap.icon2);

mImg2.setImageResource(R.mipmap.icon2);

mImg3.setImageResource(R.mipmap.icon2);

mImg4.setImageResource(R.mipmap.icon2);

}

}

每个页面的Acvitity

四个页面的实现都一样:

public class pageActivity1 extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.tab1);

this.getSupportActionBar().hide();//隐藏标题栏

TextView txt = (TextView)findViewById(R.id.txt1);

txt.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

Log.d(“dd”,“dddd”);

Toast.makeText(pageActivity1.this, “当前页面:1”, Toast.LENGTH_SHORT).show();

}

});

}

}

布局文件和上面的Fragment实现是一样的,就不在发代码了。

viewpager对view进行管理,大多情况单独使用viewpager用来实现简单的广告图案滚动展示,要实现每个界面的activity的话不方便。但是在动图展示里面很明显可以看出我是已经实现了每个view对应的Acvitity。示例中为了实现view的acvitity使用了LocalActivityManager,但是这个就很古老了,是API level 13之前的,不过既然都实现了而且还能用就也粘出来。说不定对看那些比较老的代码会有帮助。

使用 ViewPager + Fragment实现底部导航栏

=========================================================================================

在官方文档中,很明白地说了ViewPager最常与结合使用Fragment,饶了一圈回来,所以以后还是要尽量看第一手文档,才是最直接管用的。ViewPager + Fragment的方式可以拥有ViewPager 方便操作和Fragment独立acvitity实现,把界面和服务完美的分开了,是我最想要的样子。

效果展示


在这里插入图片描述

概念介绍


FragmentPagerAdapter简介

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总)

面试成功其实是必然的,因为我做足了充分的准备工作,包括刷题啊,看一些Android核心的知识点,看一些面试的博客吸取大家面试的一些经验,下面这份PDF是我翻阅了差不多1个月左右一些Android大博主的博客从他们那里取其精华去其糟泊所整理出来的一些Android的核心知识点, 全部都是精华中的精华,我能面试到现在资深开发人员跟我整理的这本Android核心知识点有密不可分的关系,在这里本着共赢的心态分享给各位朋友。

这份PDF囊括了JVM,Java集合,Java多线程并发,Java基础,生命周期,微服务, 进程,Parcelable 接口,IPC,屏幕适配,线程异步,ART,架构,Jetpack,NDK开发,计算机网络基础,类加载器,Android 开源库源码分析,设计模式汇总,Gradle 知识点汇总…

由于篇幅有限,就不做过多的介绍,大家请自行脑补

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-2fDe9LAM-1712557142479)]

[外链图片转存中…(img-OI67IQyy-1712557142480)]

[外链图片转存中…(img-BmSywuH2-1712557142480)]

[外链图片转存中…(img-awkRmqB0-1712557142481)]

[外链图片转存中…(img-AlUDnNyh-1712557142481)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总)

[外链图片转存中…(img-w3UAw8wD-1712557142481)]

面试成功其实是必然的,因为我做足了充分的准备工作,包括刷题啊,看一些Android核心的知识点,看一些面试的博客吸取大家面试的一些经验,下面这份PDF是我翻阅了差不多1个月左右一些Android大博主的博客从他们那里取其精华去其糟泊所整理出来的一些Android的核心知识点, 全部都是精华中的精华,我能面试到现在资深开发人员跟我整理的这本Android核心知识点有密不可分的关系,在这里本着共赢的心态分享给各位朋友。
[外链图片转存中…(img-SmWmQoCf-1712557142482)]

这份PDF囊括了JVM,Java集合,Java多线程并发,Java基础,生命周期,微服务, 进程,Parcelable 接口,IPC,屏幕适配,线程异步,ART,架构,Jetpack,NDK开发,计算机网络基础,类加载器,Android 开源库源码分析,设计模式汇总,Gradle 知识点汇总…

由于篇幅有限,就不做过多的介绍,大家请自行脑补

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 24
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 Android 底部导航栏可以使用以下步骤: 1. 在布局文件中添加 BottomNavigationView 控件。 2. 在 Java 文件中获取 BottomNavigationView 的实例,并设置导航栏的选项。 3. 创建多个 Fragment 来作为导航栏的选项内容。 4. 在 Java 文件中设置导航栏选项的监听器,根据选项的不同切换 Fragment。 以下是一个基本的 Android 底部导航栏实现示例代码: XML 布局文件: ``` <RelativeLayout <!-- other views --> <FrameLayout android:id="@+id/fragment_container" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_above="@+id/bottom_navigation_view" /> <android.support.design.widget.BottomNavigationView android:id="@+id/bottom_navigation_view" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" app:menu="@menu/bottom_navigation_menu" /> </RelativeLayout> ``` Java 文件: ``` public class MainActivity extends AppCompatActivity { private BottomNavigationView bottomNavigationView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bottomNavigationView = findViewById(R.id.bottom_navigation_view); bottomNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() { @Override public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) { switch (menuItem.getItemId()) { case R.id.navigation_home: switchFragment(new HomeFragment()); return true; case R.id.navigation_search: switchFragment(new SearchFragment()); return true; case R.id.navigation_notifications: switchFragment(new NotificationFragment()); return true; } return false; } }); // 默认显示 HomeFragment switchFragment(new HomeFragment()); } private void switchFragment(Fragment fragment) { getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container, fragment).commit(); } } ``` 其中,我们使用了 FrameLayout 来作为 Fragment 的容器,将 Fragment 切换时使用了 FragmentTransaction。同时,我们使用了 BottomNavigationView 的 setOnNavigationItemSelectedListener 来监听导航栏选项点击事件,并根据不同选项切换不同的 Fragment。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值