android实现tab切换效果
2016-03-30 20:41
387 查看
一:利用ViewPager实现Tab切换效果
1.首先新建几个要切换的xml布局文件,然后在主布局中间添加<android.support.v4.view.ViewPager>布局,用于显示我们写好的xml布局。
2.在主方法中,定添加代码如下:LayoutInflater mInflater = LayoutInflater.from(this);View tab01 = mInflater.inflate(R.layout.tab01, null);mViews.add(tab01);其中的mView代表我们list数据源。
3.实现PagerAdapter()适配器,注意要重写其中的destroyItem方法,在里面实现container.removeView(mViews.get(position)); 在public Object instantiateItem(ViewGroup
container, int position)方法中获取当前显示的view,并将其添加到ViewGroup中。
4.设置前面实现的适配器,然后添加按钮的点击时间,将其与我们活动的ViewPager绑定, 这样只有当我们点击按钮,或是滑动按钮时的按钮颜色变化;最后需要添加一个setOnPageChangeListener的方法来监听ViewPager的活动。主要是在public void
onPageSelected(int arg0)方法中实现逻辑代码。
5.综上所述,利用利用ViewPager实现Tab切换效果实现思路基本完成。具体代码参考:
2.新建几个类,一个布局对应一个类,用于加载我们的布局。该类需要继承 Fragment,然 后重写public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle
savedInstanceState){ return inflater.inflate(R.layout.tab04, container, false); },其中 的R.layout.tab04对应我们前面写好的xml布局文件。
3.将继承自AppActivity 的 MainActivity改成继承FragmentActivity 。
4.获取之前写好的类并显示出来,具体的逻辑代码如下:
FragmentManager fm = getSupportFragmentManager();//获取FragmentManage对象
FragmentTransaction transaction = fm.beginTransaction();//通过FragmentManage对象,获 取FragmentTransaction对象。
Fragment mTab01 = new WeixinFragment(); //实例化前面写好的类 (WeixinFragment()对应一个xml布局文件,在之前我们已经写好)
transaction.add(R.id.id_content, mTab04); //显示xml布局文件到指定的id控件中
transaction.commit(); //最后不要忘了commit一下我们的事物。
5.设置按钮与Fragment 想呼应,可以通过按钮切换view。具体代码比较简单,可以参考:
Ps:在这里我不得不得提醒一次,在导入包的时候,我们一定要慎重,如果我们Fragment的包倒的是android.support.v4.app.Fragment;,后面的.FragmentManager,FragmentTransaction,FragmentActivity;全部都要导入android.support.v4.app这个下面的
子包。不然就会出错。保持包的一致,保持包的一致,保持包的一致。重要的事情说三 篇。
2.与前面的第二步一致,再次不做赘述。
3. MainActivity仍然需要继承FragmentActivity。
4.创建FragmentPagerAdapter适配器和添加Fragmenl到list中,主要实现逻辑代码。
新建一个List 将前面写好的类实例化并且添加到list当中来。然后在 FragmentPagerAdapter适配器中重写public Fragment getItem(int arg0)和public int
getCount()方法,用于返回当前选中的FragmentItem和Fragmentcount.
5.添加OnPageChangeListener的监听器,通过重写 public void onPageSelected(int arg0)方 法按钮相绑定。
6.添加按钮的监听事件,实现与相交互。具体代码参考:https://github.com/Reoger/frament_view.git
(ps:最后我还是想说一句,在导入Fragment相对应的包的时候,一定只能导入一个包下的子包。)
1.首先新建几个要切换的xml布局文件,然后在主布局中间添加<android.support.v4.view.ViewPager>布局,用于显示我们写好的xml布局。
2.在主方法中,定添加代码如下:LayoutInflater mInflater = LayoutInflater.from(this);View tab01 = mInflater.inflate(R.layout.tab01, null);mViews.add(tab01);其中的mView代表我们list数据源。
3.实现PagerAdapter()适配器,注意要重写其中的destroyItem方法,在里面实现container.removeView(mViews.get(position)); 在public Object instantiateItem(ViewGroup
container, int position)方法中获取当前显示的view,并将其添加到ViewGroup中。
4.设置前面实现的适配器,然后添加按钮的点击时间,将其与我们活动的ViewPager绑定, 这样只有当我们点击按钮,或是滑动按钮时的按钮颜色变化;最后需要添加一个setOnPageChangeListener的方法来监听ViewPager的活动。主要是在public void
onPageSelected(int arg0)方法中实现逻辑代码。
5.综上所述,利用利用ViewPager实现Tab切换效果实现思路基本完成。具体代码参考:
二:利用Fragment实现Tab切换效果(不能滑动)
1.首先仍然需要新建需要切换的xml布局文件,然后在主布局中添加FrameLayout 以显示前 面写好的布局文件。2.新建几个类,一个布局对应一个类,用于加载我们的布局。该类需要继承 Fragment,然 后重写public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle
savedInstanceState){ return inflater.inflate(R.layout.tab04, container, false); },其中 的R.layout.tab04对应我们前面写好的xml布局文件。
3.将继承自AppActivity 的 MainActivity改成继承FragmentActivity 。
4.获取之前写好的类并显示出来,具体的逻辑代码如下:
FragmentManager fm = getSupportFragmentManager();//获取FragmentManage对象
FragmentTransaction transaction = fm.beginTransaction();//通过FragmentManage对象,获 取FragmentTransaction对象。
Fragment mTab01 = new WeixinFragment(); //实例化前面写好的类 (WeixinFragment()对应一个xml布局文件,在之前我们已经写好)
transaction.add(R.id.id_content, mTab04); //显示xml布局文件到指定的id控件中
transaction.commit(); //最后不要忘了commit一下我们的事物。
5.设置按钮与Fragment 想呼应,可以通过按钮切换view。具体代码比较简单,可以参考:
Ps:在这里我不得不得提醒一次,在导入包的时候,我们一定要慎重,如果我们Fragment的包倒的是android.support.v4.app.Fragment;,后面的.FragmentManager,FragmentTransaction,FragmentActivity;全部都要导入android.support.v4.app这个下面的
子包。不然就会出错。保持包的一致,保持包的一致,保持包的一致。重要的事情说三 篇。
三:利用Fragment实现Tab切换效果(可以滑动)
1.首先仍然需要新建需要切换的xml布局文件,然后在主布局中添加android.support.v4.view.ViewPager以显示前面写好的布局文件。2.与前面的第二步一致,再次不做赘述。
3. MainActivity仍然需要继承FragmentActivity。
4.创建FragmentPagerAdapter适配器和添加Fragmenl到list中,主要实现逻辑代码。
新建一个List 将前面写好的类实例化并且添加到list当中来。然后在 FragmentPagerAdapter适配器中重写public Fragment getItem(int arg0)和public int
getCount()方法,用于返回当前选中的FragmentItem和Fragmentcount.
5.添加OnPageChangeListener的监听器,通过重写 public void onPageSelected(int arg0)方 法按钮相绑定。
6.添加按钮的监听事件,实现与相交互。具体代码参考:https://github.com/Reoger/frament_view.git
(ps:最后我还是想说一句,在导入Fragment相对应的包的时候,一定只能导入一个包下的子包。)
相关文章推荐
- ubuntu 14.04系统 Android 4.0.1 源码编译过程
- Android学习--AsyncTask工具
- 爱加密Android APk 原理解析
- Android实现“打招呼”
- (4.6.8)Android性能调优
- (4.6.7)Android性能调优工具TraceView介绍
- Android Studio下如何配置AIDL文件并生成java文件
- (4.6.4)性能优化之Java(Android)代码优化
- android动画详解六 XML中定义动画
- android studio 初体验
- android 使用LinearGradient进行字体渐变的效果
- 关于安卓异步加载Asynctask的学习笔记
- android手机安全性测试手段
- android中锁屏后代码不运行的问题
- android配置selector需要注意的点
- 【Android】获取一个uri的资源的真实路径
- android基础学习之一个简单的歌词滚动软件的实现
- BaseAdapter用法详解
- AndroidStudio常用快捷键
- android 图像渲染(Shader)