一、方案确定
计划做视频播放,要求能够播放H264编码的mp4文件,各个浏览器,各种终端都能播放。
首先查找可行性方案,
http://www.cnblogs.com/sink_cup/archive/2011/04/21/html5_video_ipad_firefox_chrome_ie9876_flash.html,这个方案将视频播放分为两部分,一是html5播放,二是flash播放。如果浏览器支持用html5的video标签播放h264的mp4文件,如ie9,chrome,safari采用html5播放,如果不支持,降级采用flowplayerp(以下简称fp)播放mp4文件。
不足是firefox,opera目前不支持h264编码,无论是html5还是fp在这两种浏览器上无法播放(经过后来实验,ff下是只有音频没有视频)。
还有一个方案是http://hi.baidu.com/alimyself/item/7f5c003f3397968bb611db07使用非常简单,只要链接一个js文件就可以了。所以,只要您的页面上(头部或底部)有这么段代码:
<scriptsrc="http://html5media.googlecode.com/svn/trunk/src/html5media.min.js"></script>
就可以了。
这个封装太严密,无法灵活控制状态条和播放器属性。
http://www.zhangxinxu.com/study/201003/html5-video-mp4.html
决定采用此方案。
首先使用方案中的代码搭建整体框架。在使用该方案过程中,有一些改动,后附代码。
其他的一些降级方案:
可行的跨浏览器HTML5音频和视频:
http://msdn.microsoft.com/zh-cn/magazine/hh781023.aspx
优雅降级:http://www.iefans.net/html5-qianru-shipin/
没怎么看明白的一篇文章,貌似也是引用外部的一个js即可:
http://camendesign.com/code/video_for_everybody
Flowplayer提供的降级方案:http://flowplayer.blacktrash.org/graceful.html
二、业务说明
基本框架加入后,就需要加入实际业务逻辑。
逻辑是所有人可以观看视频播放。
角色A满足某条件时,观看视频时不能控制播放进度,不能快进和后退,并且需要记录本次有效观看时间。播放开始时,需要从上次观看结束的时间点自动开始播放。
三、html5播放
首先是html5部分,在用video标签实现了基本播放后,需要控制角色A的播放控制条,禁用进度条。
搜索到一个用jquery和css实现的html5自定义控件:
http://www.inwebson.com/html5/custom-html5-video-controls-with-jquery/。可以灵活控制按钮是否可见,及按钮事件。
下个问题是html5播放如何计时。在上边的控件中,有文件video.js中,定义有播放器的timeupdate事件,在此方法中,调用自定义的timeupdate方法,在自定义方法中,获取当前播放视频的进度currenttime,进行计时。
下个问题是html5如何在播放开始时设置播放器从哪里开始播放。html5的video有currenttime属性。在chrome,safari下可以设置后,效果很好。但是ie9下,若设置开始播放时间较长,currenttime会没有效果,直接从0开始播放。因此做了一些特殊处理。
相关参考:
检测当前浏览器是否支持html5的video标签:
http://www.w3school.com.cn/html5/html_5_video.asp
Html5全局属性:http://www.w3school.com.cn/html5/html5_ref_globalattributes.asp
Html5全局事件属性:http://www.w3school.com.cn/html5/html5_ref_eventattributes.asp
针对html5的video标签的详解:http://www.aspxhome.com/design/css/20106/1415123_3.htm
http://wiki.whatwg.org/wiki/Video_type_parameters
各个浏览器对html5支持程度测试:www.html5test.com
各个浏览器对html5支持程度的图文说明:http://html5readiness.com/
Html5视频播放能否用wowza服务器,
http://www.wowza.com/forums/showthread.php?7532-HTML5-Support-for-video-playback
目前没有测试成功,直接使用http播放。
四、flowplayer播放
Html5播放搞定后,整个播放才完成了一小部分,继续fp播放。首先是fp的播放按钮控制,fp有提供一个控制条插件:在页面jsp中加入flowplayer.controls-3.2.8.js,flowplayer.controls-3.2.8.min.js
并且在播放器初始代码中初始化即可。可自定义控制条各个按钮是否显现及播放条样式。
工具条插件:
http://flowplayer.org/plugins/flash/controlbar.html
http://flowplayer.org/documentation/configuration/clips.html
//菜单插件
http://flowplayer.org/plugins/flash/menu.html
下边是播放如何计时。由于fp没有类似于html5的timeupdate事件,因此需要自定义js计时器,在播放器开始播放时,开始计时:
clearIntervalFun=setInterval(fpTimeUpdate,1000);
在timeupdate中用getttime方法获取fp的当前时间并计时。
Flowerplayer事件及属性
http://blog.sina.com.cn/s/blog_6cabf4070100wry7.html
http://flowplayer.org/demos/skinning/tooltips.html
http://flowplayer.org/documentation/events/
http://releases.flowplayer.org/apidoc-latest/org/flowplayer/model/Clip.html
最难的是fp如何设置视频的开始播放时间,在fp官网看到一个关于伪流的东西,http://flowplayer.org/plugins/streaming/pseudostreaming.html
上边有一句话很是让人开心:Randomseekingtoanypartofthetimelineatanytime.。可以加载到视频的任何地方进行播放。需要flowplayer.pseudostreaming-3.2.9.swf插件,看还有说要用到一个名为lighttpd的webserver。
于是尝试在linux服务器下安装lighttpd,以期能够使用flowplayer.pseudostreaming
搜索之后,发现lighttpd默认播放flv,如果要播放h264的,需要添加h264模块。
http://h264.code-shop.com/trac/wiki/Mod-H264-Streaming-Apache-Version2
安装完lighttpd,添加h264模块,
http://www.wenzizone.cn/?p=167
这个过程极其繁琐,耗费大量时间。
此时再使用fp的start参数,或者是seek方法,均不凑效。
后再仔细看流媒体概念,见:
http://202.192.163.58/internet/page/kch-nr/page_10_4.htm
才发现伪流是顺序流式下载,“这种方式和传统的下载方式没有本质的区别,只是因为客户端的软件可以在媒体没有完全下载就可以播放,它不能跳过头部,必须先下完前面的才可以看后面的;”。如果需要视频从一开始就播放还未下载到的部分,那么只能使用实时流式传播。
是我对fp的伪流控件的说明理解的有问题,还是lighttpd安装有问题,具体问题出在哪里,现在还不明白。
如果要使用实时流式传播,就要使用流媒体服务器。鉴于fp有提供一个rtmp的插件,决定用rtmp协议。
原来已经安装成功helix,并成功使用rtsp协议进行realplayer播放。准备继续沿用helix,但是在helix端口配置中未找到rtmp的端口配置,不确定helix是否支持rtmp协议,因此决定流媒体服务器用wowza。
各个流媒体对比:http://en.wikipedia.org/wiki/Comparison_of_streaming_media_systems
Wowza在各种流媒体服务器中,支持较多编码格式,较多终端。
安装wowza,
Wowza安装http://sunky045.iteye.com/blog/538288
并配置applications,具体见
http://www.wowza.com/forums/content.php?3-quick-start-guide
Wowza配置application,简单说就是在安装目录/usr/local/WowzaMediaServerPro的application下,创建一个你的applicationName名称的空文件夹。在
/usr/local/WowzaMediaServerPro的conf文件夹下,创建一个与上边applicationName保持一致的文件夹,然后把/usr/local/WowzaMediaServerPro的conf下的所有配置文件,复制到
/usr/local/WowzaMediaServerPro/conf/applicationName下,修改复制过来的配置文件中的application.xml的StorageDir路径,这个就是wowza的application指向的地址。
Wowza测试是否正在运行访问:http://ip:1935如果能访问到,说明wowza安装成功。
安装完毕,并参考fp官网的rtmp用法,
Flowplayer使用wowza示例:http://flowplayer.blacktrash.org/test/issue392.html
Wowza官网关于flowplayer使用rtmp协议播放视频的示例:
http://www.wowza.com/forums/content.php?54
直接播放,在ie876下,能播放,有声音,但是没有图像。经过搜索,给wowza打了patch包,详见
http://www.wowza.com/forums/showthread.php?14256-No-video-in-RTSP-gt-RTMP-resteam-from-ip-cam
再次播放,可以。
参考fp官网关于rtmp的用法,并设置start参数,播放成功。
详见http://flowplayer.electroteque.org/controls-markers
比较有趣的一个东西:flowplayer和jw分别使用start参数,看视频播放处理的不同方式:
http://lvis.lavasmith.com/flowplayer/3.2.9.aspx?player=flowplayer&clip=Topic8&start=40&cb=1340611398536。
没有任何流媒体及视频播放基础,一个人钻牛角尖,无同事可请教,自己硬啃英文网站及文档,苦不堪言。幸亏有热心网友帮忙,指点迷津。
如果文章能对他人有一点帮助,将十分欣慰。仍然有一些遗留问题,有热心高人指点下,不胜感激。
另: 源代码,总结文档,第三方播放下载地址:http://download.csdn.net/detail/qingwangyoucao/4544606
分享到:
相关推荐
支持h264在各个浏览器下的视频播放,如果支持浏览器支持html5,采用html5播放,若不支持,采用flowplayer播放。并且有用到流媒体服务器服务器wowza,实现视频播放不卡,流畅,且能拖拽至未加载部分。实现视频观看...
1. **HTML5视频支持**:Flowplayer基于HTML5技术,支持MP4、WebM和Ogg等主流视频格式,确保在多种浏览器和设备上都能播放。 2. **Flash fallback**:对于不支持HTML5视频的老旧浏览器,Flowplayer会自动切换到Flash...
同时,它也支持FLV格式,这是一种早期的流媒体格式,适用于那些不支持H.264的旧版浏览器。 3. **嵌入与集成**:Flowplayer可以轻松地通过JavaScript API嵌入到HTML页面中,允许开发者自定义播放器外观、控制条、...
5. **跨平台与跨浏览器兼容**:Flowplayer考虑到各种浏览器和设备的差异,确保在Chrome、Firefox、Safari、Edge以及移动设备上的iOS和Android等主流平台都能正常工作。这使得无论用户使用何种设备,都能享受一致的...
Flowplayer是一款开源的HTML5/Flash视频播放器,它支持多种视频格式,包括H.264编码的MP4、WebM和Ogg。Flowplayer的核心特性是其简洁的API和丰富的自定义选项,使得开发者可以轻松地集成到网站中,实现各种播放控制...
5. `docs`或`manual`文件夹:可能包含用户手册和开发指南,帮助开发者更好地理解和使用FlowPlayer。 6. `examples`文件夹:可能包含一些示例代码,展示如何在实际项目中应用FlowPlayer。 FlowPlayer还支持自定义...
7. **视频编码与格式**:Flowplayer通常需要H.264编码的MP4视频作为主要格式,同时也支持WebM和Ogg等其他格式,以确保跨平台兼容性。 8. **广告集成**:Flowplayer支持VAST(Video Ad Serving Template)标准,可以...
【标题】:“rtmp_flowplay_flowplayer.zip”这个压缩包文件可能包含了一个关于RTMP流媒体播放和FlowPlayer的相关实现。RTMP(Real-Time Messaging Protocol)是Adobe开发的一种实时传输协议,常用于在线视频流媒体...
由于HTML5的普及,Flowplayer也支持HTML5视频播放,但在某些老版本或不支持HTML5的浏览器中,仍会依赖Flash插件。 3. `flowplayer-3.2.7.swf`:这是另一个Flowplayer的Flash插件文件,版本为3.2.7。与上述的...
Flowplayer是一个基于JavaScript和HTML5的视频播放器,它的特点是轻量级、高度可定制,并且兼容各种浏览器。Flowplayer不仅支持HTML5的HLS、DASH等现代流媒体协议,还通过Flash fallback机制支持RTMP,确保在不支持...
Flowplayer 是一个开源(GPL 3...Flowplayer支持播放flv、swf等流媒体以及图片文件,能够非常流畅的播放视频文件,支持自定义配置和扩展。 1、加载flowplayer.js 在要播放视频的页面的head之间加入flowplayer.js。 ...
Flowplayer作为网页播放器,支持多种视频格式,如FLV、MP4和H.264,同时兼容HTML5和Flash,确保在各种浏览器和设备上都能正常播放。Flowplayer提供了丰富的自定义选项,包括皮肤、控制条、广告插入以及与其他...
1. **HTML5视频支持**:Flowplayer基于HTML5技术,能够支持现代浏览器的原生视频播放功能,包括MP4、WebM和Ogg等常见视频格式。这使得它可以在无需Flash插件的情况下工作,提高了在移动设备上的兼容性和性能。 2. *...
这个播放器支持多种视频格式,包括H.264、WebM和Ogg,能够适应不同的浏览器和设备,确保用户在不同环境下都能流畅地观看视频内容。 Flowplayer的核心特性包括: 1. **自定义皮肤**:提供的`skin`文件夹可能包含了...
1. **多格式支持**:Flowplayer不仅支持FLV格式,还支持MP4,这是一种广泛接受的H.264编码视频格式,可以在大多数现代浏览器中流畅播放。这使得Flowplayer可以覆盖更广泛的用户群体,无论他们的设备或浏览器偏好如何...
- 支持多种视频格式,如MP4、H.264、WebM以及FLV。 - 具有广告插播功能,允许在视频播放前、后或中间插入广告。 - 提供了丰富的API接口,允许开发者自定义播放器行为,如添加控制条、水印、字幕等。 - 支持...
1. **跨平台兼容性**:Flowplayer支持多种浏览器,如Chrome、Firefox、Safari、IE(至IE9)以及现代的Edge和Opera等,确保了用户在不同设备上都能流畅观看视频。 2. **HTML5与Flash的无缝切换**:在不支持HTML5视频...
flowplayer.commercial-3.2.18.swf 亲测可用,随便使用