Android自定义View实现弹性小球效果

所属分类: 软件编程 / Android 阅读数: 28
收藏 0 赞 0 分享

照例先看效果图

自定义代码示例

public class BezierView extends View {

 Paint paint;//画笔
 Path path;//路径

 int radius = 50;//圆的半径
 int time = 100;//计数时长

 int index;
 int offsetIndex;
 float viewX, viewY;//图形中心点坐标

 float width;//屏幕宽度
 float partWidth;//屏幕宽度的1/4
 int paddingLeft, paddingRight;//图形内边距
 float x1, y1, x2, y2, x3, y3, x4, y4;//圆形左上右下四个点

 float x12, y12, x23, y23, x34, y34, x41, y41;//圆形左上右下四个点之间的渐变点

 public BezierView(Context context) {
  this(context, null);
 }

 public BezierView(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
 }

 public BezierView(Context context, AttributeSet attrs, int defStyleAttr) {
  super(context, attrs, defStyleAttr);

  paint = new Paint();
  paint.setColor(ResourcesCompat.getColor(getResources(), R.color.colorPrimary, null));
  paint.setAntiAlias(true);
 }


 @Override
 protected void onDraw(Canvas canvas) {
  paddingLeft = getPaddingLeft();
  paddingRight = getPaddingRight();
  width = getWidth() - paddingLeft - paddingRight;
  partWidth = width / 4;

  path = new Path();
  path.moveTo(x1, y1);
  path.cubicTo(x1, y1, x12, y12, x2, y2);
  path.cubicTo(x2, y2, x23, y23, x3, y3);
  path.cubicTo(x3, y3, x34, y34, x4, y4);
  path.cubicTo(x4, y4, x41, y41, x1, y1);
  canvas.drawPath(path, paint);

  move();
 }


 public void move() {
  new Timer().schedule(new TimerTask() {
   @Override
   public void run() {
    if (index < time - 1) {
     index++;
     viewX = width / time * index + paddingLeft;
     viewY = 400;

     x1 = viewX - radius;
     x2 = viewX;
     x3 = viewX + radius;
     x4 = viewX;

     y1 = viewY;
     y2 = viewY - radius;
     y3 = viewY;
     y4 = viewY + radius;

     offsetIndex = index % (time / 4) + 1;

     //根据图形移动到的区域进行曲线变化
     float position = (viewX - paddingLeft) / partWidth;

     //右边半圆
     if (position >= 0 && position < 1) {
      x3 = viewX + radius + radius / (time / 4) * offsetIndex;
     } else if (position >= 1 && position < 2) {
      x3 = viewX + radius + radius;
     } else if (position >= 2 && position < 3) {
      x3 = viewX + radius + radius - radius / (time / 4) * offsetIndex;
     } else {
      x3 = viewX + radius;
     }
     x23 = x34 = x3;
     y12 = y23 = y2;

     //左边半圆
     if (position >= 1 && position < 2) {
      x1 = viewX - radius - radius / (time / 4) * offsetIndex;
     } else if (position >= 2 && position < 3) {
      x1 = viewX - radius - radius;
     } else if (position >= 3) {
      x1 = viewX - radius - radius + radius / (time / 4) * offsetIndex;
     } else {
      x1 = viewX - radius;
     }
     x12 = x41 = x1;
     y34 = y41 = y4;

     postInvalidate();
    } else {
     cancel();
    }
   }
  }, 0, 5000);
 }

}

以上就是Android自定义View实现弹性小球效果的全部内容,希望对大家开发Android能带来一定的帮助,如果有疑问大家可以留言交流。谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

Android设计登录界面、找回密码、注册功能

这篇文章主要为大家详细介绍了Android设计登录界面的方法,Android实现找回密码、注册功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android通过手势实现答题器翻页效果

这篇文章主要为大家详细介绍了Android通过手势实现答题器翻页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android采用双缓冲技术实现画板

这篇文章主要为大家详细介绍了Android采用双缓冲技术实现画板的相关资料,思路清晰,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android开发之毛玻璃效果实例代码

这篇文章主要给大家分享android开发之毛玻璃效果的实例代码,非常具有参考借鉴价值,感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

Android实现桌面悬浮窗、蒙板效果实例代码

这篇文章主要介绍了Android实现桌面悬浮窗、蒙板效果实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

深入解读Android的Volley库的功能结构

这篇文章主要介绍了Android的Volley开发框架的功能结构,Volley是Android开发中网络部分的一大利器,包含很多HTTP协议通信的相关操作,需要的朋友可以参考下
收藏 0 赞 0 分享

Android开发中使用Volley库发送HTTP请求的实例教程

这篇文章主要介绍了Android开发中使用Volley库发送HTTP请求的实例教程,包括创建Volley单例的基本知识与取消Request请求的技巧等,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿QQ聊天撒花特效 很真实

本文写的这个特效,是关于聊天的,你肯定遇到过,就是你跟人家聊天的时候,比如发送应(么么哒),然后屏幕上全部就是表情了,今天我们就是做这个,撒花的特效,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android的HTTP操作库Volley的基本使用教程

这篇文章主要介绍了Android的HTTP操作库Volley的基本使用教程,包括JSON请求与图片加载等用法的实例,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿水波纹流量球进度条控制器

这篇文章主要介绍了Android仿水波纹流量球进度条控制器的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多