android录音波浪动画_Android 实现圆圈扩散水波动画效果两种方法

本文介绍了两种在Android中实现圆圈扩散水波动画的方法:自定义View和动画实现。自定义View通过不断改变圆半径和透明度来达到扩散效果,而动画则利用ImageView的缩放和渐变动画组合实现。文章提供了详细代码示例,并比较了两者的效果和适用场景。
摘要由CSDN通过智能技术生成

两种方式实现类似水波扩散效果,先上图为敬

自定义view实现

动画实现

201805280858325.gif

自定义view实现

思路分析:通过canvas画圆,每次改变圆半径和透明度,当半径达到一定程度,再次从中心开始绘圆,达到不同层级的效果,通过不断绘制达到view扩散效果

private Paint centerPaint; //中心圆paint

private int radius = 100; //中心圆半径

private Paint spreadPaint; //扩散圆paint

private float centerX;//圆心x

private float centerY;//圆心y

private int distance = 5; //每次圆递增间距

private int maxRadius = 80; //最大圆半径

private int delayMilliseconds = 33;//扩散延迟间隔,越大扩散越慢

private List spreadRadius = new ArrayList<>();//扩散圆层级数,元素为扩散的距离

private List alphas = new ArrayList<>();//对应每层圆的透明度

style文件里自定义属性

初始化

public SpreadView(Context context) {

this(context, null, 0);

}

public SpreadView(Context context, @Nullable AttributeSet attrs) {

this(context, attrs, 0);

}

public SpreadView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.SpreadView, defStyleAttr, 0);

radius = a.getInt(R.styleable.SpreadView_spread_radius, radius);

maxRadius = a.getInt(R.styleable.SpreadView_

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值