Android开发ViewPager+TabLayout详解(使用FragmentPagerAdapter和PagerAdapter两个Demo叙述)

在讲解之前首先看一下所要展示的效果:

在使用TabLayout这个控件之前,首先要在build.gradle添加下面这行依赖:

compile 'com.android.support:design:27.1.0'

1,在activity_main.xml布局文件中添加TabLayout和ViewPager两个控件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.example.myactivitydemo.MainActivity">

    <android.support.design.widget.TabLayout
        android:id="@+id/tabLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabGravity="fill"
        app:tabMode="scrollable"
        app:tabSelectedTextColor="@android:color/holo_red_dark"
        app:tabIndicatorColor="@android:color/holo_red_dark"
        app:tabTextColor="@android:color/white"
        app:tabBackground="@android:color/holo_blue_light"
        >
    </android.support.design.widget.TabLayout>
    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </android.support.v4.view.ViewPager>
</LinearLayout>

2,定义一个MyViewPagerAdapter类继承PagerAdapter

public class MyViewPagerAdapter extends PagerAdapter {
    private List<View> myAdapterList;
    public MyViewPagerAdapter(List<View> myAdapterList){
        this.myAdapterList=myAdapterList;
    }
    @Override
    public int getCount() {
        return myAdapterList.size();
    }

    @Override
    public Object instantiateItem(ViewGroup container, int position) {
        container.addView(myAdapterList.get(position));
        //return myAdapterList.get(position);
        return position;
    }

    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view==myAdapterList.get(Integer.parseInt(object.toString()));
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView(myAdapterList.get(position));
    }

    @Override
    public CharSequence getPageTitle(int position) {
        return "布局";
    }
}

3,主布局的写法

public class MainActivity extends AppCompatActivity {

    private TabLayout tabLayout;
    private ViewPager viewPager;

    private List<View> myView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //初始化控件
        tabLayout=findViewById(R.id.tabLayout);
        viewPager=findViewById(R.id.viewPager);

        LayoutInflater layoutInflater=getLayoutInflater();
        View view1=layoutInflater.inflate(R.layout.layout_1,null);
        View view2=layoutInflater.inflate(R.layout.layout_2,null);
        View view3=layoutInflater.inflate(R.layout.layout_3,null);
        myView=new ArrayList<>();
        myView.add(view1);
        myView.add(view2);
        myView.add(view3);

        MyViewPagerAdapter my=new MyViewPagerAdapter(myView);
        viewPager.setAdapter(my);
        tabLayout.setupWithViewPager(viewPager);

    }
}

二,下面讲解FragmentPagerAdapter的使用方法。

1,activity_main.xml布局不改变

2,定义一个MyFragmentAdapter继承自FragmentPagerAdapter。


public class MyFragmentAdapter extends FragmentPagerAdapter {
    private List<MainActivity.PageModel> modelList;
    private MainActivity.PageModel pageModel;
    public MyFragmentAdapter(FragmentManager fm, List<MainActivity.PageModel> modelList) {
        super(fm);
        this.modelList=modelList;
    }

    @Override
    public Fragment getItem(int position) {
        pageModel=modelList.get(position);
        return MyFragment.newInstance(pageModel.sampleLayout);
    }

    @Override
    public int getCount() {
        return modelList.size();
    }

    @Override
    public CharSequence getPageTitle(int position) {
        pageModel= modelList.get(position);
        return pageModel.layoutTitle;
    }
}

3,写一个MyFragment继承自Fragment


public class MyFragment extends Fragment {
    private Context mContext;
    private int sampleLayout;

    public static Fragment newInstance(int sampleLayout){
        MyFragment myFragment=new MyFragment();
        Bundle bundle=new Bundle();
        bundle.putInt("sampleLayoutRes",sampleLayout);
        myFragment.setArguments(bundle);
        return myFragment;
    }
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mContext = getActivity();
        Bundle args=getArguments();
        this.sampleLayout=args.getInt("sampleLayoutRes");

    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view=inflater.inflate(R.layout.fragment_page,container,false);
        ViewStub viewStub=view.findViewById(R.id.sampleStub);
        viewStub.setLayoutResource(sampleLayout);
        viewStub.inflate();
        return view;
    }

    @Override
    public void onActivityCreated(@Nullable Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
    }
}

