android 引导动画效果,高质量的客户端引导动画效果-IT蓝豹

主要实现,通过ViewPager加载每一个fragment.创建一个引导页adapter即GuideAdapter,

设置viewpager缓存页数,默认的缓存一页,因为引导页共有4页,所以设置缓存3页,

这样所以page在滑动过程中不会重新创建,每一个fragment切换的时候通过HKTransformer动画实现效果。

代码来源:外链网址已屏蔽github.com/hanks-zyh/500px-guideview

部分

/**

* by Hanks

*/

class HKTransformer implements ViewPager.PageTransformer {

@Override

public void transformPage(View view, float position) {

if (fragment00.getView() == view) {

Log.i("", "view:    " + view + "position= " + position);

currentPosition = position;

}

blurringView.invalidate();

if (position < -1) { // [-Infinity,-1)

// This page is way off-screen to the left.

} else if (position <= 0) { // [-1,0]

// Use the default slide transition when moving to the left page

} else if (position <= 1) { // (0,1]

// Fade the page out.

float p = Math.abs(position);

float f = (1 - p);

Log.i("", "p= " + p);

// p : 1~0

// f : 0~1

iv_final_photo.setPivotY(0f);

iv_final_photo.setPivotX(iv_final_photo.getWidth() / 2);

if (-1 < currentPosition && currentPosition <= 0) {

// A ~ B 界面的动画

iv_initial_phone.setTranslationY(-600 * f);

iv_initial_phone.setScaleX(0.5f * p + 0.5f);

iv_initial_phone.setScaleY(0.5f * p + 0.5f);

iv_device.setScaleX(1 + 2 * f);

if (p > 0.5 && p <= 1) {

iv_device.setAlpha(2 * p - 1);

} else {

iv_device.setAlpha(0f);

}

ll_comments.setTranslationY(800 * p);

ll_comments.setAlpha(f);

ll_comments.setScaleX(2 - f);

ll_comments.setScaleY(2 - f);

ll_rows.setTranslationY(-1000 - 500 * p);

ll_rows.setAlpha(0.5f);

iv_final_photo.setTranslationY(-1000 - 500 * p);

iv_final_photo.setAlpha(0.5f);

tv_avatar_you.setTranslationY(-300);

tv_register.setTranslationY(300);

} else if (-2 < currentPosition && currentPosition <= -1) {

// B ~ C 界面的动画

iv_initial_phone.setTranslationY(-600 + -300 * f);

ll_comments.setAlpha(p);

ll_rows.setTranslationY(-1000 * p);

ll_rows.setAlpha(0.5f + 0.5f * f);

iv_final_photo.setTranslationY(-1000 * p);

iv_final_photo.setAlpha(0.5f + 0.5f * f);

tv_avatar_you.setTranslationY(-300);

tv_register.setTranslationY(300);

} else if (-3 < currentPosition && currentPosition <= -2) {

// C ~ D 界面的动画

iv_final_photo.setScaleX(1 + 3 * f); //1~3

iv_final_photo.setScaleY(1 + 3 * f); //1~3

for (int i = 0; i < ll_rows.getChildCount(); i++) {

View child = ll_rows.getChildAt(i);

child.setAlpha(p);

if (i % 2 == 0) {

child.setTranslationX(100 * f);

} else {

child.setTranslationX(-100 * f);

}

}

tv_avatar_you.setTranslationY(-300 + 300 * f);

tv_register.setTranslationY(300 - 300 * f);

}

} else { // (1,+Infinity]

// This page is way off-screen to the right.

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值