基于Android平台的可视对讲系统设计

发布者:快乐之源最新更新时间:2013-12-27 来源: 21ic关键字:可视对讲系统  音视频  Android 手机看文章 扫描二维码
随时随地手机看文章
Android是Google公司推出的基于Linux的开源手机操作系统,由于代码开源,受到很多手机厂家的青睐。可视对讲系统在Android操作系统未出现之前,软件研发一般采用底层语言,容易出现功能单一、产品升级困难等情况,要在对讲系统中开发出具有3D图形效果的界面更是难上加难。鉴于此,本文利用Android平台的可移植性、代码开源等优势,结合JNI、NDK技术,提出了基于Android平台的可视对讲系统的设计方案并加以实现。

JNI[1](Java Native Interface)是Java本地调用接口,它使得运行于Android平台的Java程序可以使用C、C++甚至汇编语言编写的动态链接库。在需要频繁访问内存或复杂计算的情况下,使用C动态链接库比在Android平台上使用Java语言实现相同功能更具有效率[2]。NDK[3](Native Development Kit)提供了一系列的工具,可以生成ARM二进制码的动态库,并且能自动地将生成的动态库和Java应用程序一起打包成Android系统可以直接安装的apk安装包,即NDK可以将包含JNI接口函数的C源程序文件编译生成动态库,供Android应用程序调用,提高了对现有代码的重用性,而加快了开发进度。

本文提出一种可视对讲系统设计方案,对讲双方为门口机和室内机,并将设计方案在i.MX51硬件平台进行实现。门口机进行音视频的采集、编码、传输及音频解码、播放;室内机采用Android平台,但考虑用户室内信息的保密性,室内机没有视频采集功能,室内机只进行音视频的解码、播放以及音频的采集、编码、传输。

1 可视对讲系统设计

1.1 通信流程设计

数据包传输协议使用面向无连接、资源消耗小、处理速度快的UDP协议。寻址完成建立UDP直连后,门口机首先对视频进行编码传输,直到被叫方按下接听键后,门口机才对音频数据进行传输。为了保证通话一直在线,室内机每隔一定的时间向门口机发送通话在线询问,如果收到在线确认应答则保持通话状态,否则就结束通话。可视对讲系统通信流程如图1所示。

表2中:包头为对讲数据包的标示符,命令类型、操作类型说明详见表3,时间戳主要是用于音视频的同步,数据类型分为音频和视频两种,帧序号为0~65 535。如果没有进行数据包分段,则总包数与当前包数均为1。音视频数据从第41位开始算起,音视频数据长度由数据包格式中的数据长度所指定。

根据系统通信流程图1、结合数据包格式,本对讲系统参数如表3所示。其中命令类型、操作类型分别与表2数据包格式相对应。

1.5 音视频编解码选择

系统音频编码选用G.711编码[4]。G.711是一种由国际电信联盟订定的音频编解码方式,拥有一倍的压缩率,是语音通信中最常用的编解码方式之一。采样和量化是音频编程及声音数字化的两个关键步骤,本系统使用的音频采样频率为8 kHz、量化位数为16 bit、单声道。[page]

FFmpeg是用于音频和视频开源方案,由于它的开源和免费以及跨平台的特点,受到开发商的青睐。FFmpeg支持包括xvid等在内的多达90种解码器,由C语言实现,不仅可以应用于PC软件平台,也可以用于嵌入式设备。本系统中视频选用xvid编解码器,视频格式为MPEG-4。(xvid是一个开放源代码的MPEG-4视频编解码器)视频标准采用NTSC制,视频尺寸为352×240,帧频为30 F/s;使用NDK提供的交叉编译工具将包含JNI接口函数的音视频编解码源文件统一编译成为动态链接库,供Android平台调用。

2 系统实现

2.1 系统软硬件平台

系统硬件平台为i.MX51 EVK。i.MX51 EVK是由Freescale公司自主研发的,中央处理器基于ARM Cortex A8核心的i.MX51处理器;主频可扩展到1 GHz;处理器内部集成了DDR/DDR2内存控制器、OpenGL/OpenVG图形核心、ATA控制器、以太网控制器等,支持720 p高清视频播放;指令缓存和数据缓存为32 KB,二级缓存为256 KB;其容量指标是之前ARM11产品的2倍,可大大提高CPU的处理能力。同时处理器内部还集成了矢量运算的浮点运算及信号处理加速器,为多媒体信息娱乐终端提供了强大的处理核心支持[5]。

