Android之实现ViewPager+Fragment左右滑动
来源:互联网 发布:手机淘宝购物车点不动 编辑:程序博客网 时间:2024/05/23 19:19
最近看新闻发现新闻的页面是可以左右滑动的,于是自己就好奇起来了,之前做过ViewPager展示图片,在想怎么加载页面呢?研究了一下,发现就是添加了Fragment,废话不多说,揭秘奥秘的时候到了。
使用过ViewPager小伙伴们都知道,Viewpager加载数据,需要数据源,这里我们定义4个Fragment。为了方便其他同事使用,我给这4个Fragment添加了一个基类,具体代码如下:
public abstract class BaseFragment extends Fragment { public Context mContext;//上下文 private View mView; @Override public void onActivityCreated(Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); initData(savedInstanceState); } @Override public void onCreate(Bundle savedInstanceState) { mContext = getActivity(); super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) { mView = initView(inflater); return mView; } /** * 初始化界面 */ public abstract View initView(LayoutInflater inflater); /** * 初始化数据 */ public abstract void initData(Bundle savedInstanceState);}
里面我添加了2个方法,一个是初始化界面,一个初始化数据,这样其他Fragment继承该类实现其两种方法,我们看一下其中一个Fragment里面的代码:
public class WeiFragment extends BaseFragment { @Override public View initView(LayoutInflater inflater) { //添加页面布局 View view = inflater.inflate(R.layout.fragment_weixin, null); return view; } @Override public void initData(Bundle savedInstanceState) { }}
这样其他同事就知道该如何处理数据了。在主页面,我们只要做两件事,一是把数据给Viewpager,另一件事则是要使下面的tab可以控制页面变化。下面是传递数据的代码:
//添加数据 list = new ArrayList<BaseFragment>(); list.add(new WeChatFragment()); list.add(new FriendFragment()); list.add(new AddressFragment()); list.add(new SettingFragment());
然后我们需要给ViewPager绑定一个适配器。针对Fragment的adapter,Google提供了专用的FragmentPagerAdapter。具体代码如下:
public class FragmentAdapter extends FragmentPagerAdapter { private List<BaseFragment> list; public FragmentAdapter(FragmentManager fm, List<BaseFragment> list) { super(fm); this.list = list; } //得到数据 @Override public Fragment getItem(int position) { return list.get(position); } @Override public int getCount() { return list.size(); }}
最后我们要把适配器绑定到ViewPager上面;
//绑定适配器 adapter = new FragmentAdapter(getFragmentManager(), list); mViewPager.setAdapter(adapter);
第二件事就是处理tab改变页面变化,这里我们给tab设置了编号,根据编号来处理tab显示页面的问题,这里就不贴代码了,具体请看demo。
效果图如下:
项目源码
如有疑问,可以给我留言,多多交流。谢谢!
6 1
- Android之实现ViewPager+Fragment左右滑动
- Fragment+ViewPager实现左右滑动
- android 学习之Fragment+ViewPager实现页面左右滑动标签页
- ViewPager结合Fragment实现页面左右滑动
- ViewPager+Fragment实现左右滑动页
- AppBarLayout、ViewPager、Fragment实现页面左右滑动
- Viewpager+Fragment实现左右滑动切换页面
- ViewPager左右滑动Fragment
- Fragment+ViewPager 左右滑动 Demo
- android 使用ViewPager实现左右滑动
- Android使用ViewPager实现左右滑动效果
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- Android ActionBar+ViewPager 实现左右滑动Tab
- 【Android开发】ViewPager实现左右循环滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- Android ActionBar+ViewPager 实现左右滑动Tab
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- android ViewPager,ViewFlipper,ViewFlow实现左右滑动
- Scrapy如何借助于BloomFilter实现增量爬取
- 一些小知识点的累积
- Swift 传值之单例传值
- 2016流行这2种色彩!附优秀网页设计案例
- Android NDK Eclipse Build Error: Unable to rename file. Reason: File exists
- Android之实现ViewPager+Fragment左右滑动
- iOS 学习日志 : git使用
- 解决 PermGen space Tomcat内存设置
- codeforces587C Duff in the Army
- Swift 可选链
- Oracle 字符集的查看和修改
- 如何查看端口是否被占用
- 不拖后腿!从3个方面聊聊2016年的UI设计新趋势
- VS中如何添加自定义代码片段——偷懒小技巧