package com.viewpagerdemo;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import java.util.ArrayList;
import java.util.List;
/**
* Created by LiuShuai on 2016/6/28.
*/
public class Guide extends Activity implements ViewPager.OnPageChangeListener {
private viewpageradapter adapter;
private List<View> views;
private ViewPager viewpagerdem;
private ImageView[] dots;
private int[] ids = {R.id.iv1, R.id.iv2, R.id.iv3};
private Button btn;
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
viewpagerdem.setCurrentItem(viewpagerdem.getCurrentItem() + 1);
handler.sendEmptyMessageDelayed(0, 2000);
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.guide);
initViews();
viewpagerdem = (ViewPager) findViewById(R.id.viewpager);
viewpagerdem.setAdapter(adapter);
//将viewpager设置为最大整数的中间这样就可以实现一开始就能左右滑动了
viewpagerdem.setCurrentItem(Integer.MAX_VALUE / 2 / ids.length * ids.length);
initDots();
viewpagerdem.addOnPageChangeListener(this);
handler.sendEmptyMessageDelayed(0, 2000);
}
public void initViews() {
LayoutInflater inflater = LayoutInflater.from(this);
views = new ArrayList<>();
views.add(inflater.inflate(R.layout.one, null));
views.add(inflater.inflate(R.layout.two, null));
views.add(inflater.inflate(R.layout.three, null));
adapter = new viewpageradapter(views, this);
}
private void initDots() {
dots = new ImageView[views.size()];
for (int i = 0; i < views.size(); i++) {
dots[i] = ((ImageView) findViewById(ids[i]));
}
}
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
for (int i = 0; i < views.size(); i++) {
if (position % views.size() == i) {
dots[i].setImageResource(R.mipmap.page_indicator_focused);
} else {
dots[i].setImageResource(R.mipmap.page_indicator_unfocused);
}
}
}
@Override
public void onPageScrollStateChanged(int state) {
}
}
=================adapter=============================
package com.viewpagerdemo;
import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import android.view.ViewParent;
import java.util.List;
/**
* Created by LiuShuai on 2016/6/28.
*/
public class viewpageradapter extends PagerAdapter {
private List<View> views;
private Context context;
public viewpageradapter(List<View> views, Context context) {
this.views = views;
this.context = context;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
//Warning:不要在这里调用removeView方法,否则会出现手动往前滑动出现黑色的屏幕
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
View view = views.get(position % views.size());
//此处是为了避免发生The specified child already has a parent.
// You must call removeView() on the child's parent first.的错误。
ViewParent vp = view.getParent();
if (vp != null) {
ViewGroup parent = (ViewGroup) vp;
parent.removeView(view);
}
container.addView(view);
return view;
}
@Override
public int getCount() {
return Integer.MAX_VALUE;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
}
=================guide.xml=============================
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000"
android:flipInterval="30"
android:persistentDrawingCache="animation">
</android.support.v4.view.ViewPager>
<LinearLayout
android:id="@+id/ll"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:layout_alignParentBottom="true"
android:orientation="horizontal">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/iv1"
android:src="@mipmap/page_indicator_focused"/>
<ImageView
android:paddingLeft="10dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/iv2"
android:src="@mipmap/page_indicator_unfocused"/>
<ImageView
android:paddingLeft="10dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/iv3"
android:src="@mipmap/page_indicator_unfocused"/>
</LinearLayout>
</RelativeLayout>