android 按键上浮动画_android自定义view实现进度条动画、按钮渐变及录制状态控制...

不得不说自定义view绘制各种图形及它们的动画是令人有成就感的事情。该篇来分享之前项目中写的一个视频录制按钮的自定义view,该view有录制、暂停(结束)等状态的控制,各种状态转变的动画,以及录制进度展示。先看效果(圆圈的小白色段是最小录制时长的标记点):

录制效果

代码的内容其实主要就是绘制进度条、录制按钮的切换动画(圆角正方形—>圆—>圆角正方形)。还是那句话,计算好每个组件的坐标(半径)事情就完成了一半,所以关键在于计算,这里的图形都简单计算并不复杂,只是要稍微细心点。注释都写得比较详细,就不一一解释了,具体看代码:

import android.content.Context;

import android.graphics.Canvas;

import android.graphics.LinearGradient;

import android.graphics.Paint;

import android.graphics.RectF;

import android.graphics.Shader;

import android.util.AttributeSet;

import android.view.View;

import androidx.annotation.Nullable;

import com.robot.common.frame.BaseApp;

import com.robot.common.utils.PixelUtil;

/**

* 视频录制控制、进度

*

* @author ly

* date 2020/3/3 11:02

*/

public class RecordProgressView extends View implements View.OnClickListener {

private static final float changeRatio = 5f;

//最小录制时长标记的弧长

private static final int minPAngle = 2;

private OnRecordStatusListener onRecordStatusListener;

private Paint paint;

//内圈录制、暂停按钮颜色

private int circleInsideColor;

//进度圈颜色

private int circleOutsideColor;

//进度颜色

private int circleProgressColor;

private float progressW;

//进度条圆圈半径

private float circleProgressR;

//内实心圆圈半径

private float circleInsideR;

//录制按钮宽高

private float pauseRectW;

//动态变量内圈半径(逐渐变小或变大)

private float curCircleInsideR;

private

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值