基于ExoPlayer的自定义通知栏的音频播放服务

2023-10-23 12:30

本文主要是介绍基于ExoPlayer的自定义通知栏的音频播放服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言在接手的项目中,有用到音频播放功能,而用到的库基本以及停止维护了(虽然也是基于exoplayer的库),但通知栏样式只有一种就是默认的,若遇到设计需要改,比较难,还需要拷贝库源代码进行修改,针对这一点,同时也为了更好的学习,于是就写了一个通用的带有自定义通知栏的音频服务,当然这也是基于exoplayer最新版本

1.仓库引入

//root/build
allprojects {repositories {...maven { url 'https://jitpack.io' }}
}//app/build
implementation 'com.github.IAmWilling:MediaPlayerServer:1.0.1'

2.初始化播放服务

//Application下初始化
//参数1 Application 参数2 Notification实例(DefaultNotification内部封装需要传入此实例可高度自定义API参考下面)
MediaPlayerService.init(this,DefaultNotification.Builder().build())

3.音频监听器

//音频播放状态
interface MediaPlayStateListener
//音频进度
interface MediaProgressListener
//音频切换声音
interface MediaSwitchTrackChange
//音频错误监听
interface MediaErrorListener

3.使用

MediaManager 音频管理类含有播放以及暂停等功能

/**
* @param itemList 需要实现PlaylistItem接口
* @param index 选择播放 默认为0
*/
MediaManager.playList(item:PlaylistItem,playIndex:Int = 0)
//上一首
MediaManager.playLast()
//下一首
MediaManager.playNext()
//设置播放模式
MediaManager.switchPlayMode(mode:Int)
//exoPlayer实例 若是有些功能没有实现,则可以拿到实例进行相应功能调用
MediaManager.getSimpleExoPlayer()
//等等....具体查看该类SDK API

4.API详解

MediaManager API

    /*** 添加进度监听*/fun addProgressListener(mediaProgressListener: MediaProgressListener)/*** 添加音频播放状态监听*/fun addMediaPlayerStateListener(mediaPlayStateListaner: MediaPlayStateListaner)/*** 添加音频错误监听*/fun addMediaErrorListener(mediaErrorListener: MediaErrorListener) /*** 移除音频进度监听*/fun removeProgressListener(mediaProgressListener: MediaProgressListener) /*** 移除音频错误监听*/fun removeErrorListener(mediaErrorListener: MediaErrorListener) /*** 移除音频改变监听*/fun removeMediaSwitchChange(mediaSwitchTrackChange: MediaSwitchTrackChange) /*** 添加音频改变监听*/fun addMediaSwitchChange(mediaSwitchTrackChange: MediaSwitchTrackChange) /*** 是否正在播放*/fun isPlaying()/*** 当前音频缓存的封面bitmap*/fun getCacheBitmap(): Bitmap/*** 设置当前id的bitmap*/fun setCacheBitmap(bitmap: Bitmap)/*** 播放下一首*/fun playNext(): Boolean /*** 播放上一首*/fun playLast(): Boolean/*** 播放切换*/fun playOrPause()/*** 播放列表(按顺序播放)** @param mutableList 播放列表*/fun playlist(mutableList: MutableList<PlaylistItem>, playIndex: Int = 0) /*** {@see #MediaPlayerExoPlayMode}** 切换音频播放模式*/fun switchPlayMode(@MediaPlayerExoPlayMode mode: Int) /*** 获取当前播放id*/fun currentId() = simpleExoPlayer.currentMediaItem?.mediaId/*** 获取播放实例*/fun getSimpleExoPlayer(): SimpleExoPlayer /*** 获取播放总进度*/fun getCurrentDuration()/*** 获取当前音频标题*/fun getCurrentMediaTitle(): String /*** 获取当前音频详情*/fun getCurrentMediaDesc(): String /*** 获取当前音频封面地址*/fun getCurrentMediaCover(): String /*** 获取当前播放模式** @link {#MediaPlayerExoPlayMode}*/fun getCurrentPlayMode(): Int

Notification.Builder API

     /*** 设置通知栏应用图标*/fun setSmallIcon(resid: Int): Builder /*** 设置通知栏自定义布局* 不设置 则 默认是sdk自带布局*/fun setRemoteViews(layoutId: Int): Builder /*** 设置图标*/fun setLargeIcon(icon: Bitmap?): Builder/*** 设置播放状态* 非必要初始化不需要设置*/fun setPlayState(state: Boolean): Builder /*** 设置通知栏音频标题* 初始化可设置初始标题*/fun setTitleText(title: String): Builder /*** 设置通知栏布局详情* 初始化可设置初始详情*/fun setIntroText(intro: String): Builder/*** 设置封面*/fun setMediaCover(bitmap: Bitmap): Builder /*** 设置播放状态时的图片*/fun setPlayImage(resid: Int): Builder/*** 设置暂停状态时的图片*/fun setPauseImage(resid: Int): Builder /*** 设置上一曲图片*/fun setLastImage(resid: Int): Builder /*** 设置下一曲图片*/fun setNextImage(resid: Int): Builder/*** 设置通知栏适配小型布局* 有些手机需要设置比如小米,总是初始为小布局 * 锁屏界面需要的话 可以设置*/fun setSmallRemoteViews(layoutId: Int): /*** 设置通知栏整体点击之后需要跳转的activity组* 一般最后一个activity是你需要最终跳转到activity* 第一个一般都是MainActivity 看需求*/fun setStartActivityClassArray(array: Array<Class<*>>): Builder/*** 跳转之后需要携带的一些数据可以自己设置 * 但这些数据最好是全局都可以拿到的,比如在MediaManager可以拿到的任何数据等*/fun setStartActivityBundle(extraName: String, block: () -> Bundle): Builder /*** 打包*/fun build(): Notification

5.自定义通知栏布局注意事项(重要

标题和详情需要为TextView 其余的需要设置的id组件都是ImageView 或者说也只能是ImageView

  • 若要展示封面则ImageView需要设置id为:”default_song_cover_img“
  • 若要展示通知栏的关闭按钮则ImageView需要设置id为:
    “default_notific_close”
  • 上一首:“default_last”
  • 下一首:“default_next”
  • 播放与暂停: “default_play”
  • 歌曲标题:“default_song_name”
  • 歌曲详情:“default_song_intro”

6.看Demo具体的操作设置

效果图:

库地址:github_链接

点个star就是我的动力,继续学习!

这篇关于基于ExoPlayer的自定义通知栏的音频播放服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/267851

相关文章

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

如何自定义一个log适配器starter

《如何自定义一个log适配器starter》:本文主要介绍如何自定义一个log适配器starter的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求Starter 项目目录结构pom.XML 配置LogInitializer实现MDCInterceptor

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

如何关闭Mac的Safari通知? 3招教你关闭Safari浏览器网站通知的技巧

《如何关闭Mac的Safari通知?3招教你关闭Safari浏览器网站通知的技巧》当我们在使用Mac电脑专注做一件事情的时候,总是会被一些消息推送通知所打扰,这时候,我们就希望关闭这些烦人的Mac通... Safari 浏览器的「通知」功能本意是为了方便用户及时获取最新资讯,但很容易被一些网站滥用,导致我们

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Java 的 Condition 接口与等待通知机制详解

《Java的Condition接口与等待通知机制详解》在Java并发编程里,实现线程间的协作与同步是极为关键的任务,本文将深入探究Condition接口及其背后的等待通知机制,感兴趣的朋友一起看... 目录一、引言二、Condition 接口概述2.1 基本概念2.2 与 Object 类等待通知方法的区别

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构