android radiobutton底部导航,android中Fragment+RadioButton实现底部导航栏
在App中经常看到这样的tab底部导航栏
那么这种效果是如何实现,实现的方式有很多种,最常见的就是使用Fragment+RadioButton去实现。下面我们来写一个例子
首先我们先在activity_mian.xml定义布局,整个布局的外面是线性布局,上面是帧布局切换不同的Fragment,底下是RadioGroup嵌套的是RadioButton。代码如下所示:
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ffffff"
android:orientation="vertical">
android:id="@+id/frameLayout"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
android:id="@+id/rg_main"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="@drawable/home_bottom_parent_bg"
android:orientation="horizontal">
android:id="@+id/rb_home"
style="@style/MainButtonStyle"
android:drawableTop="@drawable/home_button_selector"
android:text="首页" />
android:id="@+id/rb_type"
style="@style/MainButtonStyle"
android:drawableTop="@drawable/type_button_selector"
android:text="分类" />
android:id="@+id/rb_community"
style="@style/MainButtonStyle"
android:drawableTop="@drawable/community_button_selector"
android:paddingTop="10dp"
android:text="发现" />
android:id="@+id/rb_cart"
style="@style/MainButtonStyle"
android:drawableTop="@drawable/cart_button_selector"
android:text="购物车" />
android:id="@+id/rb_user"
style="@style/MainButtonStyle"
android:drawableTop="@drawable/user_button_selector"
android:text="个人中心" />
注意:上面还有样式和drawable,下面我们一个一个的来完善。
首先来看样式,打开【res】—【values】—【styles】,代码如下所示:
0dp
wrap_content
1
@null
@drawable/bottom_button_text_selector
10sp
center
里面还有一个@drawable/bottom_button_text_selector,这个是设置图片和文字的颜色,在drawable的目录下建bottom_button_text_selector,代码如下所示:
接着我们继续来完善drawable,有【首页】【分类】【发现】【购物车】【个人中心】,写法都是一样的,这里用【首页】来做例子,在drawable目录下建home_button_selector,代码如下所示:
接下来看MainActivity中的代码,代码如下:
package com.nyl.shoppingmall.app.activity;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentTransaction;
import android.widget.FrameLayout;
import android.widget.RadioGroup;
import com.nyl.shoppingmall.R;
import com.nyl.shoppingmall.base.BaseFragment;
import com.nyl.shoppingmall.community.fragment.CommunityFragment;
import com.nyl.shoppingmall.home.fragment.HomeFragment;
import com.nyl.shoppingmall.shoppingcart.fragment.ShoppingCartFragment;
import com.nyl.shoppingmall.type.fragment.TypeCartFragment;
import com.nyl.shoppingmall.user.fragment.UserCartFragment;
import java.util.ArrayList;
import butterknife.Bind;
import butterknife.ButterKnife;
public class MainActivity extends FragmentActivity{
@Bind(R.id.frameLayout)
FrameLayout frameLayout;
@Bind(R.id.rg_main)
RadioGroup rgMain;
//装fragment的实例集合
private ArrayList fragments;
private int position = 0;
//缓存Fragment或上次显示的Fragment
private Fragment tempFragment;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//ButterKnife和当前Activity绑定
ButterKnife.bind(this);
//初始化Fragment
initFragment();
//设置RadioGroup的监听
initListener();
}
private void initListener() {
rgMain.check(R.id.rb_home);
rgMain.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(RadioGroup radioGroup, int i) {
switch (i){
case R.id.rb_home: //首页
position = 0;
break;
case R.id.rb_type: //分类
position = 1;
break;
case R.id.rb_community: //发现
position = 2;
break;
case R.id.rb_cart: //购物车
position = 3;
break;
case R.id.rb_user: //个人中心
position = 4;
break;
default:
position = 0;
break;
}
//根据位置得到相应的Fragment
BaseFragment baseFragment = getFragment(position);
/**
* 第一个参数: 上次显示的Fragment
* 第二个参数: 当前正要显示的Fragment
*/
switchFragment(tempFragment,baseFragment);
}
});
}
/**
* 添加的时候按照顺序
*/
private void initFragment(){
fragments = new ArrayList<>();
fragments.add(new HomeFragment());
fragments.add(new TypeCartFragment());
fragments.add(new CommunityFragment());
fragments.add(new ShoppingCartFragment());
fragments.add(new UserCartFragment());
}
/**
* 根据位置得到对应的 Fragment
* @param position
* @return
*/
private BaseFragment getFragment(int position){
if(fragments != null && fragments.size()>0){
BaseFragment baseFragment = fragments.get(position);
return baseFragment;
}
return null;
}
/**
* 切换Fragment
* @param fragment
* @param nextFragment
*/
private void switchFragment(Fragment fragment,BaseFragment nextFragment){
if (tempFragment != nextFragment){
tempFragment = nextFragment;
if (nextFragment != null){
FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
//判断nextFragment是否添加成功
if (!nextFragment.isAdded()){
//隐藏当前的Fragment
if (fragment != null){
transaction.hide(fragment);
}
//添加Fragment
transaction.add(R.id.frameLayout,nextFragment).commit();
}else {
//隐藏当前Fragment
if (fragment != null){
transaction.hide(fragment);
}
transaction.show(nextFragment).commit();
}
}
}
}
}
首先使用ButterKnife初始化布局控件,然后在onCreate方法中初始化Fragment和绑定RadioGroup的选中改变事件,为了方便初始化Fragment,写了一个initFragment方法,在方法内部创建HomeFragment,TypeCartFragment,CommunityFragment,ShoppingCartFragment,UserCartFragment四个Fragment实例,然后使用一个fragments集合存储这四个实例。接下来写一个switchFragment方法,用于切换显示指定的Fragmetn,当RadioGroup的选中改变时,首先根据选中的位置获取到对应的Fragment,然后将获取到的Fragment传入到switchFragment方法中进行显示。由于每次RadioGroup的选中改变获取到的Fragment都不一样,从而可以实现根据选中的RadioGroup展示不同的Fragment效果,也就是常见的Tab切换效果。
Activity中用到的HomeFragment,TypeCartFragment,CommunityFragment,ShoppingCartFragment,UserCartFragment这四个Fragment的代码比较简单,以HomeFragment为例,代码如下:
package com.nyl.shoppingmall.home.fragment;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.widget.TextView;
import com.nyl.shoppingmall.base.BaseFragment;
/**
* 首页Fragment
*/
public class HomeFragment extends BaseFragment {
private final static String TAG = HomeFragment.class.getSimpleName();
private TextView textView;
@Override
public View initView() {
textView = new TextView(mContext);
textView.setGravity(Gravity.CENTER);
textView.setTextSize(25);
Log.e(TAG,"主页面的Fragment的UI被初始化了");
return textView;
}
@Override
public void initData() {
super.initData();
textView.setText("首页");
Log.e(TAG,"主页面的Fragment的数据被初始化了");
}
}
HomeFragment继承自BaseFragment,然后重写父类的initView方法和initData方法,BaseFragment的代码如下:
package com.nyl.shoppingmall.base;
import android.content.Context;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
/**
* 基类Fragment
* 首页:HomeFragment
* 分类:TypeFragment
* 发现:CommunityFragment
* 购物车:ShoppingCartFragment
* 用户中心:UserFragment
* 等等都要继承该类
*/
public abstract class BaseFragment extends Fragment{
protected Context mContext;
/**
* 当该类被系统创建的时候回调
* @param savedInstanceState
*/
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mContext = getActivity();
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
return initView();
}
//抽象类,由孩子实现,实现不同的效果
public abstract View initView();
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
initData();
}
/**
* 当子类需要联网请求数据的时候,可以重写该方法,该方法中联网请求
*/
public void initData() {
}
}
其余几个Fragment的代码也类似,这里就不再细说了,使用Fragment+RadioButton实现底部导航栏的思路和代码实现就是这样的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
android radiobutton底部导航,android中Fragment+RadioButton实现底部导航栏相关推荐
- 处女男学Android(十一)---Gallery、ViewPager和ViewPager+Fragment实现的Tab导航
一.前言 转载请标明出处:http://blog.csdn.net/wlwlwlwl015/article/details/42087915 有阵子没更新博客了,主要是最近公司接了个P2P的金融借贷项 ...
- android radiobutton底部导航,Android底部导航栏之RadioButton
一. 简介 1.1 原理 就是用RadioButton实现一组导航栏的布局,然后处理点击事件,动态替换Fragment 1.2 用到东西 RadioButton StateListDrawable 1 ...
- Android studio实现底部导航,Android 开发之BottomBar+ViewPager+Fragment实现炫酷的底部导航效果...
BottomBar BottomBar是Github上的一个开源框架,因为从1.3.3开始不支持fragments了,要自己配置,弄了很久,不管是app的fragment还是V4 的程序总是总是闪退. ...
- Android 2.2 r1 API 中文文档系列(11) —— RadioButton
一.结构 public class RadioButton extends CompoundButton java.lang.Object android.view.View ...
- android顶部导航高度,Android特效——————底部/顶部导航条(Fragment+ViewPaper+XTabLayout)...
初次使用xtablayout和viewpaper2.所以就弄了最基础的导航条 一.效果 二.代码 配置环境[在bulid.gradle中添加以下代码] implementation 'androidx ...
- android标签栏图标大小,如何在android底部导航布局中增加图标大小?
我在 Android中使用最近由设计库25中的谷歌引入的底部布局导航样式.在我看到的所有教程和问题中,图标中的图像是正常大小,但是我的图像非常小,尽管事实上我保存到drawable文件夹的图像是72× ...
- android多个单选按钮互斥使用,在android中使用RadioButton时,要想实现互斥
[搬运] http://www.cnblogs.com/wt616/archive/2011/06/20/2085531.html RadioButton和CheckBox的区别: 1.单个Radio ...
- android radiogroup 底部菜单,Android底部菜单栏(RadioGroup+Fragment)美化
众所周知,android的底部菜单栏太重要,平时项目一般都是需要用到的,但是网上关于这方面的demo做得太丑了,实在惨不忍睹,所以这里便用RadioGroup+Fragment的方式写了一个,顺便美化 ...
- php仿微信底部菜单,Android实现简单底部导航栏 Android仿微信滑动切换效果
Android仿微信滑动切换最终实现效果: 大体思路: 1. 主要使用两个自定义View配合实现; 底部图标加文字为一个自定义view,底部导航栏为一个载体,根据需要来添加底部图标; 2. 底部导航栏 ...
最新文章
- Atitit. atiJavaExConverter4js 新的特性
- html5 像素人物,HTML5 Canvas 像素火焰 | 火苗
- 最短路径问题(Floyd算法)
- 20169217 《Linux内核原理与分析》第七周作业
- [react] 在react中无状态组件有什么运用场景
- 长文解析:作为容器底层技术的半壁江山, cgroup如何突破并发创建瓶颈?
- 这届年轻人,连泡面也买不起了
- python入门指南 许半仙txt-影帝的脑子坏了
- 手机丢了如何损失最小
- Python 认识字典
- 刘润老师的5分钟商学院营销案例~比例偏见!
- 在用mybatis时报错java.lang.AbstractMethodError: com.mysql.jdbc.ServerPreparedState
- 【锂电池】关于4.2V锂电池充电IC的一些记录
- 用java画人物_如何画不同人物的视角?该怎么画?
- mac设置共享屏幕 苹果mac屏幕共享设置详细教程
- 6种改善客户体验的方法
- c语言组播源码_CLAA Class C简单组播业务的实现
- 程序员不爱炫富?不,那是你了解的程序员
- (导数)微分与积分的概念
- LitePal数据库的基本操作
热门文章
- matlab计数器清零,51单片机计数器清零
- 索引添加后,ACCESS数据库表查询运行速度的区别
- 编程语言“鄙视链” +1?亚马逊力捧 Rust,Go 技术负责人连发 14 条推特抵制“拉踩”
- 十年比肩?看国产数据库如何突出重围! | 新程序员
- Canvas渲染会取代DOM吗?
- Go 应用优化“指北”
- 美国团购巨头是怎样衰落的
- Java 是如何优雅地实现接口数据校验的?
- GitHub 下架 Youtube-dl 遭粉丝疯狂上传源码报复,开源者的权益谁来维护?
- IBM将剥离传统IT基础设施部门;迅雷前CEO陈磊涉嫌职务侵占罪被调查 ;Python 3.9发布|极客头条