Android初级进阶之自定义果冻视图(BouncingJellyView)(二)

简介: 啰嗦废话本篇为Android初级进阶之自定义果冻视图(BouncingJellyView)(一)的后续篇章。没有看过的赶紧去看看,顺便点个喜欢。BouncingJellyView 果冻视图,就像果冻一样伸缩弹跳,也叫阻尼效果。

啰嗦废话

本篇为Android初级进阶之自定义果冻视图(BouncingJellyView)(一)的后续篇章。没有看过的赶紧去看看,顺便点个喜欢。

BouncingJellyView 果冻视图,就像果冻一样伸缩弹跳,也叫阻尼效果。这个效果在MIUI上面到处都可以看到。

上一篇文章到现在的间隔已经是足足的三个月时间了,因为期间在待业中,所以没什么心情来写文章,所以拖到了现在,找着了工作,解决了其中的一些小问题,才开始写文章。

我现在的公司是做自己的产品,而且是从零到有得一个过程,所以我会把我在做项目的过程中遇到的问题解决方案及一些自定义的UI控件写成文章和demo,希望大家多多star,多多关注,也为能为我将来增加一些砝码。

效果图

废话不多说 先整两张效果图

img_89960346faf537e4a1e2ffdb5f6e9904.gif
普通的
img_1bd1fbe7ef6ed7ce6a61f45c87190200.gif
嵌套RecyclerView的

区别

  1. 上个版本所留下的BUG,应该没有人发现。我这里描述一下:在5.0以上使用ToolBar的时候,不管是上拉还是下拉都是没有问题的,但是在5.0以下的时候就很糟糕了,下拉没有问题,但是上拉却是会遮挡ToolBar,如下图所示:
img_911b7d23f8e5d04f61278070092cc8cf.png
BouncingJellyView在5.0以下的BUG
  1. 上个版本中,要使用对应的BouncingJelly才能够达到效果,但是在这个版本中,只需要使用BouncingJellyView就可以达到相应的效果。

  2. 和RecyclerView等嵌套的时候快速滑动不是很流畅。

分析

  1. 在5.0以下进行缩放的时候,会遮挡住ToolBar,其中的原因是:上面的ToolBar与我的BouncingJellyView是处与同一级的,而且都是CoordinatorLayout之下。缩放的是整个BouncingJellyView,导致遮挡。

解决方案

  1. 继承至android.support.v4.widget.NestedScrollView更加便捷的解决滑动冲突。

  2. 在onInterceptTouchEvent中做了一些判断,能让BouncingJellyView进行快速滑动。

     @Override
     public boolean onInterceptTouchEvent(MotionEvent e) {
         int action = e.getAction();
         switch (action) {
             case MotionEvent.ACTION_DOWN:
                 downX = (int) e.getRawX();
                 downY = (int) e.getRawY();
                 break;
             case MotionEvent.ACTION_MOVE:
                 int moveY = (int) e.getRawY();
                 //判断是否达到最小滚动值
                 if (Math.abs(moveY - downY) > mTouchSlop) {
                       return true;
                 }
         }
         return super.onInterceptTouchEvent(e);
     }
    
  3. 改变缩放目标,由原来的缩放BouncingJellyView改成缩放子View

      @Override
     protected void onLayout(boolean changed, int l, int t, int r, int b) {
         super.onLayout(changed, l, t, r, b);
         childAt = getChildAt(0);
     }
    
     /**
      * 从顶部开始滑动
      */
     public void bouncingTo() {
         //设置X坐标点
         ViewHelper.setPivotX(childAt, getWidth() / 2);
         //设置Y坐标点
         ViewHelper.setPivotY(childAt, 0);
         //进行缩放
         ViewHelper.setScaleY(childAt, 1.0f + offsetScale);
         if (onBouncingJellyListener != null) {
             onBouncingJellyListener.onBouncingJelly(1.0f + offsetScale);
         }
     }
    
     /**
      * 从顶部开始滑动
      */
     public void bouncingBottom() {
         //设置X坐标点
         ViewHelper.setPivotX(childAt, getWidth() / 2);
         //设置Y坐标点
         ViewHelper.setPivotY(childAt, childAt.getHeight());
         ViewHelper.setScaleY(childAt, 1.0f + offsetScale);
         if (onBouncingJellyListener != null) {
             onBouncingJellyListener.onBouncingJelly(1.0f + offsetScale);
         }
     }
    

TODO

  1. 快速滚动到底部应该滑动一次。

源码地址 希望大家能我一个star, 万分感谢。

