在开发app的过程中有需要播放mp3的功能,一直想实现,但苦于具体的困难一直未能实现,经过一段时间的资料查询和测试,最终摸索出来,现记录如下:

1.最重要的是安装第三方插件ionic-audio,开源地址是 https://github.com/arielfaur/ionic-audio

第一,cd D:\Dev\sourcecode\IonicApp\FlexApp\IonicEnglish 目录下

第二,安装插件到本地: npm install ionic-audio --save, 安装完成后的效果图如下

2.在src/app/app.module.ts文件中加入  IonicAudioModule.forRoot(),如图

3.在我们自己的页面中引入AudioProvider类

 import { Component } from '@angular/core';
import { NavController, NavParams,LoadingController } from 'ionic-angular';
import { URLSearchParams } from '@angular/http';
import { CommonService } from '../../providers/baseService/CommonService';
import { AudioProvider } from 'ionic-audio'; /*
Generated class for the English page. See http://ionicframework.com/docs/v2/components/#navigation for more info on
Ionic pages and navigation.
*/ @Component(
{
selector: 'page-english',
templateUrl: 'english.html'
}) export class EnglishPage
{
private groupEnglish ;
private shownGroup ;
public englishWord:string;
public loading; public startIndex: number; constructor(public navCtrl: NavController, public navParams: NavParams,private loadCtrl:LoadingController,private audioProvider: AudioProvider,private service:CommonService)
{
this.groupEnglish = [];
this.shownGroup = {};
this.startIndex = 0;
} ionViewDidLoad()
{
console.log('ionViewDidLoad EnglishPage');
} search()
{
let url = 'XXXXX';
let val = this.englishWord;
let searchParams = new URLSearchParams()
searchParams.set('key', val); this.loading = this.loadCtrl.create({ content: '加载中...'});
this.loading.present();
this.service.getJsonDataParameter(url,searchParams).then(result =>
{
//this.groupEnglish = result.Data;
this.groupEnglish = [];
for(var i = 0; i< result.Data.length; i++)
{
let ele = {
src: 'url'+result.Data[i].Word+'.mp3',
item : result.Data[i]
};
this.groupEnglish.push(ele);
}
this.loading.dismiss();
},
err =>
{ });
} onTrackFinished(track: any)
{
if(this.audioProvider.tracks.length > this.startIndex )
{
this.startIndex = this.startIndex + 1;
this.autoPlay();
}
else
{
this.startIndex = 0;
this.audioProvider.stop();
}
} autoPlay()
{
this.audioProvider.play(this.startIndex);
} toggleGroup(group,id)
{
if (this.isGroupShown(group))
{
this.shownGroup = null;
}
else
{
this.shownGroup = group;
this.startIndex = id;
this.autoPlay();
}
} isGroupShown(group)
{
return this.shownGroup === group;
}
}

播放mp3的数据格式是A:

{
src: 'mp3数据源,本地的或网络的都可以,必须的字段',
artist: '作者名称',
title: '标题',
art: '图片',
preload: 'metadata' // tell the plugin to preload metadata such as duration for this track, set to 'none' to turn off
},

我这里就根据自己的需要就只用了src数据源字段,同时添加了自己的一个类字段item .

将获得的数据groupEnglish数组绑定到对应的网页上,

 <ion-content>

   <ion-list>
<audio-track #audio *ngFor="let item of groupEnglish" [track]="item" (onFinish)="onTrackFinished($event)">
<ion-item>
<ion-item class="rectangle" (click)="toggleGroup(item.item,audio.id)">
<i class="ion-icon" >
{{item.item.Word}}
</i>
<i style="color:green;font-size:14px"> {{item.item.Accent}}</i>
<i style="font-size:10px">词频</i>
<i style="color:red;font-size:10px"> {{item.item.Index}}</i>
<i style="font-size:10px">{{item.item.Source}}</i>
</ion-item >
<div *ngIf="isGroupShown(item.item)">
<ion-item text-wrap class="rectangle" *ngFor="let it of item.item.Items" >
<div [innerHTML]="it.Sentence">
</div>
</ion-item>
</div>
</ion-item>
</audio-track>
</ion-list>
</ion-content>

其中的audio-track节点是必须的,数据绑定之后的#audio 是一个类,包含了前面的数据源数据A和我们自己的数据item

这里尤其强调的是audio其中的id字段,播放mp3的时候是根据这个id来确定的,这个id基本上是按顺序从0开始的。

基本都这里就实现了mp3的播放。

4.实现自动的播放mp3功能。

基本思路是每一个mp3播放完毕之后都会调用onTrackFinished事件,在这里,调用下一个mp3的开始。

这里一个有意思的事情是,每次查询之后将groupEnglish清零,下标也清零,重新开始从头播放。如果是第一次查询出来的结果,这样一个个的播放是没问题的,但第二次查询出来之后播放的还是第一次的数据,经排查原因是this.audioProvider.tracks还是保留了上一次的数据,所以要么清除上次的数据,要么在原来的基础上id继续增加,我选择的是后者。

Ionic2 播放mp3功能实现的更多相关文章

  1. java实现播放mp3功能

    1.首先引入jlayer.jar <!-- https://mvnrepository.com/artifact/javazoom/jlayer --> <dependency> ...

  2. 在C语言控制台程序中播放MP3音乐

    游戏没有声音多单调. 这里做一个简单的范例,用 mciSendString 函数播放 MP3 格式的音乐,先看看代码吧: // 编译该范例前,请把 background.mp3 放在项目文件夹中 // ...

  3. 微信小程序背景音频播放分享功能

    如果正常背景音频播放的话,只能跳转到自己对应的微信小程序,无法分享朋友圈,我们需要设置分享朋友圈,需要调用一个API 音频背景播放 注意:背景播放在锁屏后播放只支持IOS端,安卓端虽然可以播放,但是锁 ...

  4. Swift实现iOS录音与播放音频功能

    作用AVPLayer:可以用来播放在线及本地音视频AVAudioSession:音频会话,主要用来管理音频设置与硬件交互使用时需要导入 #import <AVFoundation/AVFound ...

  5. 读取SD卡文件夹下的MP3文件和播放MP3文件

    首先获取SD卡path路径下的所有的MP3文件,并将文件名和文件大小存入List数组(此代码定义在FileUtils类中): /** * 读取目录中的Mp3文件的名字和大小 */ public Lis ...

  6. 遭遇flash播放mp3诡异问题

    在部分ie10+flash player 播放mp3,播放第二句话时,中断无法正常播放,(客户的机器上),自己公司的机器测试了几个,都没发现这个问题.其它浏览器(chrome,firefox)也没发现 ...

  7. Android命令行播放MP3音乐

    /*************************************************************************** * Android命令行播放MP3音乐 * 说 ...

  8. ios开发——实用技术篇Swift篇&播放MP3

    播放MP3 // MARK: - 播放MP3 /*----- mp3 ------*/ //定时器- func updateTime() { //获取音频播放器播放的进度,单位秒 var cuTime ...

  9. ubuntu 13.10 Rhythmbox不能播放mp3 和中文乱码的问题

    1.ubuntu 13.10 Rhythmbox不能播放mp3的解决方法 软件中心搜索(ubuntu额外的版权受限软件)不带括号 2.中文乱码问题解决方法: 终端顺序操作 : 1.  sudo ged ...

随机推荐

  1. oracle执行先决条件检查失败的解决方法

    在安装oracle 11g时,出现执行先决条件失败的情况如下: 你可以忽略所有强制安装,一般不会影响功能,但如果你想知道为什么会产生这种错误, 并且当出现以上情况时又该如何解决呢?如下列出了原因和解决 ...

  2. OkHttp3源码详解(二) 整体流程

    1.简单使用 同步: @Override public Response execute() throws IOException { synchronized (this) { if (execut ...

  3. asp.net core中IHttpContextAccessor和HttpContextAccessor的妙用

    分享一篇文章,关于asp.net core中httpcontext的拓展. 现在,试图围绕HttpContext.Current构建你的代码真的不是一个好主意,但是我想如果你正在迁移一个企业类型的应用 ...

  4. python第三十一天-----类的封装、继承,多态.....

    封装 封装最好理解了.封装是面向对象的特征之一,是对象和类概念的主要特性. 封装,也就是把客观事物封装成抽象的类,并且类可以把自己的数据和方法只让可信的类或者对象操作,对不可信的进行信息隐藏. cla ...

  5. 浅谈C#依赖注入

    什么是依赖注入?不管是js中的一些前端框架还是,java,C#,php等中的一些后端开发框架中,都会涉及这个看着逼格略高的词语:依赖注入,越是看着好像很厉害的东西越是会让许多人学习产生恐惧,好像很厉害 ...

  6. 合理配置SQLSERVER内存

    合理配置SQLSERVER内存 原文地址:https://www.cnblogs.com/lyhabc/archive/2012/09/28/2707857.html SQLSERVER是个很喜欢内存 ...

  7. Python & 机器学习之项目实践

    机器学习是一项经验技能,经验越多越好.在项目建立的过程中,实践是掌握机器学习的最佳手段.在实践过程中,通过实际操作加深对分类和回归问题的每一个步骤的理解,达到学习机器学习的目的. 预测模型项目模板不能 ...

  8. Flask应用错误处理

    目录 Flask 应用错误处理 错误日志工具 错误处理 注册 处理 日志 排除应用错误 有疑问时,请手动运行 使用调试器 参考 Flask 应用错误处理 应用出错,服务器出错.或早或晚,你会遇到产品出 ...

  9. Python-数学篇之计算方法的目录:

    目录: 1.出本专题的初衷: 2.参考计算方法的书籍: 3.具体算法的实现: (一)出本专题的初衷: 在我们机械专业的大二上学期课程中,能与计算机沾上边的科目就数<计算方法>了.简化为&q ...

  10. 4.6Python多版本存在问题

    返回总目录 目录: 1.展示效果: 2.操作流程: (一)展示效果: 1.多个版本python运行的情况: 2.多个版本pip运行的情况: (二)操作流程: 1.很关键的一条语句: pythonx.x ...