热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Flutter播放assets配置目录的音频文件(亲测有效)

1. 修改pubspec.yaml配置,添加audioplayers插件和本地音频文件位置,记得Pubupgrade,Pubget。dependencies:#音乐播放audiop

1. 修改pubspec.yaml配置,添加audioplayers插件和本地音频文件位置,记得Pub upgrade,Pub get。

dependencies:
# 音乐播放
audioplayers: ^0.13.1
flutter:
uses-material-design: true
# 静态资源
assets:
- static/sounds/

比如,以下是我Flutter项目添加的音频文件:

《Flutter播放assets配置目录的音频文件(亲测有效)》

 2. 安卓配置文件AndroidManifest.xml添加权限(后面几个是核心)










3. 音频播放工具类(Dart版本支持新特性)

import 'dart:async';
import 'dart:io';
import 'dart:typed_data';
import 'package:audioplayers/audio_cache.dart';
import 'package:audioplayers/audioplayers.dart';
import 'package:flutter/services.dart';
import 'package:path_provider/path_provider.dart';
// 单例模式
final AudioPlayerUtil audioPlayerUtil = new AudioPlayerUtil();
///
/// Title: Flutter提示声音工具类
/// Description:
/// 1. 单例模式
/// 2. 文件缓存管理优化
/// 3. 播放Flutter项目本地assets音频文件
/// 4. 播放网络音频文件
///
/// @version 1.0.0
/// @date 2021/12/31
///
class AudioPlayerUtil {
static String SOUNDS_PATH = "static/sounds/";
static String SUCCESS_FILE = "success.mp3";
static String ERROR_FILE = "error.mp3";
static late AudioPlayer _audioPlayer;
static late AudioCache _audioCache;
// 工厂方法构造函数
factory AudioPlayerUtil() => _getInstance();
// instance的getter方法,singletonManager.instance获取对象
static AudioPlayerUtil get instance => _getInstance();
// 静态变量_instance,存储唯一对象
static AudioPlayerUtil _instance = AudioPlayerUtil.internal();
// 获取对象
static AudioPlayerUtil _getInstance() {
if (_instance == null) {
// 使用私有的构造方法来创建对象
_instance = AudioPlayerUtil.internal();
}
return _instance;
}
// 私有命名式构造方法,通过它实现一个类 可以有多个构造函数,
// 子类不能继承internal
// 不是关键字,可定义其他名字
AudioPlayerUtil.internal() {
// 初始化...
_audioCache = AudioCache();
_audioPlayer = AudioPlayer();
print("初始化成功...");
}
// 音频文件夹, 缓存使用,path:文件
Map loadedFiles = {};
///播放
loadAudioCache(String fileName) {
// 播放给定的[fileName]。
// 如果文件已经缓存,它会立即播放。否则,首先等待文件加载(可能需要几毫秒)。
// 它创建一个新的实例[AudioPlayer],所以它不会影响其他的音频播放(除非你指定一个[fixedPlayer],在这种情况下它总是使用相同的)。
// 返回实例,以允许以后的访问(无论哪种方式),如暂停和恢复。
_audioCache.play(fileName, mode: PlayerMode.LOW_LATENCY);
}
///清空单个
void clear(String fileName) {
loadedFiles.remove(fileName);
}
///清空整个
void clearCache() {
loadedFiles.clear();
}
/// 读取assets文件
static Future _fetchAsset(String fileName) async {
return await rootBundle.load('${SOUNDS_PATH}${fileName}');
}
/// 读取到内存
static Future _fetchToMemory(String fileName) async {
String path = '${(await getTemporaryDirectory()).path}/${fileName}';
final file = File(path);
await file.create(recursive: true);
return await file.writeAsBytes((await _fetchAsset(fileName)).buffer.asUint8List());
}
///读取文件
Future _loadFile(String fileName) async {
if (!loadedFiles.containsKey(fileName)) {
// 新增到缓存
loadedFiles[fileName] = await _fetchToMemory(fileName);
}
return loadedFiles[fileName];
}
/// 本地音乐文件播放
playLocal(String fileName) async {
// 读取文件
File? file = await _loadFile(fileName);
// 播放音频
// 如果[isLocal]为true, [url]必须是本地文件系统路径。
int result = await _audioPlayer.play(file!.path, isLocal: true);
if (result == 1) {
print('play success');
} else {
print('play failed');
}
}
/// 远程音乐文件播放,localPath类似http://xxx/xxx.mp3
playRemote(String localPath) async {
int result = await _audioPlayer.play(localPath);
if (result == 1) {
print('play success');
} else {
print('play failed');
}
}
playLocalSuccess() async{
playLocal(SUCCESS_FILE);
}
playLocalError() async{
playLocal(ERROR_FILE);
}
///暂停
pause() async {
// 暂停当前播放的音频。
// 如果你稍后调用[resume],音频将从它的点恢复
// 已暂停。
int result = await _audioPlayer.pause();
if (result == 1) {
print('pause success');
} else {
print('pause failed');
}
}
/// 调整进度 - 跳转指定时间
/// milliseconds 毫秒
jump(int milliseconds) async {
//移动光标到目标位置。
int result =
await _audioPlayer.seek(new Duration(milliseconds: milliseconds));
if (result == 1) {
print('seek to success');
} else {
print('seek to failed');
}
}
///调整音量
///double volume 音量 0-1
setVolume(double volume) async {
// 设置音量(振幅)。
// 0表示静音,1表示最大音量。0到1之间的值是线性的
int result = await _audioPlayer.setVolume(volume);
if (result == 1) {
print('seek to success');
} else {
print('seek to failed');
}
}
///释放资源
release() async {
// 释放与该媒体播放器关联的资源。
// 当你需要重新获取资源时,你需要重新获取资源
// 调用[play]或[setUrl]。
int result = await _audioPlayer.release();
if (result == 1) {
print('release success');
} else {
print('release failed');
}
}
}

