【简单项目框架一】Fragment实现的底部导航
来源:互联网 发布:图书数据加工人员 编辑:程序博客网 时间:2024/05/25 21:34
流行的应用的导航一般分为两种,一种是底部导航,一种是侧边栏。
我所做的项目涉及到比较多的是底部导航,今天我就把项目中使用的一种实现方式分享一下。
主要实现思路是:在一个Activity里面底部添加四个按键,上边通过切换不同的Fragment来实现。
首先在activity_main.xml
实现一个底部布局
<RelativeLayout android:id="@+id/aboveLayout" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <RelativeLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#dbdbdb" android:orientation="vertical" > <LinearLayout android:id="@+id/fragmentRoot" android:layout_width="fill_parent" android:layout_height="fill_parent" /> <LinearLayout android:id="@+id/bottomList" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:background="@android:color/black" android:orientation="horizontal" > <LinearLayout android:id="@+id/bottomItemCurrentBg1" style="@style/main_bottom_item" > <RadioButton android:id="@+id/rbMain" style="@style/footbar" android:drawableTop="@drawable/tab_weixin_normal" android:paddingTop="8dp" android:text="微信" /> </LinearLayout> <LinearLayout android:id="@+id/bottomItemCurrentBg2" style="@style/main_bottom_item" > <RadioButton android:id="@+id/rbCategory" style="@style/footbar" android:drawableTop="@drawable/tab_address_normal" android:paddingTop="8dp" android:text="通讯录" /> </LinearLayout> <LinearLayout android:id="@+id/bottomItemCurrentBg3" style="@style/main_bottom_item" > <RadioButton android:id="@+id/rbFind" style="@style/footbar" android:drawableTop="@drawable/tab_find_frd_normal" android:paddingTop="8dp" android:text="发现" /> </LinearLayout> <LinearLayout android:id="@+id/bottomItemCurrentBg4" style="@style/main_bottom_item" > <RadioButton android:id="@+id/rbMe" style="@style/footbar" android:drawableTop="@drawable/tab_settings_normal" android:paddingTop="8dp" android:text="我" /> </LinearLayout> </LinearLayout> </RelativeLayout> </RelativeLayout>
这里主要用到的知识点有:style的使用,Radiobutton的一些特殊属性设置,权重,以及drawableTop的使用。
底部布局实现之后,就需要在MainActivity里面找到对应的控件做出相应的逻辑处理了。
首先实例化一个FragmentManager实例
然后初始化首页的布局,这里为微信首页面,通过调用initFragment();来实现,接着就是点击的处理dealBottomButtonsClickEvent();
代码如下:
/** * 初始化首个Fragment */ private void initFragment() { FragmentTransaction ft = fMgr.beginTransaction(); WeiXinFragment weiXinFragment = new WeiXinFragment(); ft.add(R.id.fragmentRoot, weiXinFragment, "weiXinFragment"); ft.addToBackStack("weiXinFragment"); ft.commit(); } /** * 处理底部点击事件 */ private void dealBottomButtonsClickEvent() { findViewById(R.id.rbWeiXin).setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub if(fMgr.findFragmentByTag("weiXinFragment")!=null && fMgr.findFragmentByTag("weiXinFragment").isVisible()) { return; } popAllFragmentsExceptTheBottomOne(); } });
点击初始化的代码我只截取了一个,这里用到的几个知识点是:
1、Fragment的管理,添加,放入堆栈,提交
2、关于Fragment的Tag的使用,因为在初始化的时候设置了tag,所以在点击时间里面,判断如果当前的的Fragment显示着,那么就直接return,都则弹出之前所有的Fragment保留WeiXinFragment。
3、关于Fragment堆栈的问题,添加的时候是把一new的Fragment添加到堆栈里,这里调用了fMgr.popBackStack();
最后就是拦截返回键的处理了。
//点击返回按钮 @Override public void onBackPressed() { if(fMgr.findFragmentByTag("weiXinFragment")!=null && fMgr.findFragmentByTag("weiXinFragment").isVisible()) { MainActivity.this.finish(); } else { super.onBackPressed(); } }
0 0
- 【简单项目框架一】Fragment实现的底部导航
- 【简单项目框架一】Fragment实现的底部导航
- Fragment实现的底部导航
- Fragment 实现底部导航栏的简单切换
- Fragment实现底部导航
- 底部导航的简单实现
- Fragment之底部导航栏的实现
- Fragment底部导航栏的实现
- Android Fragment实现底部导航
- 使用 Fragment 实现底部导航
- Fragment + RadioGroup实现底部导航
- viewpager+fragment实现底部导航
- Fragment底部导航栏实现
- Fragment的应用之底部导航栏的实现(一)
- 底部导航栏实现页面的切换(一):Fragment + LinearLayout + TextView
- Android 底部导航与Fragment联动的实现
- BottomBar+ViewPager+Fragment实现炫酷的底部导航效果
- Android个人学习笔记-底部导航切换Fragment的实现
- C++面试
- java面试
- oracle使用记录
- CSS_02 文字属性_文本属性_背景属性_列表属性
- iOS学习笔记--几种注释的作用pragma warning /***/星号
- 【简单项目框架一】Fragment实现的底部导航
- Oracle 参数文件
- WebM Web Video Encoding Tutorial With FFMpeg
- PAT 1023. Have Fun with Numbers (20)
- 实时编辑表格,可以编辑的表格
- 营业额统计
- 【建立二叉树】后序建立二叉树
- 验证表单元素常用的正则表达式
- Binary Tree Preorder Traversal