因为项目需要,要做一个下载暂停开始的按钮,要求按钮上显示进度。网上找了找没有合适的,不太满意,于是自己动手写了一个。

效果如下:

主要步骤:

1、最外侧的圆环。

2、圆环内侧代表进度的圆弧。

3、暂停时在中心部位画出三角形。

4、播放时在中心部位画出矩形。

5、重写onTouch方法,DOWN事件时设置播放或者暂停的状态。

6、添加一个状态监听器,在调用者中监听状态。

7、设置进度,重绘。

代码比较简单,所以贴出来View的代码,Activity和布局文件就不写了:

/** Created by xuzhilei on 2016/8/16. 模仿音乐暂停开始按钮的View */

public class PlayButtonView extends View {

/** 中心点X轴坐标 */

private int viewCenterX;

/** 中心点Y轴坐标 */

private int viewCenterY;

/** 有效长度的一般(View长宽较小者的一半) */

private int viewHalfLength;

/** 三角形右侧顶点 */

private Point pointA = new Point();

/** 三角形左上顶点 */

private Point pointB = new Point();

/** 三角形左下顶点 */

private Point pointC = new Point();

/** 矩形左边界 */

private int RectLeft;

/** 矩形上边界 */

private int RectTOP;

/** 矩形右边界 */

private int RectRight;

/** 矩形下边界 */

private int RectBottom;

/** 三角形的三条边路径 */

private Path path = new Path();

/** 包围最外侧圆环的矩形 */

private RectF rectF = new RectF();

/** 包围进度圆弧的矩形 */

private RectF rectF2 = new RectF();

/** 进度 */

private int progress;

/** 暂停中还是播放中 */

private boolean isPlaying = false;

/** 是否进行过了测量 */

private boolean isMeasured = false;

/** 画笔颜色 */

private int color = 0xffff0099;

/** 最外侧圆环画笔 */

private Paint paintA = new Paint();

/** 进度圆弧画笔 */

private Paint paintB = new Paint();

/** 暂停开始画笔 */

private Paint paintC = new Paint();

/** 状态监听器 */

private OnStatusChangeListener onStatusChangeListener;

/** 构造器 */

public PlayButtonView(Context context, AttributeSet attrs) {

super(context, attrs);

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

if (!isMeasured) {

getWidthAndHeight();

isMeasured = true;

}

}

/** 得到视图等的高度宽度尺寸数据 */

private void getWidthAndHeight() {

int viewHeight = getMeasuredHeight();

int viewWidth = getMeasuredWidth();

viewCenterX = viewWidth / 2;

viewCenterY = viewHeight / 2;

viewHalfLength = viewHeight < viewWidth ? viewHeight / 2 : viewWidth / 2;

int paintAwidth = viewHalfLength / 15;

int paintBwidth = viewHalfLength / 8;

rectF.left = viewCenterX - (viewHalfLength - paintAwidth / 2);

rectF.top = viewCenterY - (viewHalfLength - paintAwidth / 2);

rectF.right = viewCenterX + (viewHalfLength - paintAwidth / 2);

rectF.bottom = viewCenterY + (viewHalfLength - paintAwidth / 2);

rectF2.left = viewCenterX - (viewHalfLength - paintBwidth / 2);

rectF2.top = viewCenterY - (viewHalfLength - paintBwidth / 2);

rectF2.right = viewCenterX + (viewHalfLength - paintBwidth / 2);

rectF2.bottom = viewCenterY + (viewHalfLength - paintBwidth / 2);

paintA.setColor(color);

paintA.setStrokeWidth(paintAwidth);

paintA.setAntiAlias(true);

paintA.setStyle(Paint.Style.STROKE);

paintB.setColor(color);

paintB.setStrokeWidth(paintBwidth);

paintB.setAntiAlias(true);

paintB.setStyle(Paint.Style.STROKE);

paintC.setColor(color);

paintC.setStrokeWidth(1);

paintC.setAntiAlias(true);

paintC.setStyle(Paint.Style.FILL);

pointA.x = viewCenterX + viewHalfLength / 2;

pointA.y = viewCenterY;

double sin = Math.sin(Math.toRadians(60)); // √(3) / 2

double cos = Math.cos(Math.toRadians(60)); // 1/ 2

pointB.x = (float) ((viewCenterX - cos * viewHalfLength + viewCenterX) / 2);

pointB.y = (float) ((viewCenterY - sin * viewHalfLength + viewCenterY) / 2);

pointC.x = (float) ((viewCenterX - cos * viewHalfLength + viewCenterX) / 2);

pointC.y = (float) ((viewCenterY + sin * viewHalfLength + viewCenterY) / 2);

RectLeft = viewCenterX - viewHalfLength / 3;

RectTOP = viewCenterY - viewHalfLength / 3;

RectRight = viewCenterX + viewHalfLength / 3;

RectBottom = viewCenterY + viewHalfLength / 3;

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

// 画未完成进度的圆环

canvas.drawArc(rectF, 0, 360, false, paintA);

// 画已经完成进度的圆弧 从-90度开始,即从圆环顶部开始

canvas.drawArc(rectF2, -90, progress * 3.6f, false, paintB);

if (isPlaying) {

canvas.drawRect(RectLeft, RectTOP, RectRight, RectBottom, paintC);

} else {

path.reset();

path.moveTo(pointA.x, pointA.y);

path.lineTo(pointB.x, pointB.y);

path.lineTo(pointC.x, pointC.y);

path.close();

canvas.drawPath(path, paintC);

}

}

/** 监听触摸DOWN时间,开始播放,暂停播放 */

@Override

public boolean onTouchEvent(MotionEvent event) {

if (event.getAction() == MotionEvent.ACTION_DOWN) {

isPlaying = !isPlaying;

invalidate();

if (isPlaying) {

onStatusChangeListener.play();

} else {

onStatusChangeListener.pause();

}

}

return super.onTouchEvent(event);

}

/** 设置进度 0-100区间 */

public void setProgress(int progress) {

if (progress < 0) {

progress = 0;

}

if (progress > 100) {

progress = 100;

}

this.progress = progress;

invalidate();

}

/** 外界设置播放状态 */

public void setPlaying(boolean isPlaying) {

this.isPlaying = isPlaying;

invalidate();

}

/** 播放暂停状态监听的接口 */

public interface OnStatusChangeListener {

void play();

void pause();

}

/** 设置监听接口 */

public void setOnStatusChangeListener(OnStatusChangeListener onStatusChangeListener) {

this.onStatusChangeListener = onStatusChangeListener;

}

/** 位置信息 */

private class Point {

float x;

float y;

}

在调用者中设置OnStatusChangeListener 的监听器即可监听播放状态,通过setProgress方法就可以设置进度。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

android 暂停音乐播放器,Android仿音乐播放器带进度的播放暂停按钮相关推荐