系统软件平台采用Linux操作系统、eclipse集成开发环境。Android SDK[6]版本为2.2,Android NDK版本为android-ndk-r6。使用串口进行调试。

2.2 Android平台在i.MX51 EVK上的移植

系统采用4 GB的SD卡存放引导程序、内核、根文件系统等镜像。引导程序采用U-Boot,Linux内核版本为2.6.31。移植流程:Android源码可以从http://source.android.com获取到,编译好U-Boot、Linux内核、根文件系统以及Android系统镜像[7]后,设置i.MX51板上的S1 Boot Switch模式为1100000001,使用ATK工具进行镜像的下载。下载后系统镜像在SD卡上分布图如图3所示。

图3中,MBR主要存储SD卡的分区信息表,起始地址为0 KB。引导程序、内核、根文件系统的起始地址分别为1 KB、1 MB、4 MB。System和Recovery分别各占一个分区,System为Android操作系统的镜像文件所占分区,Recovery分区主要是用来备份和还原系统。

2.3 音视频编解码实现

2.3.1 音频编解码实现

音频编码与解码的区别仅在于调用的C库函数不一样,音频编解码调用的C库函数分别为G711Encoder、G711Decoder(本文以解码为例)。音频解码具体流程如下:

(1)音频Java本地调用函数

在使用音频解码的类中编写Java本地调用函数:

public native void G711Decoder(byte[]pcm,byte[]code,int size,int lawflag);

(2)生成头文件

C库与Java间需要一个后缀为“.h”的头文件来衔接,这个头文件通过javah命令生成,javah工具包含在JDK中。JDK是Java的核心,包含Java运行环境、Java工具、Java基础类库。

(3)JNI接口函数

JNI接口函数编写在C语言文件中,与音视频解码源码一起打包生成动态链接库。在接口函数中声明4个无符号指针变量:decode指向待解码的数据、depcm指向解码后的数据、enpcm指向待编码的数据、encode指向编码后的数据。解码代码如下:

void Java_com_qsa_play_G711Decoder

(JNIEnv*env,jobject this,jbyteArray pcm,jbyteArray code,jint size,jint lawflag)

{

depcm=(unsigned char*)(*env)->

GetByteArrayElements(env,pcm,0);

decode=(unsigned char*)(*env)->

GetByteArrayElements(env,code,0);

G711Decoder(depcm,decode,size,lawflag);

(*env)->ReleaseByteArrayElements(env, pcm,

(jbyte)depcm,0);

(*env)->ReleaseByteArrayElements(env,code,(jbyte)

decode,0);

}

其中,depcm=(unsigned char*)(*env)->GetByteArrayElements(env,pcm,0)用来获取Java层传递的待解码字节数组的首地址,G711Decoder()函数实现音频解码,(*env)->ReleaseByteArrayElements(env,pcm, (jbyte)depcm,0)释放传递的数组成员,进行资源回收。

(4)使用NDK中ndk-build命令编译生成动态链接库

ndk-build命令是ndk命令工具集中的一个命令,与Linux下shell编程中的make命令相似,它会查找文件夹中的后缀为“.mk”的Makefile文件,根据该文件的依赖文件,将源文件编译成动态链接库。

2.3.2 视频编解码实现

视频的编解码流程与音频编解码流程基本相似,视频编解码调用的C库函数分别为avcodec_encode_video、avcodec_decode_video2。限于篇幅,在此重点介绍Android平台视频的解码及显示。

在解码视频数据前,要先做一系列的准备工作:

(1)给出主要的数据结构

static AVPacket avpkt;

static AVFrame*picture;

static AVFrame*pFrameRGB;

static AVCodec*codec;

static AVCodecContext*c= NULL;

static struct SwsContext*img_convert_ctx;

AndroidBitmapInfo info;

void*pixels;

(2)初始化流程

①注册解码器

avcodec_init();

av_register_all();

②初始化AVPacket、AVCodecContext、AVFrame

av_init_packet(&avpkt);

c=avcodec_alloc_context();

picture=avcodec_alloc_frame();