目录
相关文章
|
1月前
|
Android开发 开发者
安卓应用开发中的自定义视图
【9月更文挑战第37天】在安卓开发的海洋中,自定义视图犹如一座座小岛,等待着勇敢的探索者去发现其独特之处。本文将带领你踏上这段旅程,从浅滩走向深海,逐步揭开自定义视图的神秘面纱。
41 3
|
1月前
|
数据可视化 Android开发 开发者
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
85 0
|
3月前
|
供应链 物联网 区块链
未来触手可及:探索新兴技术的趋势与应用安卓开发中的自定义视图:从基础到进阶
【8月更文挑战第30天】随着科技的飞速发展,新兴技术如区块链、物联网和虚拟现实正在重塑我们的世界。本文将深入探讨这些技术的发展趋势和应用场景,带你领略未来的可能性。
|
3月前
|
测试技术 Android开发 Python
探索软件测试的艺术:从基础到高级安卓应用开发中的自定义视图
【8月更文挑战第29天】在软件开发的世界中,测试是不可或缺的一环。它如同艺术一般,需要精细的技巧和深厚的知识。本文旨在通过浅显易懂的语言,引领读者从软件测试的基础出发,逐步深入到更复杂的测试策略和工具的使用,最终达到能够独立进行高效测试的水平。我们将一起探索如何通过不同的测试方法来确保软件的质量和性能,就像艺术家通过不同的色彩和笔触来完成一幅画作一样。
|
17天前
|
搜索推荐 前端开发 Android开发
安卓应用开发中的自定义视图实现
【10月更文挑战第30天】在安卓开发的海洋中,自定义视图是那抹不可或缺的亮色,它为应用界面的个性化和交互体验的提升提供了无限可能。本文将深入探讨如何在安卓平台创建自定义视图,并展示如何通过代码实现这一过程。我们将从基础出发,逐步引导你理解自定义视图的核心概念,然后通过一个实际的代码示例,详细讲解如何将理论应用于实践,最终实现一个美观且具有良好用户体验的自定义控件。无论你是想提高自己的开发技能,还是仅仅出于对安卓开发的兴趣,这篇文章都将为你提供价值。
|
19天前
|
Android开发 开发者 UED
安卓开发中自定义View的实现与性能优化
【10月更文挑战第28天】在安卓开发领域,自定义View是提升应用界面独特性和用户体验的重要手段。本文将深入探讨如何高效地创建和管理自定义View,以及如何通过代码和性能调优来确保流畅的交互体验。我们将一起学习自定义View的生命周期、绘图基础和事件处理,进而探索内存和布局优化技巧,最终实现既美观又高效的安卓界面。
28 5
|
1月前
|
XML 前端开发 Java
安卓应用开发中的自定义View组件
【10月更文挑战第5天】自定义View是安卓应用开发的一块基石,它为开发者提供了无限的可能。通过掌握其原理和实现方法,可以创造出既美观又实用的用户界面。本文将引导你了解自定义View的创建过程,包括绘制技巧、事件处理以及性能优化等关键步骤。
|
2月前
|
Android开发 开发者
安卓开发中的自定义视图:从入门到精通
【9月更文挑战第19天】在安卓开发的广阔天地中,自定义视图是一块充满魔力的土地。它不仅仅是代码的堆砌,更是艺术与科技的完美结合。通过掌握自定义视图,开发者能够打破常规,创造出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战应用,一步步展示如何用代码绘出心中的蓝图。无论你是初学者还是有经验的开发者,这篇文章都将为你打开一扇通往创意和效率的大门。让我们一起探索自定义视图的秘密,将你的应用打造成一件艺术品吧!
62 10
|
2月前
|
XML 编解码 Android开发
安卓开发中的自定义视图控件
【9月更文挑战第14天】在安卓开发中,自定义视图控件是一种高级技巧,它可以让开发者根据项目需求创建出独特的用户界面元素。本文将通过一个简单示例,引导你了解如何在安卓项目中实现自定义视图控件,包括创建自定义控件类、处理绘制逻辑以及响应用户交互。无论你是初学者还是有经验的开发者,这篇文章都会为你提供有价值的见解和技巧。
46 3
|
2月前
|
前端开发 Android开发 开发者
安卓应用开发中的自定义视图基础
【9月更文挑战第13天】在安卓开发的广阔天地中,自定义视图是一块神奇的画布,它允许开发者将想象力转化为用户界面的创新元素。本文将带你一探究竟,了解如何从零开始构建自定义视图,包括绘图基础、触摸事件处理,以及性能优化的实用技巧。无论你是想提升应用的视觉吸引力,还是追求更流畅的交互体验,这里都有你需要的金钥匙。
下一篇
无影云桌面