android ViewPager用于左右滑动图片或Fragment activity界面都是很方便的,这里只介绍ViewPager滑动图片的效果示例,先入门学习一下ViewPager控件的使用,首先来预览下本人的项目结构,以便更好的理解下面的内容,如图所示。

下面是ViewPager控件的使用步骤。
1:在activity_main.xml文件中添加ViewPager控件,作为父控件显示后面自定义的xml视图。
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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" tools:context="com.baidu.smalldemo.MainActivity"> <android.support.v4.view.ViewPager android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/myViewPager"/> </RelativeLayout>
2:在layout文件下新建my_image.xml文件,里面添加一个TextView显示图片的角标,ImageView用于显示我们的图片,实现左右滑动图片的效果,代码如下。
<?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"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="你好 viewpager" android:textSize="25dp" android:textStyle="bold" android:gravity="center" android:layout_marginTop="25dp" android:id="@+id/image_count"/> <ImageView android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="25dp" android:layout_gravity="center" android:id="@+id/image_view"/> </LinearLayout>
3:自定义SliderImageAdapter类,并继承PagerAdapter适配器类,并实现里面的instantiateItem方法,初始化界面的数据,代码如下。
package com.baidu.smalldemo;
import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;
/**
* Created by ts on 2017/9/14.
*/
public class SliderImageAdapter extends PagerAdapter {
//图片数据源数组
private int[] image_resources = {R.drawable.first,R.drawable.second,R.drawable.third};
//传入调用者页面的context
private Context context;
//填充数据的对象
private LayoutInflater layoutInflater;
//构造方法
public SliderImageAdapter(Context context){
this.context = context;
}
//图片的长度
@Override
public int getCount() {
return image_resources.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return (view == (LinearLayout)object);
}
//此方法是给viewpager填充数据的方法
@Override
public Object instantiateItem(ViewGroup container, int position) {
layoutInflater = (LayoutInflater)context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
/**
* 参数一:需要填充那个layout.xml
* 参数二:填充到哪里
* 参数三:是否是rootview
* return 我们自定义的xml文件对象
*/
View item_view = layoutInflater.inflate(R.layout.my_images,container,false);
//通过item_view获取my_images.xml中的ImageView对象
ImageView imageView = (ImageView)item_view.findViewById(R.id.image_view);
//通过item_view获取my_images.xml中的TextView对象,显示图片角标
TextView textView = (TextView)item_view.findViewById(R.id.image_count);
//设置图片数据源
imageView.setImageResource(image_resources[position]);
//设置第几张图片
textView.setText("第"+position+"角标图片");
//将item_view加入container容器对象
container.addView(item_view);
//返回item_view
return item_view;
}
//viewpager销毁方法
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
//从父layout中删除对象
container.removeView((LinearLayout)object);
}
}4:在MainActivity.java主类中初始化ViewPager对象和前面自定义的SliderImageAdapter适配器对象,然后通过viewPager.setAdapter(sliderImageAdapter);方法将我们适配器里面填充的数据设置到ViewPager控件中,代码如下。
package com.baidu.smalldemo;
import android.annotation.TargetApi;
import android.os.Build;
import android.speech.tts.TextToSpeech;
import android.support.annotation.RequiresApi;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import java.util.Locale;
public class MainActivity extends AppCompatActivity {
private ViewPager viewPager;
private SliderImageAdapter sliderImageAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//初始化ViewPager对象
viewPager = (ViewPager)findViewById(R.id.myViewPager);
//初始化自定义的adapter
sliderImageAdapter = new SliderImageAdapter(this);
viewPager.setAdapter(sliderImageAdapter);
}
}运行之后效果如图所示,非常的好看的效果。

完毕!欢迎转载!