android item切换动画效果,Android实现单页显示3个Item的ViewPager炫酷切换效果

单页显示3个Item的ViewPager炫酷切换效果,适用于Banner等。

效果图

Rotate Y

a44489638836fefb14726c2fc956f27a.gif

Rotate Down

5d1ee970b54ff7ed8f4da1fa10621c3f.gif

Rotate Up

fae90a20999ea65ede8535b64ed225a1.gif

Alpha

7c1f9634e04aa54f1f2268e3cb4097e7.gif

ScaleIn

3a39d31e409c596d3e56388f8dfb20cc.gif

ScaleIn + Alpha + Rotate Down

92c2e195f9675ba1fcad584dc69d9e0a.gif

使用

###(1)引入

compile `com.zhy:magic-viewpager:1.0.1`

###(2)示例

布局文件

android:layout_width="match_parent"

android:layout_height="160dp"

android:clipChildren="false"

android:layout_centerInParent="true"

android:background="#aadc71ff"

>

android:id="@+id/id_viewpager"

android:layout_width="match_parent"

android:layout_marginLeft="60dp"

android:clipChildren="false"

android:layout_marginRight="60dp"

android:layout_height="120dp"

android:layout_gravity="center"

>

注意外层android:layout_centerInParent="true".(貌似其实没什么影响)

编码

mViewPager.setPageMargin(20);//设置page间间距,自行根据需求设置

mViewPager.setOffscreenPageLimit(3);//>=3

mViewPager.setAdapter...//写法不变

//setPageTransformer 决定动画效果

mViewPager.setPageTransformer(true, new RotateDownPageTransformer());

##目前可选动画

AlphaPageTransformer

RotateDownPageTransformer

RotateUpPageTransformer

RotateYTransformer

NonPageTransformer

ScaleInTransformer

动画间可以自由组合,例如:

mViewPager.setPageTransformer(true,new RotateDownPageTransformer(new AlphaPageTransformer(new ScaleInTransformer())));

需求:

1.一个页面显示三个item

2.viewpager无限循环

3.定时滑动

4.长条形小点

4fa8d4575beb3ea24aa50e4d27b695c1.png

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:background="#aadc71ff"

android:clipChildren="false"

tools:context="com.example.administrator.banner2.MainActivity">

android:id="@+id/viewpager"

android:layout_width="match_parent"

android:layout_height="150dp"

android:layout_gravity="center"

android:layout_marginBottom="10dp"

android:layout_marginLeft="30dp"

android:layout_marginRight="30dp"

android:layout_marginTop="10dp"

android:clipChildren="false">

android:id="@+id/dotLayout"

android:layout_width="match_parent"

android:layout_height="10dp"

android:layout_gravity="bottom"

android:layout_marginBottom="10dp"

android:gravity="center"

android:orientation="horizontal">

import android.os.Bundle;

import android.os.Handler;

import android.support.v4.view.PagerAdapter;

import android.support.v4.view.ViewPager;

import android.support.v7.app.AppCompatActivity;

import android.view.View;

import android.view.ViewGroup;

import android.widget.ImageView;

import android.widget.LinearLayout;

import android.widget.RelativeLayout;

import com.zhy.magicviewpager.transformer.ScaleInTransformer;

import java.util.Timer;

import java.util.TimerTask;

public class MainActivity extends AppCompatActivity {

private ViewPager mViewPager;

private PagerAdapter mAdapter;

private LinearLayout dotLayout;

private Timer timer;

private Handler mHandler = new Handler();

private int prePosition = 0;

int[] imgRes = {R.drawable.a, R.drawable.b, R.drawable.c, R.drawable.d,

R.drawable.e, R.drawable.f, R.drawable.g, R.drawable.h, R.drawable.i};

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mViewPager = (ViewPager) findViewById(R.id.viewpager);

dotLayout = (LinearLayout) findViewById(R.id.dotLayout);

initDots();

mViewPager.setPageMargin(20);

mViewPager.setOffscreenPageLimit(3);

mViewPager.setAdapter(mAdapter = new PagerAdapter() {

@Override

public Object instantiateItem(ViewGroup container, int position) {

ImageView view = new ImageView(MainActivity.this);

view.setScaleType(ImageView.ScaleType.FIT_XY);

view.setImageResource(imgRes[position % imgRes.length]);

container.addView(view);

return view;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

container.removeView((View) object);

}

@Override

public int getCount() {

return Integer.MAX_VALUE;

}

@Override

public boolean isViewFromObject(View view, Object o) {

return view == o;

}

});

mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

@Override

public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

}

@Override

public void onPageSelected(int position) {

dotLayout.getChildAt(prePosition).setEnabled(false);

dotLayout.getChildAt(position % imgRes.length).setEnabled(true);

prePosition = position % imgRes.length;

}

@Override

public void onPageScrollStateChanged(int state) {

}

});

mViewPager.setPageTransformer(true, new ScaleInTransformer());

if (null != timer) {

timer.cancel();

}

timer = new Timer();

timer.schedule(new TimerTask() {

@Override

public void run() {

mHandler.post(new Runnable() {

@Override

public void run() {

mViewPager.setCurrentItem(mViewPager.getCurrentItem() + 1);

}

});

}

}, 0, 1000);

}

private void initDots() {

if (null != dotLayout) {

dotLayout.removeAllViews();

}

for (int i = 0; i < imgRes.length; i++) {

ImageView dot = new ImageView(this);

dot.setEnabled(false);

dot.setImageResource(R.drawable.dot);

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);

params.leftMargin = 10;

dot.setLayoutParams(params);

dotLayout.addView(dot);

}

dotLayout.getChildAt(0).setEnabled(true);

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值