新知识,新摘要:

效果图:framgent导入包都是v4包下,谨慎导入错误!

首先设置viewPager布局:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager1221"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_above="@+id/bottom">

    </android.support.v4.view.ViewPager>
    <LinearLayout
        android:id="@+id/bottom"
        android:layout_width="match_parent"
        android:layout_height="50dp"
       android:layout_alignParentBottom="true"
        android:background="@color/colorPurple"
        android:orientation="horizontal"
        >
        <TextView
            android:id="@+id/you"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="你好"
            android:textSize="20sp"
            android:gravity="center"
            />
        <View
            android:layout_width="1dp"
            android:layout_height="match_parent"
            android:background="#FFFFFF"></View>
        <TextView
            android:id="@+id/me"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="我好"
            android:textSize="20sp"
            android:gravity="center"
            />
        <View
            android:layout_width="1dp"
            android:layout_height="match_parent"
            android:background="#FFFFFF"></View>
        <TextView
            android:id="@+id/hei"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="大家好"
            android:textSize="20sp"
            android:gravity="center"
            />

    </LinearLayout>
</RelativeLayout>

其次设置子布局framgent:设置三个页面例如页面一

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/first"
        android:layout_width="match_parent"
        android:layout_height="50dp"
         android:text="第一个页面"
        android:textSize="30sp"
        android:gravity="center"
        android:background="@color/colorPurple"
        />
    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_below="@id/first"
        android:src="@mipmap/cute"/>

</RelativeLayout>

然后分别设置三个页面的framgent类继承Fragment类,列如第一页面:

package com.example.administrator.test_1216.framgent;

import com.example.administrator.test_1216.R;

public class OneFramgent1221 extends Fragment {
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        // 添加布局
        View v=inflater.inflate(R.layout.oneframgent1221_item,null);
        return v;
    }
}
其次设置adapter继承

package com.example.administrator.test_1216.adapter;

public class FramgentPagerAdapter1221 extends FragmentPagerAdapter{

    //声明集合
  private List<Fragment> list;
    public FramgentPagerAdapter1221(FragmentManager fm, List<Fragment> list) {
        super(fm);
        this.list = list;
    }

    @Override
    public Fragment getItem(int position) {
        return list.get(position);
    }

    @Override
    public int getCount() {
        return list.size();
    }
}
最后设置activity:代码思路:a、声明控件,绑定id,首先实现文字控件的颜色改变和监听;

              b、声明viewPager控件,绑定id,声明集合,将framgent类型的页面加入到list集合中

              c、初始化适配器,加载适配器;

              d、为viewPager设置监听,页面滚动切换页面时候文字发生颜色发生改变;

代码如下:

package com.example.administrator.test_1216;

public class FramgentPagerActivity1221 extends FragmentActivity implements View.OnClickListener, ViewPager.OnPageChangeListener {
    //声明控件
    private TextView you;
    private TextView me;
    private TextView hei;
    private int currentColor;
    private  int otherColor;
    private ViewPager viewpager1221;
    private FramgentPagerAdapter1221 adapter1221;
    List<Fragment> list;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.pagerviewframgent1221);
        currentColor=getResources().getColor(R.color.currentColor);
        otherColor=getResources().getColor(R.color.otherColor);
        intiview();
        andViewPager();
    }

    private void andViewPager() {
        viewpager1221= (ViewPager) findViewById(R.id.viewpager1221);
        //初始化集合
        list=new ArrayList<Fragment>();
        //添加页面到集合
        list.add(new OneFramgent1221());
        list.add(new TwoFramgent1221());
        list.add(new ThreeFramgent1221());
        //初始化适配器
        adapter1221=new FramgentPagerAdapter1221(getSupportFragmentManager(),list);
        viewpager1221.setAdapter(adapter1221);
        //设置每次启动软件时的显示页面
        viewpager1221.setCurrentItem(0);
        //设置viewpager的监听
        viewpager1221.setOnPageChangeListener(this);
    }

    private void intiview() {
        //绑定id
        you= (TextView) findViewById(R.id.you);
        me= (TextView) findViewById(R.id.me);
        hei= (TextView) findViewById(R.id.hei);
        //添加初始默认颜色
        you.setTextColor(currentColor);
        me.setTextColor(otherColor);
        hei.setTextColor(otherColor);
        //设置监听
        you.setOnClickListener(this);
        me.setOnClickListener(this);
        hei.setOnClickListener(this);
    }

    @Override
    public void onClick(View v) {
        //声明下标
        int index=0;
        switch (v.getId()){
            case R.id.you:
                you.setTextColor(currentColor);
                me.setTextColor(otherColor);
                hei.setTextColor(otherColor);
                index=0;
                break;
            case R.id.me:
                you.setTextColor(otherColor);
                me.setTextColor(currentColor);
                hei.setTextColor(otherColor);
                index=1;
                break;
            case R.id.hei:
                you.setTextColor(otherColor);
                me.setTextColor(otherColor);
                hei.setTextColor(currentColor);
                index=2;
                break;
        }
        // 为viewpager设置下标
        viewpager1221.setCurrentItem(index);
    }