其中,AVFrame是数据流在编解码过程中用来保存数据缓存的对象,从数据流中读取到的数据首先保存到AVPacket中。一个AVPacket最多只包含一个AVFrame,而一个AVFrame可以包含好几个AVPacket。AVCodecContext用于动态记录一个解码器的上下文信息。[page]

③设置视频解码器

codec=avcodec_find_decoder(MPEG-4);

avcodec_open(c,codec);

④视频解码流程

视频解码流程如图4所示。图4中,AndroidBitmap_getinfo用于获取Android平台Bitmap对象的大小,AndroidBitmap_ lockpixels函数是对Bitmap进行加锁、互斥使用资源。如果AVPacket包中存在未解码完的数据,则调用函数avcodec_decode_ video2进行解码;若解码出一帧后需要调用函数sws_scale进行格式转换。视频数据解码完后颜色空间为YUV,需转换成RGB颜色空间。最后调用fill_bitmap函数进行数据填充及进行Bitmap的解锁和资源的释放。

视频显示采用Android平台的ImageView控件进行显示。解码线程接收到视频数据后,通过JNI调用,调用动态库中的视频解码接口函数进行解码,每解码完一帧后通过消息通知主线程进行显示图像的更新,这样就达到了视频数据动态显示的效果。

3 实现效果

Android平台在i.MX51 EVK平台上移植成功后,串口中Android 操作系统启动信息如图5所示。 从图中的启动信息可以看出,Android平台移植成功,启动信息也包含有CPU信息、内核版本、大小、加载地址、Android文件系统版本等信息。

该软件开发完成后,在Android工程的bin下生成apk文件,并复制apk文件到SD卡中,在Android系统中安装该软件,使用门口机进行拨号,编码后的音视频数据通过网线进行传输。

本文将Android手机操作系统应用于i.MX51 EVK平台,并在该平台上提出了可视对讲的设计方案,分别进行了通信流程、应用协议、功能模块等设计,最后实现了系统的设计方案。但由于视频是使用软件解码,运行效率有待提高,且语音对讲部分回声消除存在问题,有待进一步研究。

关键字:可视对讲系统  音视频  Android 引用地址:基于Android平台的可视对讲系统设计

上一篇:Android系统的内存管理研究
下一篇:μC/OS-III中的高效时钟节拍管理机制

推荐阅读最新更新时间:2024-05-02 22:53

Android 13 Beta 2.1更新发布:修复打开热点时设备崩溃等问题
在 4 月底和 I / O 2022 相继推出 Android 13 的前两个公开测试版本后,谷歌今日发布了 Android 13 Beta 2.1 更新。   IT之家了解到,发布说明显示,用户和开发人员报告的四个问题已在 Android 13 Beta 2.1 中得到解决,该版本为“小更新”,还包括稳定性方面的改进。   此外,今天的 TPBB.220414.018 版本仍为 2022 年 5 月安全补丁。Pixel 6、Pixel 5、Pixel 4 等机型可 OTA 更新 Android 13 Beta 2.1,以 Pixel 4a 为例更新大小仅为 11.80MB
[手机便携]
Android应用增速追上苹果
      谷歌应用商店Android Market中的应用总下载量突破了60亿次大关,其下载次数的增长速率与苹果App store几乎一样,都是10亿次/月。       据了解,Android Market中的应用数量为约25万个,与苹果App store中的超过50万个应用和150亿次下载量相比还有一定差距。根据双方自己公布的数据,Android应用下载量三个月来增长了30亿次,苹果应用下载量五个月来增长了50亿次,双方增长速率上的差距在不断缩小。       周二在日本东京举行的谷歌移动革命大会上,谷歌执行董事长埃里克-施密特说,“每个月,中国和印度新增用户的数量达到了1000万。在印度尼西亚和菲律宾,我们也有望看到令人惊讶
[手机便携]
安卓版Apple Music应用摘掉Beta标签:增加均衡器支持
       新浪手机讯 8月4日下午消息,苹果更新了安卓版Apple Music应用(Apple Music for Android),彻底告别Beta标签,成为正式版。目前,安卓版Apple Music应用的版本号为1.0,历经近10个月的测试终于在Google Play Store上线。   正式版的苹果音乐不仅仅只是摘掉了Beta的标签,还带来了许多新特性。这次的更新,苹果给用户开放了更多权限,包括添加均衡器的设置。用户可以根据自己的需求使用Apple Music应用并调节iTunes的播放内容。在iOS上,调节均衡器是要到设置中操作的,而在安卓版Apple Music上,可以直接在app中调节。   在长达1
