使用Fragment实现的滑动组件ViewPager
来源:互联网 发布:c语言程序视频教程 编辑:程序博客网 时间:2024/05/16 12:00
- 1适配器FragmentPagerAdapter的实现
- 2两个Fragment类
- OrderFragmentjava
- fragment_orderxml
- MeFragmentjava
- fragment_mexml
- OrderFragmentjava
- 3主activity实现
- activity_mainxml
1适配器FragmentPagerAdapter的实现
对于FragmentPagerAdapter的派生类,只需要重写getItem(int)和getCount()就可以了。
public class MyFragmentPagerAdapter extends FragmentPagerAdapter { private List<Fragment> list; public MyFragmentPagerAdapter(FragmentManager fm, List<Fragment> list) { super(fm); this.list = list; } //返回了当前要滑动的View的个数 @Override public int getCount() { return list.size(); } //在getItem(int arg0)中,根据传来的参数arg0,来返回当前要显示的fragment @Override public Fragment getItem(int arg0) { return list.get(arg0); }}
2两个Fragment类
OrderFragment.java
public class OrderFragment extends Fragment { //在onCreateView()中返回要显示的View @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // TODO Auto-generated method stub View view= inflater.inflate(R.layout.fragment_order, container, false); //View中控件的操作方法 refresh = view.findViewById(R.id.order_count_refresh); refresh.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //操作逻辑 countStatus(); } }); return view; }}
fragment_order.xml
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" android:orientation="vertical" > <Button android:id="@+id/fragment1_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="show toast" /></LinearLayout>
MeFragment.java
public class MeFragment extends Fragment { //在onCreateView()中返回要显示的View @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // TODO Auto-generated method stub View view= inflater.inflate(R.layout.fragment_me, container, false); //View中控件的操作方法 login = view.findViewById(R.id.me_login); login.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { startActivity(new Intent(MeFragment.this.getActivity(), LoginActivity.class)); } }); return view; }}
fragment_me.xml
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffff00" android:orientation="vertical" ></LinearLayout>
3主activity实现
public class MainActivity extends FragmentActivity { private ViewPager mPager; private List<Fragment> fragmentList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mPager = (ViewPager) findViewById(R.id.viewpager); //初始化fragment List<Fragment> fragmentList=new ArrayList<Fragment>(); fragmentList.add(new OrderFragment()); fragmentList.add(new MeFragment()); FragAdapter adapter = new FragAdapter(getSupportFragmentManager(), fragments); //给ViewPager设置适配器 mPager.setAdapter(new MyFragmentPagerAdapter(getSupportFragmentManager(), fragmentList)); mPager.setCurrentItem(0);// 设置当前显示标签页为第一页 //MyOnPageChangeListener()是页面变化监听器 mPager.setOnPageChangeListener(new MyOnPageChangeListener()); radioGroup = (RadioGroup) findViewById(R.id.main_tab); //给radioGroup设置监听器 radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { @Override public void onCheckedChanged(RadioGroup group, int checkedId) { if(checkedId == R.id.tab_me){ mPager.setCurrentItem(INDEX_ME); }else if(checkedId == R.id.tab_shoujian){ mPager.setCurrentItem(INDEX_SHOUJIAN); } } }); } //实现页面变化监听器OnPageChangeListener public class MyOnPageChangeListener implements OnPageChangeListener { @Override //当页面在滑动的时候会调用此方法,在滑动被停止之前,此方法会一直得到调用。 /** * arg0:当前页面,及你点击滑动的页面 * arg1:当前页面偏移的百分比 *arg2:当前页面偏移的像素位置 */ public void onPageScrolled(int arg0, float arg1, int arg2) { // TODO Auto-generated method stub } @Override //当页面状态改变的时候调用 /** * arg0 * 1:表示正在滑动 * 2:表示滑动完毕 * 0:表示什么都没做,就是停在那 */ public void onPageScrollStateChanged(int arg0) { // TODO Auto-generated method stub } @Override //页面跳转完后调用此方法 /** * arg0是页面跳转完后得到的页面的Position(位置编号)。 */ public void onPageSelected(int arg0) { // TODO Auto-generated method stub switch (arg0) { case INDEX_ME: radioGroup.check(R.id.tab_me); break; case INDEX_SHOUJIAN: radioGroup.check(R.id.tab_shoujian); break; } } }}
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android"> <android.support.v4.view.ViewPager android:id="@+id/viewpager" android:layout_alignParentTop="true" android:layout_width="fill_parent" android:layout_height="match_parent" android:layout_gravity="center" android:layout_marginBottom="60dip" android:flipInterval="30" android:persistentDrawingCache="animation"/> <RadioGroup android:id="@+id/main_tab" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_alignParentBottom="true" android:layout_height="60dip"> <RadioButton style="@style/main_tab" android:id="@+id/tab_shoujian" <!--图片在文字的上面--> android:drawableTop="@drawable/tab_shoujian_selector" android:layout_height="match_parent" android:checked="true" android:text="****" /> <RadioButton style="@style/main_tab" android:id="@+id/tab_me" android:drawableTop="@drawable/tab_me_selector" android:layout_height="match_parent" android:text="*" /> </RadioGroup> </RelativeLayout>
0 0
- 使用Fragment实现的滑动组件ViewPager
- 使用Fragment实现ViewPager滑动
- ViewPager -----使用Fragment实现ViewPager滑动
- 使用FragmentTabHost+Fragment+viewpager 实现滑动分页
- 使用FragmentTabHost+Fragment+viewpager 实现滑动分页
- android 使用Fragment实现ViewPager滑动
- 使用FragmentTabHost+Fragment+viewpager 实现滑动分页
- ViewPager+Fragment 实现滑动页面的效果
- Viewpager+Fragment实现页面的滑动
- ViewPager+Fragment的实现及禁止滑动
- ViewPager+Fragment+TabLayout实现的头部滑动
- ViewPager+Fragment的实现及禁止滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- ViewPager 详解(五)-----使用Fragment实现ViewPager滑动
- 即将到来的Daydream是个什么鬼
- popwindow 设置好了以后不显示的问题
- js 实现拷贝页面文本数据时,给文本结尾添加文本的出处”<p>这段文本来自我的js练习</p>”。
- 【Linux】进程间通信的几种方式(1)
- 华为交换机SPAN端口镜像
- 使用Fragment实现的滑动组件ViewPager
- Webview的使用和注意事项
- 编写高质量的代码——从命名入手
- kvm设置桥接网卡
- 【Dev Club 分享第三期】iOS 黑客技术大揭秘
- JAVA几种缓存技术介绍说明
- 带指示器的seekbar
- 关于fragment监听回退的问题
- 交叉编译tcpdump