4. Page页面调用播放音频

import 'package:/common/util/audio_player_util.dart';
// 播放错误error.mp3
audioPlayerUtil.playLocalError();
// 播放成功success.mp3
audioPlayerUtil.playLocalSuccess();

参考:

9.1.flutter-音频 – 简书


推荐阅读
  • 在分析Android的Audio系统时,我们对mpAudioPolicy->get_input进行了详细探讨,发现其背后涉及的机制相当复杂。本文将详细介绍这一过程及其背后的实现细节。 ... [详细]
  • 本文探讨了Android系统中支持的图像格式及其在不同版本中的兼容性问题,重点涵盖了存储、HTTP传输、相机功能以及SparseArray的应用。文章详细分析了从Android 10 (API 29) 到Android 11 的存储规范变化,并讨论了这些变化对图像处理的影响。此外,还介绍了如何通过系统升级和代码优化来解决版本兼容性问题,以确保应用程序在不同Android版本中稳定运行。 ... [详细]
  • 往期文章Prom ... [详细]
  • 本视频教程将带你快速了解 Android 开发的基础知识,并详细讲解如何在 Android 应用中使用 SQLite 数据库进行数据存储和管理。 ... [详细]
  • 在Android应用开发中,实现与MySQL数据库的连接是一项重要的技术任务。本文详细介绍了Android连接MySQL数据库的操作流程和技术要点。首先,Android平台提供了SQLiteOpenHelper类作为数据库辅助工具,用于创建或打开数据库。开发者可以通过继承并扩展该类,实现对数据库的初始化和版本管理。此外,文章还探讨了使用第三方库如Retrofit或Volley进行网络请求,以及如何通过JSON格式交换数据,确保与MySQL服务器的高效通信。 ... [详细]
  • 在Android 4.4系统中,通过使用 `Intent` 对象并设置动作 `ACTION_GET_CONTENT` 或 `ACTION_OPEN_DOCUMENT`,可以从相册中选择图片并获取其路径。具体实现时,需要为 `Intent` 添加相应的类别,并处理返回的 Uri 以提取图片的文件路径。此方法适用于需要从用户相册中选择图片的应用场景,能够确保兼容性和用户体验。 ... [详细]
  • 本文详细探讨了OpenCV中人脸检测算法的实现原理与代码结构。通过分析核心函数和关键步骤,揭示了OpenCV如何高效地进行人脸检测。文章不仅提供了代码示例,还深入解释了算法背后的数学模型和优化技巧,为开发者提供了全面的理解和实用的参考。 ... [详细]
  • 在Spring Boot项目中,通过YAML配置文件为静态变量设置值的方法与实践涉及以下几个步骤:首先,创建一个新的配置类。需要注意的是,自动生成的setter方法默认是非静态的,因此需要手动将其修改为静态方法,以确保静态变量能够正确初始化。此外,建议使用`@Value`注解或`@ConfigurationProperties`注解来注入配置属性,以提高代码的可读性和维护性。 ... [详细]
  • 本文深入探讨了Spring Cloud Eureka在企业级应用中的高级使用场景及优化策略。首先,介绍了Eureka的安全配置,确保服务注册与发现过程的安全性。接着,分析了Eureka的健康检查机制,提高系统的稳定性和可靠性。随后,详细讨论了Eureka的各项参数调优技巧,以提升性能和响应速度。最后,阐述了如何实现Eureka的高可用性部署,保障服务的连续性和可用性。通过这些内容,开发者可以更好地理解和运用Eureka,提升微服务架构的整体效能。 ... [详细]
  • Envoy 流量分配策略优化
    在本研究中,我们对Envoy的流量分配策略进行了优化,旨在提高系统的稳定性和性能。实验环境包括一个前端代理服务(Envoy,IP地址为172.31.57.10)和五个后端服务。通过调整Envoy的配置,实现了更高效的流量分发和负载均衡,显著提升了整体系统的响应速度和可靠性。 ... [详细]
  • 解决发布版APK构建失败的问题 ... [详细]
  • 零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ... [详细]
  • Tornado框架中模块与静态文件的应用
    本文详细介绍了Tornado框架中模块和静态文件的使用方法。首先明确模块与模板的区别,然后通过具体的代码示例展示如何在HTML文档中使用模块,并配置模块的路由。最后,提供了模块类中参数获取的示例。 ... [详细]
  • oracle c3p0 dword 60,web_day10 dbcp c3p0 dbutils
    createdatabasemydbcharactersetutf8;alertdatabasemydbcharactersetutf8;1.自定义连接池为了不去经常创建连接和释放 ... [详细]
  • Android目录遍历工具 | AppCrawler自动化测试进阶(第二部分):个性化配置详解
    终于迎来了“足不出户也能为社会贡献力量”的时刻,但有追求的测试工程师绝不会让自己的生活变得乏味。与其在家消磨时光,不如利用这段时间深入研究和提升自己的技术能力,特别是对AppCrawler自动化测试工具的个性化配置进行详细探索。这不仅能够提高测试效率,还能为项目带来更多的价值。 ... [详细]
author-avatar
晨曦微露jie
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有