  1. 【Android App】实战项目之仿拼多多的直播带货(附源码和演示 超详细必看)

    需要源码请点赞关注收藏后评论区留言私信~~~ 近年来电商业态发生了不小的改变,传统的电商平台把商品分门别类,配上精美的图文说明供消费者挑选,新潮的电商平台则请来明星网红,开启直播秀向广大粉丝推销商品, ...

  2. android输入框圆形,GitHub - mylhyl/Android-CircleDialog: 仿IOS圆角对话框、进度条、列表框、输入框,ad广告框,支持横竖屏切换...

    Android-CircleDialog 基于DialogFragment封装,已封装的对话框类型有,常规对话框.列表框.输入框.进度框: 每个对话框类型也支持自定义边框圆角.背景透明度.字体大小与色 ...

  3. uniapp - [微信小程序] 超详细实时录音功能,录制外部声音及播放上传到服务器(支持录音完毕生成 mp3、试听音频(带进度条)、暂停录音、重新录音、限制录音最大时长、自定义音频名称等功能)

    前言 网上的教程都太乱了,功能不好用且一堆 BUG,没有注释很难改造示例为自己用. 本文实现了 uniapp 微信小程序平台,授权麦克风进行录音并保存为音频的功能,内置播放器可播放录音文件, 您直接复 ...

