初学者使用Fragment+RadioButton切换效果

先上效果图

             

界面代码就不用贴出来了就是一个RadioGroup+3个RadioButton,底下一个FrameLayout。完事(底部导航栏也可以这样做)

(1)先初始化控件

@BindView(R.id.rad_group)
RadioGroup radGroup;
@BindView(R.id.rab_1)
RadioButton rab1;
@BindView(R.id.rab_2)
RadioButton rab2;
@BindView(R.id.rab_3)
RadioButton rab3;
@BindView(R.id.fl_contain)
FrameLayout flContain;

private ShareFragmentOne shareFragmentOne;
private ShareFragmentTwo shareFragmentTwo;
private ShareFragmentThree shareFragmentThree;
@Override
protected void onCreate(Bundle savedInstanceState) {
    mvpPresenter = createPresenter();
    super.onCreate(savedInstanceState);
//默认显示第一个,默认的rabutton设置下xml checked=true属性
    setSelect(1);

    radGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
//点击radGroup的监听事件,切换Fragment,这里还可以用For循环去实现。
    @Override
    public void onCheckedChanged(RadioGroup radioGroup, int i) {
        switch (i) {
            case R.id.rab_1:
                setSelect(1);//切换
       
                break;
            case R.id.rab_2:
                setSelect(2);
              
                break;
            case R.id.rab_3:
                setSelect(3);
            
                break;
        }
    }
});
}

 

public void setSelect(int i)

{

FragmentManager fm = getSupportFragmentManager();

FragmentTransaction ft = fm.beginTransaction();

hideFragment(ft);//先隐藏所有Fragment

switch (i) {
    case 1://如果点击的是第一个rab,如果为空先Add,如果不为空直接show,
        if (shareFragmentOne == null) {
            shareFragmentOne = new ShareFragmentOne();
            ft.add(R.id.fl_contain, shareFragmentOne);
        } else {
            ft.show(shareFragmentOne);
        }
        break;
    case 2://如果点击的是第二个rab...
        if (shareFragmentTwo == null) {
            shareFragmentTwo = new ShareFragmentTwo();
            ft.add(R.id.fl_contain, shareFragmentTwo);
        } else {
            ft.show(shareFragmentTwo);
        }
        break;
    case 3:
        if (shareFragmentThree == null) {
            shareFragmentThree = new ShareFragmentThree();
            ft.add(R.id.fl_contain, shareFragmentThree);
        }
        break;
      ft.commit();//这句话别漏了
}

 

}

 

private void hideFragment(FragmentTransaction ft) {
    if (shareFragmentOne != null) {
        ft.hide(shareFragmentOne);
    }
    if (shareFragmentTwo != null) {
        ft.hide(shareFragmentTwo);
    }
    if (shareFragmentThree != null) {
        ft.hide(shareFragmentThree);
    }
}

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以在`onCreateView`方法中使用`AlertDialog.Builder`创建一个对话框,并在其中加载布局,然后在布局中添加两个`TextView`和四个`RadioButton`。最后给四个`RadioButton`添加点击事件,并在对话框中添加取消和确定按钮。具体实现如下: ``` @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View rootView = inflater.inflate(R.layout.your_layout, container, false); // 创建对话框 AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); builder.setTitle("标题"); // 加载布局 View dialogView = inflater.inflate(R.layout.dialog_layout, null); builder.setView(dialogView); // 添加TextView和RadioButton TextView textView1 = dialogView.findViewById(R.id.textview1); TextView textView2 = dialogView.findViewById(R.id.textview2); RadioButton radioButton1 = dialogView.findViewById(R.id.radiobutton1); RadioButton radioButton2 = dialogView.findViewById(R.id.radiobutton2); RadioButton radioButton3 = dialogView.findViewById(R.id.radiobutton3); RadioButton radioButton4 = dialogView.findViewById(R.id.radiobutton4); // 给四个RadioButton添加点击事件 radioButton1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 } }); radioButton2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 } }); radioButton3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 } }); radioButton4.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 } }); // 添加取消和确定按钮 builder.setNegativeButton("取消", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 处理取消按钮点击事件 } }); builder.setPositiveButton("确定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // 处理确定按钮点击事件 } }); // 显示对话框 AlertDialog dialog = builder.create(); dialog.show(); return rootView; } ``` 在这个例子中,我们首先使用`AlertDialog.Builder`创建一个对话框,并设置对话框的标题。然后,我们使用`LayoutInflater`加载一个布局文件,并将其设置为对话框的视图。在布局文件中,我们添加了两个`TextView`和四个`RadioButton`。接下来,我们给四个`RadioButton`添加了点击事件,并在对话框中添加了取消和确定按钮。最后,我们调用`show`方法显示对话框,并返回根视图。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值