关闭

Fragment和ViewPager的简单使用

标签: ViewPager和Fragment的简
154人阅读 评论(0) 收藏 举报
首先这是MainActivity的布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.myapplication.MainActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <TextView
            android:id="@+id/tv_current"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="正在上映"
            android:textColor="#f00"
            />

        <TextView
            android:id="@+id/tv_late"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:gravity="center"
            android:text="即将上映"
            />
    </LinearLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

    </android.support.v4.view.ViewPager>
</LinearLayout>

然后创建新的类继承Fragment
package com.example.myapplication;

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

/**
 * Created by 
 on 2017/1/3. */public class CuerrentFileFragment extends Fragment {    @Nullable    @Override    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {        TextView textView=new TextView(getActivity());        textView.setText("我是正在上线的界面");        return textView;    }}


在次创建一个新的类继承Fragment也可以直接粘贴
package com.example.myapplication;

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

/**
 * Created by  on 2017/1/3.
 */

public class LateFilmFragment extends Fragment {
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        TextView textView=new TextView(getActivity());
        textView.setText("我是即将上映的界面");

        return textView;
    }
}

最后我们来写一下MainActivity的代码

package com.example.myapplication;

import android.graphics.Color;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;

import org.w3c.dom.Text;

import java.util.ArrayList;

public class MainActivity extends FragmentActivity implements View.OnClickListener{
    ArrayList<TextView> viewList = new ArrayList<TextView>();

    private TextView tv_current;
    private TextView tv_late;
    private ViewPager viewpager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找控件
        initView();
        viewpager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {
            @Override
            public Fragment getItem(int position) {
                Fragment fragment = null;
                switch (position) {
                    case 0:
                        fragment = new CuerrentFileFragment();
                        break;
                    case 1:
                        fragment = new LateFilmFragment();
                        break;
                }
                return fragment;
            }

            @Override
            public int getCount() {

                return 2;
            }
        });
        viewpager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

            }

            @Override
            public void onPageSelected(int position) {
                //将字体变色
                for (int i = 0; i < viewList.size(); i++) {
                    TextView textView = viewList.get(i);
                    if (i == position) {
                        textView.setTextColor(Color.RED);
                    }else{
                        textView.setTextColor(Color.BLACK);
                    }
                }

            }

            @Override
            public void onPageScrollStateChanged(int state) {

            }
        });
    }

    private void initView() {
        viewpager = (ViewPager) findViewById(R.id.viewpager);
        tv_current = (TextView) findViewById(R.id.tv_current);
        tv_late = (TextView) findViewById(R.id.tv_late);
        viewList.add(tv_current);
        viewList.add(tv_late);
        for (int i=0;i<viewList.size();i++){
            viewList.get(i).setOnClickListener(this);
        }
    }

    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.tv_current:
                viewpager.setCurrentItem(0);
                break;
            case R.id.tv_late:
                viewpager.setCurrentItem(1);
        }
    }
}

0
0
查看评论

Android中Fragment和ViewPager那点事儿(仿微信APP)

在之前的博文《Android中使用ViewPager实现屏幕页面切换和引导页效果实现》和《Android中Fragment的两种创建方式》以及《Android中Fragment与Activity之间的交互(两种实现方式)》中我们介绍了ViewPager以及Fragment各自的使用场景以及不同的实现...
  • panhouye
  • panhouye
  • 2016-12-25 01:17
  • 1007

ViewPager和Fragment的组合使用

今天想看TabHost相关信息的时候,提示建议使用Fragment代替,然后就高出了下面的
  • u013758734
  • u013758734
  • 2014-06-10 16:11
  • 3240

ViewPager简单使用步骤

前言:感觉和listView使用一样。 1.xml文件中布局 2.Actvity中实例化ViewPager 3.自定义Adapter,这里具体实现稍有不同,也有些暂时不懂的地方 4.Adapter实例化,并填充到ViewPager 5.ViewPager事件监听 好了,直接上代码(本代码...
  • zinjin_woxin
  • zinjin_woxin
  • 2015-09-02 16:41
  • 2356

ViewPager和Fragment配合使用,以及它的Fragment生命周期分析

首先需要一个FragmentPagerAdapter。这个是Andbase下封装的一个Adapter源码。public class AbFragmentPagerAdapter extends FragmentPagerAdapter { /** The m fragment list. *...
  • kongxiuqi
  • kongxiuqi
  • 2016-05-03 14:18
  • 888

ViewPager+Fragment原来这么简单

我们在使用微信或是网易客户端的时候都会看到下面这样的效果,左右滑动切换页面,点击table栏也可以切换界面,以前看着感觉好高大上,今天用ViewPager和Fragment实现了一下,其实还是蛮好实现的 关键点: 1.viewPage的用法大家要掌握,主要就是设置适配器(.setAdapter()...
  • u014733374
  • u014733374
  • 2014-12-18 16:59
  • 8305

Android - Fragment+ViewPager结合使用

这篇作为详细回顾Fragment的最后一篇。 第一篇:http://blog.csdn.net/u014470702/article/details/48139579 为什么使用Fragment,Fragment的生命周期及各个生命期我们可以做的事,静态创建Fragment 第二篇:h...
  • u014470702
  • u014470702
  • 2015-09-04 09:33
  • 1287

ViewPager 从入门到带你撸个启动页之Fragment+ViewPager(二)

上一篇我们分享了ViewPager的基本用法后,相信大家对ViewPager的使用已经有比较清晰的认识了,这篇我们准备来使用官方推荐的Fragment+ViewPager组合来实现上一篇的效果。Fragment+ViewPager的基本用法1.FragmentPagerAdapter与Fragmen...
  • javazejian
  • javazejian
  • 2016-08-07 10:45
  • 5252

ViewPager + Fragment 这些坑你踩过吗?

1.ViewPager + Fragment,fragment 的页面不显示: 1.PullToReFreshView/ScrollView 嵌套ViewPager有冲突导致ViewPager高度变化,这一点和ScrollView包含ListView/GridView一个道理,在上一篇阐述过了。 2...
  • u010911576
  • u010911576
  • 2015-03-16 11:24
  • 1501

ViewPager(2):ViewPager与Fragment一起使用

FragmentPagerAdapterFragmentPagerAdapter继承自PagerAdapter ,主要用来展示多个Fragment页面,并且每一个Fragment都会被保存在FragmentManager中。 FragmentPagerAdapter最适用于那种少量且相对静态的页面。...
  • lj2012sy
  • lj2012sy
  • 2016-06-17 10:36
  • 880

使用ViewPager时,系统的Fragment 和支持包v4的Fragment二者传递对象不兼容

import android.app.Fragment;和import android.support.v4.app.Fragment;  两种Fragment的实现不一样,二者传递对象不兼容。 ViewPager时,需要使用了FragmentStatePagerAdapter,Fragm...
  • Buaaroid
  • Buaaroid
  • 2015-08-14 12:29
  • 3032
    个人资料
    • 访问:2674次
    • 积分:101
    • 等级:
    • 排名:千里之外
    • 原创:7篇
    • 转载:1篇
    • 译文:0篇
    • 评论:1条
    文章存档
    最新评论