TabLayou+fragment+viewpager实现滑动切换页面
来源:互联网 发布:莱昂纳德防守知乎 编辑:程序博客网 时间:2024/05/18 01:52
在android studio中添加依赖
com.android.support:design:23.2.1
TabLayou 主要实现的是标题头的 滑动 这个 控件 类似于 ScrollView ##
XML中的布局
<LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" > <android.support.design.widget.TabLayout android:id="@+id/homefragment_tablelayouts" android:layout_width="0dp" android:layout_height="30dp" app:tabIndicatorHeight="2dp" android:layout_weight="1" app:tabIndicatorColor="@color/colorred" app:tabSelectedTextColor="#000000" app:tabMode="scrollable" > </android.support.design.widget.TabLayout> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/add_channel_titlbar_new" /> </LinearLayout> <android.support.v4.view.ViewPager android:layout_weight="1" android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/homefragment_vp" ></android.support.v4.view.ViewPager>
以下是代码的实现
//定义一个方法 public void getVpTitleData() { // 找到 TabLayou 控件 TabLayout mTabLayout= (TabLayout) getView().findViewById(R.id.homefragment_tablelayouts); // 找到 ViewPager 控件 ViewPager mViewPager= (ViewPager) getView().findViewById(R.id.homefragment_vp); //定义 title 集合 来存储 解析的data数据 listtitle = new ArrayList<>(); listtitle .add("头条"); listtitle .add("社会"); listtitle .add("国内"); listtitle .add("国际"); listtitle .add("明星"); listtitle .add("娱乐"); listtitle .add("军事"); listtitle .add("财经"); listtitle .add("时尚"); listtitle .add("八卦"); //遍历 listtitle 集合 将title 添加经 TabLayou z中 for (int i = 0; i <listtitle.size() ; i++) { mTabLayout.addTab(mTabLayout.newTab().setText(listtitle.get(i))); } //创建集合 循环添加创建的Fragment listfragment = new ArrayList<>(); for (int i = 0; i <date.size() ; i++) { BeiJingFragment mjingFragment = new BeiJingFragment(); listfragment.add(mjingFragment); } HomeFragmentVPFragmentAdapter mAdapter = new HomeFragmentVPFragmentAdapter(getFragmentManager(),listfragment,listtitle); //给ViewPager设置适配器 mViewPager.setAdapter(mAdapter); //将TabLayout和ViewPager关联起来。 mTabLayout.setupWithViewPager(mViewPager); //给TabLayout设置适配器 mTabLayout.setTabsFromPagerAdapter(mAdapter); }
ViewPager与Fragment的适配器
public class HomeFragmentVPFragmentAdapter extends FragmentStatePagerAdapter { List<Fragment> listfragment; List<String> listtitle; public HomeFragmentVPFragmentAdapter(FragmentManager fm, List<Fragment> listfragment, List<String> listtitle) { super(fm); this.listfragment = listfragment; this.listtitle = listtitle; } @Override public CharSequence getPageTitle(int position) { return listtitle.get(position); } @Override public Fragment getItem(int position) { return listfragment.get(position); } @Override public int getCount() { return listfragment.size(); }}
效果图
http://blog.csdn.net/itachi85/article/details/50412332
阅读全文
0 0
- TabLayou+fragment+viewpager实现滑动切换页面
- fragment+viewpager+tablayou实现滑动切换页面
- Viewpager+Fragment实现左右滑动切换页面
- Fragment嵌套Fragment, TabLayout + ViewPager实现页面切换滑动
- ActionBarSherlock与Fragment及ViewPager结合实现滑动切换页面
- ViewPager+Fragment+广播来实现一个滑动页面切换
- Android ViewPager加Fragment实现滑动或者点击页面切换
- ViewPager+Fragment实现滑动页面
- ViewPager+Fragment实现滑动页面
- ViewPager + Fragment 实现页面滑动
- Fragment + ViewPager实现滑动页面
- Fragment+viewpager切换滑动页面Demo
- viewpager+fragment左右滑动切换页面
- ViewPager实现滑动切换页面
- ViewPager+Fragment实现页面切换
- Viewpager+Fragment实现页面切换
- viewpager+Fragment实现简单滑动切换效果
- Viewpager+Fragment 实现滑动切换显示内容
- crontab计划任务
- Lagrange 插值
- spark并行度和partion联系
- Spring事务管理
- 进程和线程
- TabLayou+fragment+viewpager实现滑动切换页面
- Servlet.service() for servlet jsp threw exception页面加载出现空指针异常
- lua异常处理机制xpcall
- jquery表单验证
- [svc]证书的生成和各个字段的含义
- hdu 1020 Encoding
- eclipse复制工作空间配置
- 22.数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果
- SAP FICO Training Tutorial: Learn SAP FI & SAP CO Modules