效果图:

文件夹结构:

代码分析:

MainActivity.java

package com.example.myfragment;

/**
* @author Arthur Lee
* @time 04/08/2014
* */
import java.util.ArrayList; import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.LinearLayout;
import android.widget.RadioButton; import com.fragment.FirstFragment;
import com.fragment.FourthFragment;
import com.fragment.SecondFragment;
import com.fragment.ThirdFragment; public class MainActivity extends FragmentActivity { ArrayList<Fragment> fragment;
public static ViewPager viewpager;
public static ArrayList<RadioButton> rb;
LinearLayout lLayout;
// ViewPager的适配器。但为了和Fragment相结合。要自己定义适配器
MyAdapter adapter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
initButton();
initAdapter(); } public void initView() {
viewpager = (ViewPager) findViewById(R.id.main_viewpager);
lLayout = (LinearLayout) findViewById(R.id.zone_rbt);
fragment = new ArrayList<Fragment>();
fragment.add(new FirstFragment());
fragment.add(new SecondFragment());
fragment.add(new ThirdFragment());
fragment.add(new FourthFragment());
} public void initAdapter() {
adapter = new MyAdapter(getSupportFragmentManager(), fragment);
viewpager.setAdapter(adapter);
viewpager.setOnPageChangeListener(myOnPageChangeListener);
// 默认显示的页面
viewpager.setCurrentItem(0);
rb.get(0).setChecked(true); } public void initButton() {
rb = new ArrayList<RadioButton>();
rb.add((RadioButton) findViewById(R.id.rb_first));// 1号
rb.add((RadioButton) findViewById(R.id.rb_second));// 2号
rb.add((RadioButton) findViewById(R.id.rb_third));// 3号
rb.add((RadioButton) findViewById(R.id.rb_fourth));// 4号
for (int i = 0; i < rb.size(); i++) {
rb.get(i).setOnClickListener(new MyListener(i));
}
} public class MyListener implements OnClickListener {
private int index; public MyListener(int index) {
this.index = index;
} @Override
public void onClick(View v) {
viewpager.setCurrentItem(index);
rb.get(index).setChecked(true);
} } OnPageChangeListener myOnPageChangeListener = new OnPageChangeListener() { // 页卡状态改变时候。
@Override
public void onPageScrollStateChanged(int arg0) {
Log.i("Main", "onPageScrollStateChanged"); } // 页卡切换过程中
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
Log.i("Main", "onPageScrolled");
} // 当radioButton被选中
@Override
public void onPageSelected(int position) { Log.i("Main", "onPageSelected");
rb.get(position).setChecked(true);
}
}; }

MyAdapter.java

package com.example.myfragment;

import java.util.ArrayList;

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter; public class MyAdapter extends FragmentPagerAdapter {
private ArrayList<Fragment> fragment; public MyAdapter(FragmentManager fm) {
super(fm);
// TODO Auto-generated constructor stub
} public MyAdapter(FragmentManager fm, ArrayList<Fragment> fragment) {
super(fm);
// TODO Auto-generated constructor stub
this.fragment = fragment;
} @Override
public Fragment getItem(int position) {
// TODO Auto-generated method stub
return fragment.get(position);
} @Override
public int getCount() {
// TODO Auto-generated method stub
return fragment.size();
} }

FirstFragment.java

package com.fragment;
/**
* @author Arthur Lee
* @time 04/08/2014
* */
import com.example.myfragment.R; import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup; public class FirstFragment extends Fragment{
//缓存视图
private View view; @Override
public void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
} @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// TODO Auto-generated method stub
//假设当前视图为空,初始化视图
if(view == null){
//指定当前视图在viewpager中显示的是view_first。xml,通过LayoutInflater来指定.
view = inflater.inflate(R.layout.view_first, null);
}
//指定当前视图的父类,以便调用父类的移除功能。 ViewGroup parent = (ViewGroup) view.getParent();
if (parent != null) {
parent.removeView(view);
} return view;
}
}

其它的三个与这个类似。不再提供。

以下是布局文件

main_activity.xml

<LinearLayout 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:orientation="vertical"
tools:context=".MainActivity" > <!-- 纵向分布两个,以AB标记 --> <!-- A --> <LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1" > <android.support.v4.view.ViewPager
android:id="@+id/main_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</android.support.v4.view.ViewPager>
</LinearLayout>
<!-- B --> <LinearLayout
android:id="@+id/zone_rbt"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="6"
android:orientation="horizontal" > <RadioGroup
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="horizontal" > <RadioButton
android:id="@+id/rb_first"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="@android:color/holo_blue_light"
android:text="1号" /> <RadioButton
android:id="@+id/rb_second"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="@android:color/holo_green_light"
android:text="2号" /> <RadioButton
android:id="@+id/rb_third"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="@android:color/holo_blue_light"
android:text="3号" /> <RadioButton
android:id="@+id/rb_fourth"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:background="@android:color/holo_green_light"
android:text="4号" />
</RadioGroup>
</LinearLayout> </LinearLayout>