4,主布局的写法


public class MainActivity extends AppCompatActivity {

    private TabLayout tabLayout;
    private ViewPager viewPager;
    private List<PageModel> pageModelList;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        tabLayout=findViewById(R.id.tabLayout);
        viewPager=findViewById(R.id.viewPager);
        pageModelList=new ArrayList<>();
        pageModelList.add(new PageModel("布局1",R.layout.layout_1));
        pageModelList.add(new PageModel("布局2",R.layout.layout_2));
        pageModelList.add(new PageModel("布局3",R.layout.layout_3));

        MyFragmentAdapter fragmentPagerAdapter=new MyFragmentAdapter(getSupportFragmentManager(),pageModelList);
        viewPager.setAdapter(fragmentPagerAdapter);
        tabLayout.setupWithViewPager(viewPager);
    }

    class PageModel{
        int sampleLayout;
        String layoutTitle;
        public PageModel(String layoutTitle,int sampleLayout){
            this.layoutTitle= layoutTitle;
            this.sampleLayout=sampleLayout;
        }
    }
}

5,fragment_page.xml布局的写法

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ViewStub
        android:id="@+id/sampleStub"
        android:layout_width="match_parent"
        android:layout_height="300dp"
        android:layout_gravity="center"/>
</LinearLayout>

其他布局非常简单,就不再一一写出。

以上就是ViewPager的使用方法。有需要源码的欢迎留言,留邮箱发给你们。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个使用TabLayout+ViewPager+Fragmet+RecyclerView结合的小demo的示例代码。 1. 首先,在xml文件中添加TabLayout和ViewPager组件。 ```xml <android.support.design.widget.TabLayout android:id="@+id/tab_layout" android:layout_width="match_parent" android:layout_height="wrap_content" /> <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 创建Fragment类,用于展示RecyclerView数据。 ```java public class SimpleFragment extends Fragment { private RecyclerView recyclerView; private SimpleAdapter adapter; @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_simple, container, false); recyclerView = view.findViewById(R.id.recycler_view); recyclerView.setLayoutManager(new LinearLayoutManager(getContext())); adapter = new SimpleAdapter(); recyclerView.setAdapter(adapter); return view; } } ``` 3. 创建FragmentPagerAdapter类,用于管理Fragment。 ```java public class SimplePagerAdapter extends FragmentPagerAdapter { private String[] titles; public SimplePagerAdapter(FragmentManager fm, String[] titles) { super(fm); this.titles = titles; } @Override public Fragment getItem(int position) { return new SimpleFragment(); } @Override public int getCount() { return titles.length; } @Nullable @Override public CharSequence getPageTitle(int position) { return titles[position]; } } ``` 4. 创建RecyclerView Adapter类,用于展示数据。 ```java public class SimpleAdapter extends RecyclerView.Adapter<SimpleViewHolder> { private List<String> data; public SimpleAdapter() { data = new ArrayList<>(); for (int i = 0; i < 20; i++) { data.add("Item " + i); } } @NonNull @Override public SimpleViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_simple, parent, false); return new SimpleViewHolder(view); } @Override public void onBindViewHolder(@NonNull SimpleViewHolder holder, int position) { holder.textView.setText(data.get(position)); } @Override public int getItemCount() { return data.size(); } } ``` 5. 创建RecyclerView ViewHolder类,用于展示每个item。 ```java public class SimpleViewHolder extends RecyclerView.ViewHolder { public TextView textView; public SimpleViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(R.id.text_view); } } ``` 6. 最后,在Activity中进行初始化和设置。 ```java public class MainActivity extends AppCompatActivity { private TabLayout tabLayout; private ViewPager viewPager; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); tabLayout = findViewById(R.id.tab_layout); viewPager = findViewById(R.id.view_pager); String[] titles = {"Tab 1", "Tab 2", "Tab 3"}; SimplePagerAdapter adapter = new SimplePagerAdapter(getSupportFragmentManager(), titles); viewPager.setAdapter(adapter); tabLayout.setupWithViewPager(viewPager); } } ``` 这样就完成了TabLayout+ViewPager+Fragmet+RecyclerView结合的小demo

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值