android仿微信的activity平滑水平切换动画,Android实现平滑翻动效果

本文实例为大家分享了Android实现平滑翻动效果的具体代码,供大家参考,具体内容如下

效果

785f2cb741db38d887227d278f976d1d.gif

1.activity加implements

implements GestureDetector.OnGestureListener

2.

android:id="@+id/mars_bg"

android:layout_width="match_parent"

android:layout_height="match_parent" />

3.

private GestureDetector gestureDetector = null;

private ViewFlipper marsBg;

private int[] imageID = {R.drawable.bg_ast1, R.drawable.bg_main, R.drawable.bg_home};

4.oncreat中

// 生成GestureDetector对象,用于检测手势事件

gestureDetector = new GestureDetector(this);

// 添加用于切换的图片

for (int value : imageID) {

// 定义一个ImageView对象

ImageView image = new ImageView(this);

image.setImageResource(value);

// 充满父控件

image.setScaleType(ImageView.ScaleType.FIT_XY);

// 添加到viewFlipper中

marsBg.addView(image, new ViewGroup.LayoutParams(

ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));

}

5.重写继承的方法

@Override

public boolean onTouchEvent(MotionEvent event) {

return this.gestureDetector.onTouchEvent(event);

}

@Override

public boolean onFling(MotionEvent arg0, MotionEvent arg1, float arg2, float arg3) {

//对手指滑动的距离进行了计算,如果滑动距离大于120像素,就做切换动作,否则不做任何切换动作。

// 从左向右滑动

if (arg0.getX() - arg1.getX() > 120) {

// 添加动画

this.marsBg.setInAnimation(AnimationUtils.loadAnimation(this,

R.anim.push_left_in));

this.marsBg.setOutAnimation(AnimationUtils.loadAnimation(this,

R.anim.push_left_out));

this.marsBg.showNext();

return true;

}// 从右向左滑动

else if (arg0.getX() - arg1.getX() < -120) {

this.marsBg.setInAnimation(AnimationUtils.loadAnimation(this,

R.anim.push_right_in));

this.marsBg.setOutAnimation(AnimationUtils.loadAnimation(this,

R.anim.push_right_out));

this.marsBg.showPrevious();

return true;

}

return true;

}

@Override

public boolean onDown(MotionEvent e) {

return false;

}

@Override

public void onShowPress(MotionEvent e) {

}

@Override

public boolean onSingleTapUp(MotionEvent e) {

return false;

}

@Override

public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {

return false;

}

@Override

public void onLongPress(MotionEvent e) {

}

6.anim

push_left_in.xml

android:duration="500" />

android:duration="500" />

push_left_out.xml

android:duration="500" />

android:duration="500" />

push_right_in.xml

android:duration="500" />

android:duration="500" />

push_right_out.xml

android:duration="500" />

android:duration="500" />

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值