ViewPager的简单使用
1、布局文件
a、主布局文件
<?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:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context="lpc.com.animation2demo.MainActivity"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="48dp"><TextViewandroid:id="@+id/tv1"android:text="苹果"android:gravity="center"android:layout_weight="1"android:layout_width="match_parent"android:layout_height="match_parent" /><TextViewandroid:id="@+id/tv2"android:text="香蕉"android:gravity="center"android:layout_weight="1"android:layout_width="match_parent"android:layout_height="match_parent" /><TextViewandroid:text="梨"android:id="@+id/tv3"android:gravity="center"android:layout_weight="1"android:layout_width="match_parent"android:layout_height="match_parent" /></LinearLayout><ImageViewandroid:id="@+id/iv"android:src="@mipmap/line"android:scaleType="matrix"android:layout_width="match_parent"android:layout_height="wrap_content" /><android.support.v4.view.ViewPagerandroid:id="@+id/viewPager1"android:layout_weight="1"android:layout_width="match_parent"android:flipInterval="30"android:layout_gravity="center"android:persistentDrawingCache="animation"android:layout_height="0dp"></android.support.v4.view.ViewPager></LinearLayout>

b、子布局
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical" android:layout_width="match_parent"android:layout_height="match_parent"><ImageViewandroid:background="@drawable/a1"android:layout_width="match_parent"android:layout_height="match_parent" /></LinearLayout>

