基于red5的flex视频研究(1)

用了两星期多,在空闲时间研究了下基于red5的实时视频直播,今天终于有了第一个版本,虽然比较简单,但是费了我好多心血,从零开始到现在,学到了好多以前根本就不知道的知识,根本没用过的东西。。。。在这里和大家分享,共同进步!
先把效果给大家看看吧,然后再细说这个过程,以后还会有后续的研究日记。。。。也希望我能坚持下去。。。。
实现了实时视频,群聊,在线列表……
[img]http://dl.iteye.com/upload/picture/pic/84361/3623820a-3973-3182-bb70-f68fdf4a6729.png[/img]
环境搭建:red hat 6 linux+red5(0.9)
flex 3 + myeclipse8.5
这儿要说一下,搭环境还是挺重要的,我刚开始是跑在window上的,window上的环境搭建还是挺容易的,网上资料也很多,为了方便我没装ant(也不知道window环境下为啥不用装),等到了后来将red5移到linux上时,环境搭建就不像window上那样简单了,ant是必要的,作为编译red5(解压目录下有个build.xml,window解压目录下没有),另外设要置好jdk环境变量,启动red5之前要ant下,参照 [url]http://wangguorui89.iteye.com/blog/698230[/url],可是这时会抛出异常,找不到各种配置文件,当时就很郁闷,版本不一样?再网上找了好久也没解决,最后还是到官网上找找,还是官网上的配置说明给力,[url]http://trac.red5.org/wiki/Install[/url],原来缺的东西还需要在它的版本库中checkout 下来,顺便就又学了些svn的东西,帽是它上面就说了0.9版本的需要这么做。。。。。还有一点在linux下安装时没有提示输入ip和端口,默认的就是0.0.0.0(表示都可以访问),5080(red5端口号),这些都在conf/red5.proerties中配置。

red5的中文资料的确很少,但是官网上的技术文档还是还是容易读懂的,我也找了个pdf版本的,另外red5api也是必须的。

red5 应用程序:项目文件必须放在webapps下面,在项目一级目录中必须有WEB-INF和META-INF,大家可以直接把解压后的例子中的拷贝过来,然后在WEB-INF中会有三个重要的文件:

red5-web.properties:里面webapp.contextPath=/项目文件夹名称

red5-web.xml:只需要改动bean id = “web.hander” class="java项目class文件目录"(响应客户端请求)

web.xml:里面<display-name>和<param-value>一定要与项目名称一样

新建java工程,我是直接将路径放在webapps下的,然后将WEB-INF和META-INF导入,注意要将java项目的output folder路径设为WEB-INF下的classes文件夹下,不然会抛出ClassNotFound异常。

java程序比较简单,一个用户列表共享对象,一个用户消息共享对象,当用户连接到服务器(appConnect())时,将用户名和连接信息形成对应存入在线列表,当用户断开时(appDisConnect()),再删除此对应关系,另外还有一个广播消息方法,用于客户端调用。

客户端(flex):
视频发布端,视频接收端,用户列表刷新,聊天内容更新,连接服务器(初始化时)……
视频发布端调用Camera,Microphone,这里要注意他们的相应配置,以达到视频的最佳效果,例如我设置的是:

cam.setMode(320,240,10); //设置摄像头的捕获模式 分辨率: 320*240 每秒10帧
cam.setQuality(100*100,80);
mic.setUseEchoSuppression(true); //抑制回音(很重要)

在刷新用户列表和聊天记录时,设置监听器:

//为共享对象添加异步事件,这也是服务器同步处理多客户端最关键的地方,
//一个客户端进行了什么操作,其它客户端也会有相应的变化,就是通过此事件来完成的
listSO.addEventListener(SyncEvent.SYNC, listSOSyncHandler);
//每当由用户进入时,listSOSyncHander方法执行,刷新用户列表
//用户列表共享对象被更新之后事件
private function listSOSyncHandler(evt:SyncEvent) {
showUserList(); //更新用户列表
}
private function showUserList() {
userArr = new ArrayCollection();
//用户数组更新
for (var j in listSO.data) {
userArr.addItem({username:listSO.data[j]});
}
userList.dataProvider = userArr; //添加DataProvider
}

还有在视频流接受端可以设置缓冲,以保证视频的流畅。

remoteStream.bufferTime=2; //缓冲2秒再播放,保证视频流畅

大家可以看看actionScript API中的Camera,Microphone相关方法说明。
测试的时候,尽量不要在本机上,这样效果不是很明显,可以把.swf文件嵌入到jsp中,部署到应用服务器上,用多台主机登陆,看看视频效果……
另外大家可以参看fms下的视频直播实现相关资料,毕竟fms资料还是相当多的,我就是遇到了瓶颈突然想到了fms下的开发,(因为它俩某些方面实现机制还是大同小异的,)才解决问题的。[url]http://mhqawjh.iteye.com/[/url]它的具体代码在豆瓣上有一个系列讲解[url]http://www.docin.com/mydoc-23978659-1.html[/url] 相信对大家肯定有所帮助的。
接下来做的事情:处理些细节,比如视频请求应答交互,实现简单共享白板。
第一次发表文章,可能有很多没写好的地方,望大家多多指教!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值