view_first.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:orientation="vertical" >
<!-- @author Arthur Lee -->
<TextView
android:id="@+id/view_first"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="第一页面"
android:textSize="20sp" /> </LinearLayout>

这一类的其他三个布局文件似。它不再可用。

版权声明:本文博主原创文章,博客,未经同意不得转载。

兔子--Fragment与ViewPager要切换滑动效果的更多相关文章

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

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

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

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

  3. 使用ViewPager实现屏幕滑动效果

    oncreate中设置viewPager viewPager.setPageTransformer(true,new DepthPageTransformer());//设置页面过滤动画效果 page ...

  4. android SlidingTabLayout实现ViewPager页卡滑动效果

    先来张效果图(能够滑动切换页卡) watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcGVuZ2t2/font/5a6L5L2T/fontsize/400/fi ...

  5. Fragment利用ViewPager实现左右滑动--第三方开源--SlidingTabLayout和SlidingTabStrip实现

    MainActivity: package com.zzw.fragmentteb; import java.util.ArrayList; import android.graphics.Color ...

  6. 011 Android TabLayout+ViewPager实现顶部滑动效果(多个页面)

    1.TabLayout介绍 TabLayout提供了一个水平的布局用来展示Tabs,很多应用都有这样的设计,典型的有网易新闻,简书,知乎等.TabLayout就可以很好的完成这一职责,首先TabLay ...

  7. 使用ViewPager实现广告滑动效果

    效果图:               watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvSk1DNjAx/font/5a6L5L2T/fontsize/400/ ...

  8. Android典型界面设计——FragmentTabHost+Fragment实现底部tab切换

    一.问题描述 在上次博文中,我们使用RadioGroup+ViewPage+Fragmen实现了顶部滑动导航(查看文章:http://www.cnblogs.com/jerehedu/p/460759 ...

  9. Android——ViewPager多页面滑动切换以及动画效果

    一.首先,我们来看一下效果图,这是新浪微博的Tab滑动效果.我们可以手势滑动,也可以点击上面的头标进行切换.与此同方式,白色横条会移动到相应的页卡头标下.这是一个动画效果,白条是缓慢滑动过去的.好了, ...

随机推荐

  1. PHP+lghttpd + postgresql 环境搭建

    PHP+lghttpd + postgresql 环境搭建 Linux 下PHP环境搭建 安装环境:PHP+lghttpd + postgresql 1:yum install lighttpd 红旗 ...

  2. jTDS驱动兼容性问题

    Java连接SQL Server 2000数据库时,有两种方法: (1)通过Microsoft的JDBC驱动连接.此JDBC驱动共有三个文件,分别是mssqlserver.jar.msutil.jar ...

  3. Unity3D 游戏开发构架篇 ——输入控制

    临近毕业之初.进入Unity3D这个行业,是一家小工作室.老板人非常不错,公司氛围也非常单纯.近期公司开发一款小游戏,初次上手,颇多周折,记录下自己的开发心得.主要涉及一些设计理念,互相交流. 先说下 ...

  4. MVC之国际化

    MVC之国际化 前言 在项目中遇到国际化语言的问题是常有的事情,之前在做关于MVC国际化语言时,刚开始打算全部利用AngularJS来实现,但是渐渐发现对于页面Title难以去控制其语言转换,于是对于 ...

  5. 创建android画笔程序的样例(有镜面效果)

    先上图: 关键是在检測到手指移动的时候用mPath.quadTo的方法,android sdk解释是: Add a quadratic bezier from the last point, appr ...

  6. [置顶] CentOS release 5.4 (Final)重置root密码(图文)

  7. Mars之android的Handler(2)

    handler .looper.messageque的关系在前面已经有个介绍,但前面handler(1)中handler的使用是极少的一种情况,因为handler.sendMessage()可以在Ma ...

  8. vim php代码规范

    vim 代码规范工具php-cs-fixer.phar (參考https://github.com/FriendsOfPHP/PHP-CS-Fixer) INSTALL curl http://get ...

  9. HDU 3699 A hard Aoshu Problem (暴力搜索)

    题意:题意:给你3个字符串s1,s2,s3;要求对三个字符串中的字符赋值(同样的字符串进行同样的数字替换), 替换后的三个数进行四则运算要满足左边等于右边.求有几种解法. Sample Input 2 ...

  10. TBDR缺点

    TBDR全称Tile-based Deferred Rendering.它是Power VR独特的TBR技术的一种延伸实现手段.TBR/TBDR通过将每一帧画面划分成多个矩形区域,并对区域内的全部像素 ...