  4. Android系统(168)---Android 开源项目分类汇总

    Android开源项目分类汇总 原网址:https://blog.csdn.net/prince77qiqiqq/article/details/51338330 Android 开源项目第一篇--个 ...

  5. android仿音乐播放器,Android仿音乐播放器功能

    本文实例为大家分享了Android仿音乐播放器功能的具体代码,供大家参考,具体内容如下 读取本地音乐文件 源代码: import android.media.MediaPlayer; import a ...

  6. android采用MVP完整漫画APP、钉钉地图效果、功能完善的音乐播放器、仿QQ动态登录效果、触手app主页等源码...

    Android精选源码 一个可以上拉下滑的Ui效果,觉得好看可以学学 APP登陆页面适配 一款采用MVP的的完整漫画APP源码 android实现钉钉地图效果源码 一个使用单个文字生成壁纸图片的app ...

  7. android采用MVP完整漫画APP、钉钉地图效果、功能完善的音乐播放器、仿QQ动态登录效果、触手app主页等源码

    Android精选源码 一个可以上拉下滑的Ui效果,觉得好看可以学学 APP登陆页面适配 一款采用MVP的的完整漫画APP源码 android实现钉钉地图效果源码 一个使用单个文字生成壁纸图片的app ...

  8. 安卓java自实现mp3播放器,Android MediaPlayer实现音乐播放器实例代码

    Android MediaPlayer实现音乐播放器 1.布局文件 android:layout_width="fill_parent" android:layout_height ...

  9. Android MediaPlayer 音乐播放器扫描 本地音乐、上一曲、下一曲切歌、播放本地音乐

    Android MediaPlayer 本地音乐播放器 运行截图 项目请在真机(自己的手机)上测试运行,因为我不喜欢用虚拟机. 为了不浪费您的时间,先看一下运行的效果图, 一进去先进行音乐扫描,然后列 ...

最新文章

  1. iOS App上架流程
  2. android alpha不起作用,API 28(P)的Android设计支持库不起作用
  3. web-inf下文件访问
  4. Win8.1 “运行”在Ipad Mini上
  5. linux c 自定义信号 测试kill信号发送
  6. (三)Redis for StackExchange.Redis
  7. tessorflow实战
  8. SAP Spartacus里的HTTPErrorInterceptor的单元测试设计原理
  9. 最小生成树——Kruskal(克鲁斯卡尔)算法
  10. 《计算机网络》学习笔记 ·007【无线网络】
  11. 猿辅导MSMARCO冠军团队:用MARS模型解决机器阅读任务 | 吃瓜笔记
  12. Jzoj5662 尺树寸泓
  13. 蓝桥杯2019年第十届C/C++省赛C组第一题-求和
  14. 正则、grep与egrep工具
  15. Vijos P1423 最佳路线
  16. android小米卸载app,MIUI系统软件卸载工具
  17. springboot 集成J2Cache
  18. 剑指 offer:变态跳水台
  19. 串口调试精灵的使用和串口程序调试技巧
  20. html3d轮播图片效果,CSS3,3D效果轮播图

热门文章

  1. 【bzoj1604】[Usaco2008 Open]Cow Neighborhoods 奶牛的邻居 旋转坐标系+并查集+Treap/STL-set...
  2. asterisk积累命令
  3. Flexigid Options
  4. mybatis的拦截器及分页机制
  5. Netty入门3之----Decoder和Encoder
  6. c语言学习笔记 关于double
  7. JAVA线程池的创建
  8. ios基础篇(十二)——UINavgationController的使用(三)ToolBar
  9. web.xml之context-param与init-param的区别与作用【转】
  10. 计算机组成 冯诺依曼体制