[手机便携]
音视频直播系统的解决方案以及云服务器
在音视频直播系统中,云服务器降低了硬件接入的门槛,在搭建云服务器过程中有很多问题提前了解可以避免踩雷,音视频服务提供商及开发团队都很重视云服务器的搭建过程及解决的问题。 音视频直播系统中,云服务器解决了延迟大,做不到连麦互动的问题;云服务器可以兼容更多的安卓手机,开发中不可能兼容全部的安卓机型,但有了云服务器的帮助,兼容的覆盖范围得到有效增加;云服务器对音频处理效果更好,嘈杂环境下传进来的声音也能有效进行降噪处理,解决回声等问题。 音视频直播的服务场景不仅仅在于直播行业,在智能家居、远程医疗、户外活动等场景下都有不错的发挥,在需求增多,还有很多潜在场景下,音视频直播系统的开发及功能越来越完善。 音视频直播系统有以下几个
[嵌入式]
Android M 将让手机进入“全时监听”时代
    Google 推出的下一代 Android 操作系统「Android M」将能够为智能手机上的一系列传感设备开启随时感知功能,使得 Wi-Fi、麦克风、感光、摄像头等「元数据」的输入端成为协处理器 Sensor Hub 的数据来源,帮助手机判断用户处于何种状态和环境下,从而调整系统和应用软件的功能进行适应。   这意味着任何具有协处理器的智能手机或平板电脑设备,在安装了 Android M 之后,将可以保持对周遭环境的监听甚至「监视」。根据消息源透露的情况,Google 将支持意法半导体(STMicroelectronics)作为协处理器的供应商,这家公司总部位于瑞士日内瓦的芯片厂商已经开始向全球各大主要智能手机「安利」自己
[安防电子]
开放向左 Android向右
     开放,奈掣肘何   据外媒消息,Android3.0操作系统源代码将推迟开放,这一消息并未得到谷歌官方渠道证实。但系统提供商的走向封闭,在苹果获得巨大利润和市场之后,似乎吸引了越来越多IT精英们的关注。   谷歌向来以开放者自居,这种姿态一直保持到Android2.3的使用。而最新Android3.0的表现,却让所有倚仗这一开放系统的开发者着实心痛了一把。   以前无论大小终端厂商要从谷歌公司获得源代码,无需付费只要申请就可以拿到。但现在,国内品牌或是小品牌平板电脑厂商,要想获得源代码,就不那么容易了。谷歌不再把底层开发包、接口开放给普通开发者,导致企业开发者和个人开发者受到影响,例如拿不到高级权限。但是谷歌会有条
[手机便携]
Microsoft Launcher最新版将给所有安卓手机带来云母材质外观
在对Android版Microsoft Launcher的重大改进进行了一段时间的等待后,一个新的更新现在正通过Google Play商店推出。如果你不是测试计划的一部分,你现在可以尝试Microsoft Launcher重新设计的新闻源和类似于Windows 11云母的新透明度效果。   你可能知道,Microsoft Launcher一直是该公司在Android上的应用套件的核心部分。Microsoft Launcher看起来与三星和Google手机上使用的Android启动器有很大不同,它与新的Windows操作系统的外观和体验相匹配。   与其他Android启动器一样,Microsoft Launcher也是可定
[手机便携]
Android 13将原生支持调整手机手电筒亮度
谷歌上个月推出了 Android 13 的第一个开发者预览版,带来了隐私功能、主题图标、语言控制等改进。此外,Android 13 还将支持一项与手电筒相关的功能,该功能已在 iPhone 上使用了一段时间。   根据 Esper 的 Mishaal Rahman 的说法,Android 13 为 CameraManager 类引入了两个新的 API:   getTorchStrengthLevel:返回手电筒的当前亮度级别   turnOnTorchWithStrengthLevel:调整亮度级别,从最小值 1 到硬件确定的最大值   也就是说,Android 13 将可以让用户调整手机手电筒的亮度,并且开放了 API
[手机便携]
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved