我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在Android界面中实现一个回弹效果

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在Android界面中实现一个回弹效果

这篇文章给大家介绍如何在Android界面中实现一个回弹效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

具体代码如下所示:

public class MyScrollView extends ScrollView {  private View childView;  public MyScrollView(Context context) {    super(context);  }  public MyScrollView(Context context, AttributeSet attrs) {    super(context, attrs);  }  public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) {    super(context, attrs, defStyleAttr);  }//  @Override//  protected void onLayout(boolean changed, int l, int t, int r, int b) {//    super.onLayout(changed, l, t, r, b);//  }  //获取子视图  @Override  protected void onFinishInflate() {    super.onFinishInflate();    if (getChildCount() > 0) {      childView = getChildAt(0);    }  }  private int lastY;//上一次y轴方向操作的坐标位置  private Rect normal = new Rect();//用于记录临界状态的左、上、右、下  private boolean isFinishAnimation = true;//是否动画结束  private int lastX, downX, downY;  //拦截:实现父视图对子视图的拦截  //是否拦截成功,取决于方法的返回值。返回值true:拦截成功。反之,拦截失败  @Override  public boolean onInterceptTouchEvent(MotionEvent ev) {    boolean isIntercept = false;    int eventX = (int) ev.getX();    int eventY = (int) ev.getY();    switch (ev.getAction()) {      case MotionEvent.ACTION_DOWN:        lastX = downX = eventX;        lastY = downY = eventY;        break;      case MotionEvent.ACTION_MOVE:        //获取水平和垂直方向的移动距离        int absX = Math.abs(eventX - downX);        int absY = Math.abs(eventY - downY);        if(absY > absX && absY >= UIUtils.dp2px(10)){          isIntercept = true;//执行拦截        }        lastX = eventX;        lastY = eventY;        break;    }    return isIntercept;  }  @Override  public boolean onTouchEvent(MotionEvent ev) {    if (childView == null || !isFinishAnimation) {      return super.onTouchEvent(ev);    }    int eventY = (int) ev.getY();//获取当前的y轴坐标    switch (ev.getAction()) {      case MotionEvent.ACTION_DOWN:        lastY = eventY;        break;      case MotionEvent.ACTION_MOVE:        int dy = eventY - lastY;//微小的移动量        if (isNeedMove()) {          if (normal.isEmpty()) {            //记录了childView的临界状态的左、上、右、下            normal.set(childView.getLeft(), childView.getTop(), childView.getRight(), childView.getBottom());          }          //重新布局          childView.layout(childView.getLeft(), childView.getTop() + dy / 2, childView.getRight(), childView.getBottom() + dy / 2);        }        lastY = eventY;//重新赋值        break;      case MotionEvent.ACTION_UP:        if (isNeedAnimation()) {          //使用平移动画          int translateY = childView.getBottom() - normal.bottom;          TranslateAnimation translateAnimation = new TranslateAnimation(0, 0, 0, -translateY);          translateAnimation.setDuration(200);//        translateAnimation.setFillAfter(true);//停留在最终位置上          translateAnimation.setAnimationListener(new Animation.AnimationListener() {            @Override            public void onAnimationStart(Animation animation) {              isFinishAnimation = false;            }            @Override            public void onAnimationEnd(Animation animation) {              isFinishAnimation = true;              childView.clearAnimation();//清除动画              //重新布局              childView.layout(normal.left, normal.top, normal.right, normal.bottom);              //清除normal的数据              normal.setEmpty();            }            @Override            public void onAnimationRepeat(Animation animation) {            }          });          //启动动画          childView.startAnimation(translateAnimation);        }        break;    }    return super.onTouchEvent(ev);  }  //判断是否需要执行平移动画  private boolean isNeedAnimation() {    return !normal.isEmpty();  }  private boolean isNeedMove() {    int childMeasuredHeight = childView.getMeasuredHeight();//获取子视图的高度    int scrollViewMeasuredHeight = this.getMeasuredHeight();//获取布局的高度    Log.e("TAG", "childMeasuredHeight = " + childMeasuredHeight);    Log.e("TAG", "scrollViewMeasuredHeight = " + scrollViewMeasuredHeight);    int dy = childMeasuredHeight - scrollViewMeasuredHeight;//dy >= 0    int scrollY = this.getScrollY();//获取用户在y轴方向上的偏移量 (上 + 下 -)    if (scrollY <= 0 || scrollY >= dy) {      return true;//按照我们自定义的MyScrollView的方式处理    }    //其他处在临界范围内的,返回false。即表示,仍按照ScrollView的方式处理    return false;  }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在Android界面中实现一个回弹效果

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在Android界面中实现一个回弹效果

这篇文章给大家介绍如何在Android界面中实现一个回弹效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。具体代码如下所示:public class MyScrollView extends ScrollView {
2023-05-31

怎么在Android中利用ScrollView实现一个放大回弹效果

这期内容当中小编将会给大家带来有关怎么在Android中利用ScrollView实现一个放大回弹效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。自定义ScrollView1、创建一个类,继承Scroll
2023-05-31

怎么在Android中使用ScrollView实现一个下拉弹回动画效果

本篇文章给大家分享的是有关怎么在Android中使用ScrollView实现一个下拉弹回动画效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Android是什么Android
2023-05-30

如何在Android中利用RecyclerView实现一个聊天界面

这篇文章给大家介绍如何在Android中利用RecyclerView实现一个聊天界面,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。具体内容如下1、首先在app/build.gradle(注意有两个build.gradl
2023-05-30

Android中怎么利用EasyBarrage实现一个弹幕效果

Android中怎么利用EasyBarrage实现一个弹幕效果,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。概述EasyBarrage是Android平台的一种轻量级弹幕效
2023-05-30

如何在Android应用中实现一个Gallery画廊效果

这期内容当中小编将会给大家带来有关如何在Android应用中实现一个Gallery画廊效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。画廊 使用Gallery表示,按水平方向显示内容,并且可以用手指直接
2023-05-31

如何在Android中利用ConstraintLayout实现一个动画效果

这篇文章将为大家详细讲解有关如何在Android中利用ConstraintLayout实现一个动画效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。xml布局: