• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Android > Android音频开发之基础知识介绍

Android音频开发之基础知识介绍

作者:网友 字体:[增加 减小] 来源:互联网 时间:2017-05-26

网友通过本文主要向大家介绍了android 音频开发,android 音频,android音频播放器,android 音频录制,android 音频焦点等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

Android音频开发之基础知识介绍


先来点闲言碎语,前段时间我有一段感悟:Android开发,本身并不是一个可以走得多远的方向,它只是一个平台,提供了许多封装好的API,让大家能够快速开发出针对特定业务的应用。

 

真正有价值的地方就在于Android与具体的业务方向结合,比如:Android与音视频技术,Android与智能硬件交互,Android与前端技术的融合与探索,Android信息安全,Android源码深度定制等等。

 

我一直比较看好音视频/多媒体方向,希望在此能够深入积累和探索,前段时间我发布了一款Android VoIP网络电话应用“飞鸽电话”,并写了一篇分析其整体架构的文章《PigeonCall:一款Android VoIP网络电话App架构分析》,欢迎有兴趣的小伙伴们先看一看。

 

在这个应用的开发过程中学到的东西还蛮多的,因此想写一些文章分享分享,本文作为开篇,主要以问答的形式,介绍一些音频开发的基础常识,非常重要,因为不了解这些常识,很多Android API或者第三方库的参数,你都不知道该怎么配置。

 

1. 音频开发的主要应用有哪些?

 

音频播放器,录音机,语音电话,音视频监控应用,音视频直播应用,音频编辑/处理软件,蓝牙耳机/音箱,等等。

 

2. 音频开发的具体内容有哪些?

 

(1)音频采集/播放

(2)音频算法处理(去噪、静音检测、回声消除、音效处理、功放/增强、混音/分离,等等)

(3)音频的编解码和格式转换

(4)音频传输协议的开发(SIP,A2DP、AVRCP,等等)

 

3. 音频应用的难点在哪?

 

延时敏感、卡顿敏感、噪声抑制(Denoise)、回声消除(AEC)、静音检测(VAD)、混音算法,等等。

 

4. 音频开发基础概念有哪些?

 

在音频开发中,下面的这几个概念经常会遇到。

 

(1) 采样率(samplerate)

 

采样就是把模拟信号数字化的过程,不仅仅是音频需要采样,所有的模拟信号都需要通过采样转换为可以用0101来表示的数字信号,示意图如下所示:

 

wKioL1bdXQviw_TBAAAVYm_x3gk862.gif

 

蓝色代表模拟音频信号,红色的点代表采样得到的量化数值。

 

采样频率越高,红色的间隔就越密集,记录这一段音频信号所用的数据量就越大,同时音频质量也就越高。

 

根据奈奎斯特理论,采样频率只要不低于音频信号最高频率的两倍,就可以无损失地还原原始的声音。

 

通常人耳能听到频率范围大约在20Hz~20kHz之间的声音,为了保证声音不失真,采样频率应在40kHz以上。常用的音频采样频率有:8kHz、11.025kHz、22.05kHz、16kHz、37.8kHz、44.1kHz、48kHz、96kHz、192kHz等。

 

(2) 量化精度(位宽)

 

上图中,每一个红色的采样点,都需要用一个数值来表示大小,这个数值的数据类型大小可以是:4bit、8bit、16bit、32bit等等,位数越多,表示得就越精细,声音质量自然就越好,当然,数据量也会成倍增大。

 

常见的位宽是:8bit 或者 16bit

 

(3) 声道数(channels)

 

由于音频的采集和播放是可以叠加的,因此,可以同时从多个音频源采集声音,并分别输出到不同的扬声器,故声道数一般表示声音录制时的音源数量或回放时相应的扬声器数量。

 

单声道(Mono)和双声道(Stereo)比较常见,顾名思义,前者的声道数为1,后者为2

 

(4) 音频帧(frame)

 

这个概念在应用开发中非常重要,网上很多文章都没有专门介绍这个概念。

 

音频跟视频很不一样,视频每一帧就是一张图像,而从上面的正玄波可以看出,音频数据是流式的,本身没有明确的一帧帧的概念,在实际的应用中,为了音频算法处理/传输的方便,一般约定俗成取2.5ms~60ms为单位的数据量为一帧音频。

 

这个时间被称之为“采样时间”,其长度没有特别的标准,它是根据编解码器和具体应用的需求来决定的,我们可以计算一下一帧音频帧的大小:

 

假设某通道的音频信号是采样率为8kHz,位宽为16bit,20ms一帧,双通道,则一帧音频数据的大小为:

 

int size = 8000 x 16bit x 0.02s x 2= 5120 bit = 640 byte

 

5. 常见的音频编码方式有哪些?

 

上面提到过,模拟的音频信号转换为数字信号需要经过采样和量化,量化的过程被称之为编码,根据不同的量化策略,产生了许多不同的编码方式,常见的编码方式有:PCM 和 ADPCM,这些数据代表着无损的原始数字音频信号,添加一些文件头信息,就可以存储为WAV文件了,它是一种由微软和IBM联合开发的用于音频数字存储的标准,可以很容易地被解析和播放。

 

我们在音频开发过程中,会经常涉及到WAV文件的读写,以验证采集、传输、接收的音频数据的正确性。

 

6. 常见的音频压缩格式有哪些?

 

首先简单介绍一下音频数据压缩的最基本的原理:因为有冗余信息,所以可以压缩。

 

(1) 频谱掩蔽效应: 人耳所能察觉的声音信号的频率范围为20Hz~20KHz,在这个频率范围以外的音频信号属于冗余信号。

 

(2) 时域掩蔽效应: 当强音信号和弱音信号同时出现时,弱信号会听不到,因此,弱音信号也属于冗余信号。

 

下面简单列出常见的音频压缩格式:

 

MP3,AAC,OGG,WMA,Opus,FLAC,APE,m4a,AMR,等等

 

7. Adndroid VoIP相关的开源应用有哪些 ?

 

imsdroid,sipdroid,csipsimple,linphone,WebRTC 等等

 

8. 音频算法处理的开源库有哪些 ?

 

speex、ffmpeg,webrtc audio module(NS、VAD、AECM、AGC),等等

 

10. Android提供了哪些音频开发相关的API?

 

音频采集: MediaRecoder,AudioRecord

音频播放: SoundPool,MediaPlayer,AudioTrack (它们之间的区别可以参考这篇文章)

音频编解码: MediaCodec

NDK API: OpenSL ES

 

11. 音频开发的延时标准是什么?

 

ITU-TG.114规定,对于高质量语音可接受的时延是300ms。一般来说,如果时延在300~400ms,通话的交互性比较差,但还可以接受。时延大于400ms时,则交互通信非常困难。

 

12. 小结

 

音频开发的知识点其实挺多的,一篇文章也无法详细地展开叙述,因此,不够全面和详尽的地方,请大家搜索专业的资料进行深入了解。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 记一次Android系统下解决音频UnderRun问题的过程
  • Android音频开发(5):音频数据的编解码
  • 管理音频播放(摘自Android官方培训课程中文版(v0.9.5))
  • Android音频开发之基础知识介绍

相关文章

  • 2017-05-26Android对应用程序签名,android签名
  • 2017-05-26android WebView控件显示网页,androidwebview
  • 2017-05-26andriod ==和equals,andriodequals
  • 2017-05-222.6.1 PopupWindow(悬浮框)的基本使用
  • 2017-05-228.3.3 Paint API之—— MaskFilter(面具)
  • 2017-05-26VS2015墙内创建ionic2 【利用nrm更换源,完美!】,vs2015ionic2
  • 2017-05-26AsyncTask注意事项,面试技巧和注意事项
  • 2017-05-26Android--去除EditText边框及添加下划线
  • 2017-05-26「视频直播技术详解」系列之六:现代播放器原理,
  • 2017-05-26Android第一天-->布局,android第一天--

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 8.2.1 Bitmap(位图)全解析 Part 1
    • [android] 手机卫士手机定位的原理,android卫士
    • [better practice系列]Android处理好activity正确情况下的生命周期和意外情况下的生命周期浅析
    • 详解Android中的SQLite数据库存储
    • android权限大全
    • 手机产品设计之用户引导,手机产品设计引导
    • Android View体系(九)自定义View
    • 我的android学习经历4,android学习经历4
    • nginx 1.12 stream 日志设置
    • Android广播机制

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有