使用fragmnet+viewPager+RadioGroup底部导航栏

昨天写了使用layout加载PagerAdapter,今天写一个使用fragmnet+viewPager+RadioGroup底部导航栏的,。

一.写一个fragment,

public class Fragment1 extends android.support.v4.app.Fragment {
    private  RadioButton radioButton;
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.activity_first_first,null);
        return view;
    }

其他三个都是一样fragment,照着撸出来就可以了,都是fragment加载布局,。

二.写个适配器

public class MyViewPagerFragmentAdapter extends FragmentPagerAdapter{
    private List<Fragment> list ;
    public MyViewPagerFragmentAdapter(FragmentManager fragmentManager,List<Fragment> list){
        super(fragmentManager);
        this.list = list;
    }
    @Override
    public Fragment getItem(int position) {

        return list.get(position);
    }
    @Override
    public int getCount() {
        return list.size();
    }
}

适配器的导包都是v4的。

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;

activity_first_first布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffffff"
    android:orientation="vertical"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center"
        android:orientation="vertical">

        <Button
            android:id="@+id/testActivity_intent"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:padding="@dimen/g10"
            android:text="@string/testActivity_intent" />

    </LinearLayout>
</LinearLayout>
其他三个都是简单的布局,就不贴出来了。

activity布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:orientation="vertical"
    android:layout_height="match_parent">
    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager_viewPager"
        android:layout_weight="1"
        android:layout_width="match_parent"
        android:layout_height="0dp">
    </android.support.v4.view.ViewPager>
    <RadioGroup
        android:id="@+id/viewPager_radioGroup"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <RadioButton
            android:id="@+id/viewPager_radioBtn1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:button="@null"
            android:drawableTop="@drawable/radio_button_pic1"
            android:gravity="center"
            android:text="主页" />
        <RadioButton
            android:id="@+id/main_fragment3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:button="@null"
            android:drawableTop="@drawable/radio_button_pic2"
            android:gravity="center"
            android:text="物业" />
        <RadioButton
            android:id="@+id/viewPager_radioBtn3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:button="@null"
            android:drawableTop="@drawable/radio_button_pic3"
            android:gravity="center"
            android:text="发现" />
        <RadioButton
            android:id="@+id/viewPager_radioBtn4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:button="@null"
            android:drawableTop="@drawable/radio_button_pic4"
            android:gravity="center"
            android:text="我的" />
    </RadioGroup>
</LinearLayout>
最后写activity的实现
public class ViewPagerFragmentActivity extends AppCompatActivity implements RadioGroup.OnCheckedChangeListener,ViewPager.OnPageChangeListener{
    private ViewPager viewPager;
    private RadioGroup radioGroup;

    private List<Fragment> list;
    private MyViewPagerFragmentAdapter myViewPagerFragmentAdapter;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_viewpager_fragment);
        initView();
        initData();
    }
    public void initView(){
        viewPager = findViewById(R.id.viewPager_viewPager);
        radioGroup = findViewById(R.id.viewPager_radioGroup);

        radioGroup.setOnCheckedChangeListener(this);
        viewPager.addOnPageChangeListener(this);

    }
    public void initData(){
        list = new ArrayList<>();
        list.add(new Fragment1());
        list.add(new Fragment2());
        list.add(new Fragment3());
        list.add(new Fragment4());

        myViewPagerFragmentAdapter = new MyViewPagerFragmentAdapter(getSupportFragmentManager(),list);
        viewPager.setAdapter(myViewPagerFragmentAdapter);

        radioGroup.check(R.id.viewPager_radioBtn1);
    }

    @Override
    public void onCheckedChanged(RadioGroup group, int checkedId) {
        switch (checkedId){
            case R.id.viewPager_radioBtn1:
                viewPager.setCurrentItem(0);
                break;
            case R.id.viewPager_radioBtn2:
                viewPager.setCurrentItem(1);
                break;
            case R.id.viewPager_radioBtn3:
                viewPager.setCurrentItem(2);
                break;
            case R.id.viewPager_radioBtn4:
                viewPager.setCurrentItem(3);
                break;
        }
    }
    //滑动中
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }
    //viewpager滑动完成之后
    @Override
    public void onPageSelected(int position) {

    }
    //监听滑动状态
    @Override
    public void onPageScrollStateChanged(int state) {
        //state 0还没滑动 -1滑动中- 2滑动完成
        if(state==2){
            switch (viewPager.getCurrentItem()){
                case 0:
                    radioGroup.check(R.id.viewPager_radioBtn1);
                    break;
                case 1:
                    radioGroup.check(R.id.viewPager_radioBtn2);
                    break;
                case 2:
                    radioGroup.check(R.id.viewPager_radioBtn3);
                    break;
                case 3:
                    radioGroup.check(R.id.viewPager_radioBtn4);
                    break;
            }
        }
    }
 }
}

就这些了,希望能对你有帮助,。一起进步,,,吐舌头吐舌头

源码下载地址:https://download.csdn.net/download/weixin_42267745/10436113



 







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值