//页面切换时候字体的颜色改变
    @Override
    public void onPageSelected(int position) {
        switch (position){
            case 0:
                you.setTextColor(currentColor);
                me.setTextColor(otherColor);
                hei.setTextColor(otherColor);
                break;
            case 1:
                you.setTextColor(otherColor);
                me.setTextColor(currentColor);
                hei.setTextColor(otherColor);
                break;
            case 2:
                you.setTextColor(otherColor);
                me.setTextColor(otherColor);
                hei.setTextColor(currentColor);
                break;
        }

    }
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }
}

ViewPager+Fragment实现页面的切换的更多相关文章

  1. ViewPager+PagerTabStrip实现页面的切换

    页面切换效果图 首先创建布局: 代码: <?xml version="1.0" encoding="utf-8"?><LinearLayout ...

  2. Android开发之利用ViewPager实现页面的切换(仿微信、QQ)

    这里利用ViewPager实现页面的滑动,下面直接上代码: 1.首先写一个Activity,然后将要滑动的Fragment镶嵌到写好的Activity中. Activity的布局文件:activity ...

  3. Android中使用ViewPager实现屏幕页面切换和页面切换效果

    之前关于如何实现屏幕页面切换,写过一篇博文<Android中使用ViewFlipper实现屏幕切换>,相比ViewFlipper,ViewPager更适用复杂的视图切换,而且Viewpag ...

  4. ViewPager -- Fragment 切换卡顿 性能优化

    当ViewPager切换到当前的Fragment时,Fragment会加载布局并显示内容,如果用户这时快速切换ViewPager,即 Fragment需要加载UI内容,而又频繁地切换Fragment, ...

  5. 【原创】【ViewPager+Fragment】ViewPager中切换界面Fragment被销毁的问题分析

    ViewPager中切换界面Fragment被销毁的问题分析   1.使用场景 ViewPager+Fragment实现界面切换,界面数量>=3   2.Fragment生命周期以及与Activ ...

  6. 转载【ViewPager+Fragment】ViewPager中切换界面Fragment被销毁的问题分析

    ViewPager中切换界面Fragment被销毁的问题分析  原文链接 http://www.cnblogs.com/monodin/p/3866441.html 1.使用场景 ViewPager+ ...

  7. ViewPager和View组合 实现页面的切换

    //--------------主页面------------------------------- package com.bw.test; import java.util.ArrayList;i ...

  8. Android - FragmentTabHost 与 Fragment 制作页面切换效果

    使用 FragmentTabHost 与 Fragment 制作页面切换效果 API 19 TabHost已经不建议使用了.用 FragmentTabHost 来代替TabHost.实际上 Fragm ...

  9. Android - TabHost 与 Fragment 制作页面切换效果

    Android - TabHost 与 Fragment 制作页面切换效果 Android API 19 , API 23 三个标签页置于顶端 效果图: 在文件BoardTabHost.java中定义 ...

随机推荐

  1. Spring Test+JUnit整合使用

    在做spring相关测试时比较麻烦,如果只用JUnit测试,需要没测有初始化一下applicationContext,效率比较底下,而且也有不足之处.具体见下文 导致多次Spring容器初始化问题 根 ...

  2. 让一个端口同时做两件事:http/https和ssh

    相信很多人都在YY:能不能让80端口分析连接协议,如果是http协议就让服务器交给http服务程序(如Apache.Nginx等)处理,如果是ssh协议就交给ssh服务程序(如OpenSSH Serv ...

  3. [ActionScript 3.0] 两个AIR之间的通信示例LocalConnection

    发送方AIR程序: package { import flash.display.DisplayObjectContainer; import flash.display.Sprite; import ...

  4. 从零开始系列--R语言基础学习笔记之一 环境搭建

    R是免费开源的软件,具有强大的数据处理和绘图等功能.下面是R开发环境的搭建过程. 一.点击网址 https://www.r-project.org/ ,进入"The R Project fo ...

  5. iOS开发 - OC - 实现本地数据存储的几种方式一

    iOS常用的存储方式介绍 在iOS App开发过程中经常需要操作一些需要持续性保留的数据,比如用户对于App的相关设置.需要在本地缓存的数据等等.本文针对OC中经常使用的一下存储方式做了个整理. 常用 ...

  6. PHP中对淘宝URL中ID提取

    <?php $taobao = 'taobao.com'; $tmall = 'tmall.com'; $guojitmall = 'tmall.hk'; $juhuasuan = 'ju.ta ...

  7. STL容器

    啦啦啦,今天听啦高年级学长讲的STL容器啦,发现有好多东西还是有必要记载的,毕竟学长是身经百战的,他在参加各种比赛的时候积累的经验可不是一天两天就能学来的,那个可是炒鸡有价值的啊,啊啊啊啊啊 #inc ...

  8. POS管理系统之出入库单分页查询

    JSP: <html>  <head>    <title>My JSP 'inOutKuPage.jsp' starting page</title> ...

  9. 1o_Samba

    ∮Linux下Samba的安装配置 §Linux 下文件共享软件 Samba 是一款实现跨主机,跨平台文件共享的软件.同类型的软件还有 ftp,nfs 不再赘述. §文件共享协议 Windows : ...

  10. Web前端入门必学知识

    入门主要有三个部分   一.html+css部分:      1.前端的入门门槛极低,体现在HTML和CSS上运行环境就是浏览器,html+css这部分特别简单,网上搜资料,书籍视频非常多.css中盒 ...