2、主Java文件
package lpc.com.animation2demo;import android.graphics.BitmapFactory;import android.graphics.Matrix;import android.os.Bundle;import android.support.v4.view.ViewPager;import android.support.v7.app.AppCompatActivity;import android.util.DisplayMetrics;import android.view.LayoutInflater;import android.view.View;import android.view.animation.Animation;import android.view.animation.TranslateAnimation;import android.widget.ImageView;import android.widget.TextView;import java.util.ArrayList;public class MainActivity extends AppCompatActivity implements View.OnClickListener,ViewPager.OnPageChangeListener{private TextView tv1; //文本对象1private TextView tv2; //文本对象2private TextView tv3; //文本对象3private ImageView iv; //图片对象(用于移动条)private ViewPager vp; //Viewpager对象private ArrayList<View> viewArrayList; //创建一个View储存数组private int offset = 0; //移动条图片的偏移量private int currentIndex = 0; //当前页面private int bmpWidth ; //图片宽度private int one = 0; //移动条滑动一页的距离private int two = 0; //滑动条移动两页的距离@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initView();}private void initView() {tv1 = (TextView) findViewById(R.id.tv1);tv2 = (TextView) findViewById(R.id.tv2);tv3 = (TextView) findViewById(R.id.tv3);iv = (ImageView) findViewById(R.id.iv);vp = (ViewPager) findViewById(R.id.viewPager1);//下划线动画的相关设置:bmpWidth = BitmapFactory.decodeResource(getResources(), R.mipmap.line).getWidth();// 获取图片宽度DisplayMetrics dm = new DisplayMetrics();getWindowManager().getDefaultDisplay().getMetrics(dm);int screenW = dm.widthPixels;// 获取分辨率宽度offset = (screenW / 3 - bmpWidth) / 2;// 计算偏移量Matrix matrix = new Matrix();matrix.postTranslate(offset, 0);iv.setImageMatrix(matrix);// 设置动画初始位置//移动的距离one = offset * 2 + bmpWidth;// 移动一页的偏移量,比如1->2,或者2->3two = one * 2;// 移动两页的偏移量,比如1直接跳3//往ViewPager填充View,同时设置点击事件与页面切换事件viewArrayList = new ArrayList<View>();LayoutInflater inflater = getLayoutInflater();viewArrayList.add(inflater.inflate(R.layout.view1,null,false));viewArrayList.add(inflater.inflate(R.layout.view2,null,false));viewArrayList.add(inflater.inflate(R.layout.view3,null,false));vp.setAdapter(new MyAdapter(viewArrayList));vp.setCurrentItem(0); //设置ViewPager当前页,从0开始算tv1.setOnClickListener(this);tv2.setOnClickListener(this);tv3.setOnClickListener(this);vp.addOnPageChangeListener(this);}@Overridepublic void onClick(View view) {switch (view.getId()){case R.id.tv1:vp.setCurrentItem(0);break;case R.id.tv2:vp.setCurrentItem(1);break;case R.id.tv3:vp.setCurrentItem(2);break;}}@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {Animation animation = null;switch (position){case 0:if (currentIndex == 1){animation = new TranslateAnimation(one,0,0,0);}else if (currentIndex == 2){animation = new TranslateAnimation(two,0,0,0);}break;case 1:if (currentIndex == 0){animation = new TranslateAnimation(offset,one,0,0);}else if (currentIndex == 2){animation = new TranslateAnimation(two,one,0,0);}break;case 2:if (currentIndex == 0){animation = new TranslateAnimation(offset,two,0,0);}else if (currentIndex == 1){animation = new TranslateAnimation(one,two,0,0);}break;}currentIndex = position;animation.setFillAfter(true);// true表示图片停在动画结束位置animation.setDuration(300); //设置动画时间为300毫秒iv.startAnimation(animation);//开始动画}@Overridepublic void onPageScrollStateChanged(int state) {}}
3、适配器文件
package lpc.com.animation2demo;import android.support.v4.view.PagerAdapter;import android.view.View;import android.view.ViewGroup;import java.util.ArrayList;/*** Created by Administrator on 2016/3/16.* 适配器*/public class MyAdapter extends PagerAdapter {//创建一个对象数组 存储Viewprivate ArrayList<View> viewArrayList;//空构造函数public MyAdapter() {}//初始化对象数组public MyAdapter(ArrayList<View> viewArrayList) {this.viewArrayList = viewArrayList;}//获取对象数组的大小@Overridepublic int getCount() {return viewArrayList.size();}//将视图转化成对象@Overridepublic boolean isViewFromObject(View view, Object object) {return view == object;}//获取选定 对象数组并将其添加到viewpager中@Overridepublic Object instantiateItem(ViewGroup container, int position) {container.addView(viewArrayList.get(position));return viewArrayList.get(position);}//移除选定的对象数组对象@Overridepublic void destroyItem(ViewGroup container, int position, Object object) {container.removeView(viewArrayList.get(position));}}
4、manifest文件
<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"package="lpc.com.animation2demo"><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:supportsRtl="true"android:theme="@style/AppTheme"><activity android:name=".MainActivity"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>
5、实现效果
ViewPager的简单使用的更多相关文章
- ViewPager的简单用法+适配器+监听器的介绍
之前的actionbar+fragment文章中写过viewpager的简单用法,但因为是融合的文章,所以今天把viewpager提取出来写了.方便查询浏览~ 思路: 1.在布局文件中设置viewpa ...
- viewpager的简单使用,以及ValueAnimator的用法示例
之前在网上看到一篇viewpager简单使用的例子程序,主要采用了上部标签button+中间指示作用的imageview+下部viewpager的结构,点击上部标签,或者滑动viewpager,均可以 ...
- Android随笔--使用ViewPager实现简单地图片的左右滑动切换
Android中图片的左右切换随处可见,今天我也试着查阅资料试着做了一下,挺简单的一个小Demo,却也发现了一些问题,话不多说,上代码~: 使用了3个xml文件作为ViewPager的滑动page,布 ...
- ViewPager的简单例子
这个例子是按照官网上的例子写的,有点抄袭的嫌疑,但是自己单独写一下会加深自己的印象. 首先是MainAcitivity.xml: <LinearLayout xmlns:android=&quo ...
- ViewPager的简单使用说明
前提:工程中使用ViewPager,需要导入google提供的jar包(android-support-v4.jar). 要学习ViewPager的使用,建议直接看官方文档 Creating Swip ...
- Android开发之ViewPager的简单使用
ViewPager是V4包中的,如果你的编译器敲不出ViewPager,那么你就需要添加,看下面: 第一步:点击+号 第二步:选择第一个Library 第三步:添加这个包: 然后点击ok-->o ...
- Android ViewPager的简单实现
研究了两天ViewPager,看了几篇网上的帖子,但总的来说看得一头雾水,理不清头绪,偶然发现了一篇简单易懂的帖子,讲的调理比较清晰,原文链接附在文后. 在本例中使用ViewPager + Fra ...
- android学习ViewPager的简单使用
使用ViewPager需要引入android.support.v4.View.ViewPager这样的jar包,谷歌公司为解决当前版本碎片化的问题,提供的兼容的包.主要目的就是解决向下兼容问题. 1, ...
- TabLayout+ViewPager的简单使用
1. build.gradle文件中加入 compile 'com.android.support:design:22.2.0' 2.写Xml文件,注意TabLayout的三个属性 app:tab ...
随机推荐
- 使用VS2013逆向生成UML类图
引自http://blog.csdn.net/funnyfu0101/article/details/7705173 首先.打开工程,[体系结构]->[新建关系图] 生成一个类图 然后[体系结构 ...
- Stanford CS1 Compilers PA2J notes
[题记·碎碎念] 斯坦福这门Compilers原本放在Coursera上,当年错过档期很是可惜,后来发现他们自己的MOOC站放了一个self paced版本,真是普大喜奔,趁着放假有空学学. 这门课的 ...
- 用javascript比较快速排序和合并排序的优劣
<script> //用来调用排列方法的类 function arr_sort(arr){ var startTime,endTime; var priv_arr = new Array; ...
- window.returnValue跨域传值问题[转]
主页面用window.showModalDialog的时候,如果直接打开其它系统的页面,这时候别人的页面在window.returnValue=1;这样返回值的时候,主页面是取不到返回值的,原因就是因 ...
- 牛客网程序员面试金典:1.1确定字符互异(java实现)
问题描述: 请实现一个算法,确定一个字符串的所有字符是否全都不同.这里我们要求不允许使用额外的存储结构. 给定一个string iniString,请返回一个bool值,True代表所有字符全都不同, ...
- Entity framework code first
EF Code First 不便之处,数据库结构改变时,需要利用程序包管理器控制台生成代码,再用update-database -Verbose更新数据库,这样的做法在很多时候不容易部署.下面介绍一种 ...
- JAVA 常用框架和工具
集成开发工具(IDE):Eclipse.MyEclipse.Spring Tool Suite(STS).Intellij IDEA.NetBeans.JBuilder.JCreator JAVA服务 ...
- log4j输出日志到不同文件
1.先看log4j的配置文件 log4j.properties 没有此文件就在根目录下创建一个: log4j.rootLogger=INFO,R,Client log4j.appender.R=org ...
- Ninject之旅之八:Ninject插件模型(附程序下载)
摘要 在前面的章节中,我们看了在单一的绑定条件下Ninject能够处理依赖类型,就是说,每个服务类型只绑定到单一的实现类型.然而,有些情况下我们需要绑定一个抽象服务类型到多个实现,这叫多个绑定.多个绑 ...
- ZXingObjC 64位 集成到自己的项目中(xcode 6.4)
参考 http://www.cocoachina.com/bbs/read.php?tid-280058-page-1.html 楼主发的DEMO中 ZXingObjC 支持64位 但是是以项目形 ...