布局文件,需要注意的是 android:clipChildren=”false”,这个方法的含义是是否允许在所在边界绘制,true为不绘制。
<?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:layout_width="match_parent"
android:layout_height="match_parent"
android:clipChildren="false"
android:layerType="software"
tools:context="com.oblivion.galley.MainActivity">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:clipChildren="false"
android:layout_centerInParent="true"
android:layout_width="200dp"
android:layout_height="300dp"></android.support.v4.view.ViewPager>
</RelativeLayout>
MainActivity中需要注意的是下边的方法
/*设置点击ViewPager之外的部位,ViewPager跟着滑动*/
RelativeLayout parent = (RelativeLayout) viewPager.getParent();
parent.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return viewPager.dispatchTouchEvent(event);
}
});
package com.oblivion.galley;
import android.os.Bundle;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.RelativeLayout;
public class MainActivity extends AppCompatActivity {
private ViewPager viewPager;
private int[] arr;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
}
private void init() {
arr = new int[]{R.drawable.i0, R.drawable.i1, R.drawable.i2, R.drawable.i3, R.drawable.i4, R.drawable.i5};
initView();
}
private void initView() {
viewPager = (ViewPager) findViewById(R.id.viewpager);
viewPager.setPageTransformer(true, new GalleyTransFormer());
viewPager.setOffscreenPageLimit(5);
viewPager.setAdapter(new PagerAdapter() {
@Override
public int getCount() {
return arr.length;
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
ImageView imageView = new ImageView(getBaseContext());
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setImageResource(arr[position]);
container.addView(imageView);
return imageView;
}
});
viewPager.setCurrentItem(3);
/*设置点击ViewPager之外的部位,ViewPager跟着滑动*/
RelativeLayout parent = (RelativeLayout) viewPager.getParent();
parent.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
return viewPager.dispatchTouchEvent(event);
}
});
}
}
TransFormer方法
package com.oblivion.galley;
import android.support.v4.view.ViewPager;
import android.view.View;
/**
* github : https://github.com/oblivion0001/AndroidStudioProjects
* Blog : http://blog.csdn.net/qq_16666847
* Created by oblivion on 2016/12/19.
*/
public class GalleyTransFormer implements ViewPager.PageTransformer {
private static final float min_scale = 0.85f;
@Override
public void transformPage(View page, float position) {
float scaleFactor = Math.max(min_scale, 1 - Math.abs(position));
float rotate = 20 * Math.abs(position);
if (position < -1) {
} else if (position < 0) {
page.setScaleX(scaleFactor);
page.setScaleY(scaleFactor);
page.setRotationY(rotate);
} else if (position >= 0 && position < 1) {
page.setScaleX(scaleFactor);
page.setScaleY(scaleFactor);
page.setRotationY(-rotate);
} else if (position >= 1) {
page.setScaleX(scaleFactor);
page.setScaleY(scaleFactor);
page.setRotationY(-rotate);
}
}
}