Android之ViewPager(引导界面)(0)
来源:互联网 发布:破解版java游戏大全 编辑:程序博客网 时间:2024/06/05 14:17
创造机会的人是勇者,等待机会的人是愚者。
本讲内容:ViewPager控件的用法
一、ViewPager的介绍
ViewPager如同容器可装载俩类东西,一种是View对象,另一种是Fragment。
将Layout布局转换为View对象的两种方式
1、LayoutInflater lf=getLayoutInflater().from(this);
lf.inflate(resource,root);
2、View.inflate(context,resource,root);
二、适配器(根据数据源可分为两类,一种View对象,另一种Fragment对象)
1、PagerAdapter 数据源:List<View> (第次加载三个页卡一组管理)
2、FragmentPagerAdapter 数据源:List<Fragment> (所有页卡都加载进去管理,不能销毁页卡,即每个页卡(Fragment)中的onDestroy()方法永远不能执行)
3、FragmentStatePagerAdapter 数据源:List<Fragment> (与2的区别,可动态销毁页卡)
三、使用步骤:
1、在布局文件里加入
<android.support.v4.view.ViewPager android:id="@+id/viewPager" android:layout_width="match_parent" android:layout_height="match_parent" /> <!-- 注意这个组件是用来显示左右滑动的界面的,如果不加载xml布局文件,他是不会显示内容的。 -->
2、加载要显示的页卡
3、需要一个适配器
示例一:
下面是res/layout/activity_main.xml 布局文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" > <android.support.v4.view.ViewPager android:id="@+id/id_viewPager" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true"/></RelativeLayout>
下面是res/layout/view1.xml 布局文件:(view2、view3类似)
<?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:orientation="vertical" > <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="第一个界面" android:gravity="center" android:textSize="30sp"/> </LinearLayout>
下面是ViewPagerAdapter.java文件:
public class ViewPagerAdapter extends PagerAdapter{private List<View> viewList;public ViewPagerAdapter(List<View> viewList) {this.viewList=viewList;}/** * 获得当前页卡的数量 */public int getCount() {return viewList.size();}/** * 判断视图是否由对象产生 */public boolean isViewFromObject(View arg0, Object arg1) {return arg0==arg1;}/** * 实例化页卡 */public Object instantiateItem(ViewGroup container, int position) {container.addView(viewList.get(position));return viewList.get(position);}/** * 删除页卡 */public void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewList.get(position));}}
下面是MainActivity.java主界面文件:
public class MainActivity extends Activity {private List<View> viewList;private ViewPager pager;private ViewPagerAdapter adapter;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);pager=(ViewPager) findViewById(R.id.id_viewPager);viewList=getData();adapter=new ViewPagerAdapter(viewList);pager.setAdapter(adapter);}/** * 数据源 */private List<View> getData(){viewList=new ArrayList<View>();/** * 通过View对象作为ViewPager的数据源 */View view1=View.inflate(this, R.layout.view1, null);View view2=View.inflate(this, R.layout.view2, null);View view3=View.inflate(this, R.layout.view3, null);viewList.add(view1);viewList.add(view2);viewList.add(view3);return viewList;}}
示例二:PagerTabStrip和PagerTitleStrp的用法(两者用法一样)
下面是res/layout/activity_main.xml 布局文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" > <android.support.v4.view.ViewPager android:id="@+id/id_viewPager" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" > <android.support.v4.view.PagerTabStrip android:id="@+id/id_tab" android:layout_width="wrap_content" android:layout_height="wrap_content" > </android.support.v4.view.PagerTabStrip> </android.support.v4.view.ViewPager></RelativeLayout>
下面是ViewPagerAdapter.java文件:
public class ViewPagerAdapter extends PagerAdapter{private List<View> viewList;private List<String> titleList;public ViewPagerAdapter(List<View> viewList,List<String>titleList) {this.viewList=viewList;this.titleList=titleList;}/** * 获得当前页卡的数量 */public int getCount() {return viewList.size();}/** * 判断视图是否由对象产生 */public boolean isViewFromObject(View arg0, Object arg1) {return arg0==arg1;}/** * 实例化页卡 */public Object instantiateItem(ViewGroup container, int position) {container.addView(viewList.get(position));return viewList.get(position);}/** * 删除页卡 */public void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewList.get(position));}/** * 页卡标题 */public CharSequence getPageTitle(int position) {return titleList.get(position);}}
下面是MainActivity.java主界面文件:
public class MainActivity extends Activity {private List<View> viewList;private List<String>titleList;private ViewPager pager;private ViewPagerAdapter adapter;private PagerTabStrip tab;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initViews();viewList=getData();adapter=new ViewPagerAdapter(viewList,titleList);pager.setAdapter(adapter);}/** * 初始化控件 */private void initViews() {pager=(ViewPager) findViewById(R.id.id_viewPager);tab=(PagerTabStrip) findViewById(R.id.id_tab);titleList=new ArrayList<String>();titleList.add("第一页");titleList.add("第二页");titleList.add("第三页");tab.setBackgroundColor(Color.YELLOW);tab.setTabIndicatorColor(Color.BLUE);tab.setDrawFullUnderline(false);//不显示分隔线tab.setTextColor(Color.RED);}/** * 数据源 */private List<View> getData(){viewList=new ArrayList<View>();/** * 通过View对象作为ViewPager的数据源 */View view1=View.inflate(this, R.layout.view1, null);View view2=View.inflate(this, R.layout.view2, null);View view3=View.inflate(this, R.layout.view3, null);viewList.add(view1);viewList.add(view2);viewList.add(view3);return viewList;}}
示例三:ViewPager装载Fragment
下面是Fragment1.java文件:(Fragment2、Fragment3类似)
public class Fragment1 extends Fragment {public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {View view = inflater.inflate(R.layout.view1, container, false);return view;}}
下面是MyFragmentPagerAdapter.java文件:
public class MyFragmentPagerAdapter extends FragmentPagerAdapter {private List<Fragment> fragments;private List<String> titleList;public MyFragmentPagerAdapter(FragmentManager fm,List<Fragment> fragments,List<String>titleList) {super(fm);this.fragments=fragments;this.titleList=titleList;}public Fragment getItem(int position) {return fragments.get(position); }public int getCount() {return fragments.size();}public CharSequence getPageTitle(int position) {return titleList.get(position);}}
下面是MainActivity.java主界面文件:
<pre class="java" name="code">public class MainActivity extends FragmentActivity implements OnPageChangeListener{private List<Fragment> fragList;private List<String> titleList;private ViewPager pager;private MyFragmentPagerAdapter adapter;private PagerTabStrip tab;protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initViews();fragList=getData();adapter=new MyFragmentPagerAdapter(getSupportFragmentManager(),fragList,titleList);pager.setAdapter(adapter);pager.setOnPageChangeListener(this);}/** * 初始化控件 */private void initViews() {pager=(ViewPager) findViewById(R.id.id_viewPager);tab=(PagerTabStrip) findViewById(R.id.id_tab);titleList=new ArrayList<String>();titleList.add("第一页");titleList.add("第二页");titleList.add("第三页");tab.setBackgroundColor(Color.YELLOW);tab.setTabIndicatorColor(Color.BLUE);tab.setDrawFullUnderline(false);//不显示分隔线tab.setTextColor(Color.RED);}/** * 数据源 */private List<Fragment> getData(){/** * 通过Fragment作为ViewPager的数据源 */fragList=new ArrayList<Fragment>();fragList.add(new Fragment1());fragList.add(new Fragment2());fragList.add(new Fragment3());return fragList;}//当滑动状态改变时调用 public void onPageScrollStateChanged(int state) {}//当前页面被滑动时调用 public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}//当新的页面被选中时调用 public void onPageSelected(int position) {Toast.makeText(this, "这是第"+(position+1)+"个界面", Toast.LENGTH_SHORT).show();}}
Take your time and enjoy it 要原码的、路过的、学习过的请留个言,顶个呗~~
- Android之ViewPager(引导界面)(0)
- Android之ViewPager(引导界面)(一)
- Android学习之界面篇(六)ViewPager学习与Android引导界面的实现
- Android UI设计(引导界面):ViewPager之界面添加底部圆点与循环显示
- Android之ViewPager+VideoView引导界面
- Android之ViewPager(仿微信引导界面以及动画效果 )(二)
- Android之ViewPager(仿人人网引导界面)(三)
- Android之ViewPager(实现应用程序只启动一次引导界面 )(四)
- Android UI设计(引导界面):ViewPager之二滑动切换效果
- Android UI设计(引导界面):ViewPager之三PagerTabStrip与PagerTitleStrip添加标题栏的区别
- Android UI设计(引导界面):ViewPager之三PagerTabStrip与PagerTitleStrip添加标题栏的区别
- Android通过ViewPager实现引导界面(一)
- Android客户端首次启动时的引导界面(viewpager)
- 【Android UI设计与开发】2.引导界面(二)使用ViewPager实现欢迎引导页面
- Android UI设计(引导界面):ViewPager之基本用法
- 引导界面(二)使用ViewPager实现欢迎引导页面
- Android之ViewPager引导页(动态加载指示器)
- Android复习之旅--ViewPager(应用引导页)
- C# 多线程文件读写整理总结
- Android之自定义Adapter的ListView
- 开源GIS软件初探
- 判断程序是否处于后台的方法
- Android 双缓冲技术
- Android之ViewPager(引导界面)(0)
- 如何理解中断的上半部和下半部
- linux下配置IP地址
- ERROR 2013 (HY000): Lost connection to MySQL server的解决方法
- 安卓屏幕适配(各种方案组合)
- ios学习笔记:从Java转ios项目总结
- 工厂方法模式(FactoryMethod)——创建型模式
- springmvc+mybatis 使用 POIFSFileSystem 读取excel中的日期 问题
- ListView的性能优化之convertView和viewHolder