- 浏览: 702940 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
shappy1978:
自己踩死自己了,我还是有远见的嘛
该死的微软,该死的IE -
calosteward:
I know Zxing and shopsavvy, bot ...
[trans]COMPARISON OF MOBILE BARCODE SCANNERS -
qq690388648:
唉……四年前的Bug,现在还没改,Apache也有不足的地方啊 ...
POI解析Word表格备忘 -
shappy1978:
Now I get to say that every met ...
Jailbreak Detection on iOS -
hebeixiaolei:
你好,我想问一下,用poi如何往word文档里插入超链接呀!
POI读取Word文档总结
google上确实没有找到其他开源的分段代码,但是这个代码本身并不复杂,可以自己参考着修改。
apple只提供了mac版本的mediafilesegmenter,但是这个工具封装的更好,它可以接受h.264/mpeg4等格式的源,不象segmenter只能接受mpegts格式的文件,还需要ffmpeg转换一下。
作者说错了,segmenter不是长度错误,而是根本没有把实际片段长度写入播放列表,而是全部写死为输入的片段长度,实际测试发现,由于是一个package顺序写入,往往一个片段会又较大的时间误差,可以到5秒以上,这样累计下来实际上到了后面就只有音频没有视频了。重新校订片段长度可以解决。感觉这个代码写得很粗糙,甚至列表文件重复写入。
分段的另一个缺点是不好seek,drag的时候往往会跳到某个片段,而且很不准,这也是没办法的事情了。
昨天在linux服务器上编译搞了一天,没办法,第一次接触linux服务器,经验:
1 用干净的源代码编译
2 用类似yum之类的命令安装的ffmpeg是无法使用的,x264也一样
3 编译segmenter还是无需指定类库路径
//***************************
在写一个基于iphone的应用,主要是用来播放视频的.但是提交给苹果审核的时候却遭到百般刁难.尤其是关于在3G网络上播放视频流的限制:
9.4 Video streaming content over a cellular network longer than 10 minutes must use HTTP Live and include a baseline 64 kbps audio-only HTTP Live stream
也罢,想想也是,在移动互联网直接播放一个几十M上百M的文件也确实是太浪费有限的流量了.难道说在互联网上直接下载整个文件,而不管会不会看完就不浪费流量了吗?觉得确实有必要研究一下这项技术了.
apple http live streaming.基于http的视频流播放,笔者称它为视频切片技术,先是将视频文件通过mpegts编码,然后通过apple提供的小工具segmenter将视频文件切割成很多小文件并维护一个时间列表.这些文件可以直接放在网站目录下面通过http协议被下载播放.不幸的是苹果提供的segmenter只能工作在mac下,我们需要一个基于linux的开源解决方案.
几经搜索和尝试最后找到Carson McDonald的<<iPhone HTTP Streaming with FFMpeg and an Open Source Segmenter>>虽然文中给出了几乎"完美"的解决方案,但是由于时代的发展和实际环境的不同,笔者着实将这篇文章细细研究了N久,于是也便有了这篇文章的出现.接下笔者会给出在ubuntu 10.04服务器编译安装ffmpeg和segmenter技术细节,并汇报一些心得.ok,go on.
1.编译安装ffmpeg
删除不用的已安装文件,升级apt-get缓存,安装必要的开发工具及库文件
apt-get remove ffmpeg x264 libx264-dev libmp3lame-dev
apt-get update
apt-get install build-essential subversion git-core checkinstall yasm texi2html \
libopencore-amrnb-dev libopencore-amrwb-dev libsdl1.2-dev libtheora-dev libvorbis-dev \
libx11-dev libxfixes-dev libxvidcore-dev zlib1g-dev nasm yasm libbz2-dev
需要用到的库及下载地址
1).faad2的安装最简单,直接解压然后
./configure &&make&&make install就ok了.
2).faac需要修改一个文件
vi +123 ./common/mp4v2/mpeg4ip.h
从123行开始修改此文件mpeg4ip.h,到129行结束。
修改前:
#ifdef __cplusplus
extern "C" {
#endif
char *strcasestr(const char *haystack, const char *needle);
#ifdef __cplusplus
}
#endif
修改后:
#ifdef __cplusplus
extern "C++" {
#endif
const char *strcasestr(const char *haystack, const char *needle);
#ifdef __cplusplus
}
#endif
然后默认安装:
./configure &&make&&make install
3).lame这样编译:
./configure --enable-nasm --disable-shared&&make&&make install
4).x264则是取的最新的代码,然后默认安装
git clone git://git.videolan.org/x264.git
./configure &&make &&make install&&cd ..
5).ffmpeg的编译参数
./configure --enable-gpl --enable-nonfree --enable-pthreads \
--enable-libfaac --enable-libfaad --enable-libmp3lame --enable-libx264
为什么要选择ffmpeg-0.6.1呢?因为较早的版本编译完以后不能正常使用而从svn取的最新的代码则会好端端的出现Unknown option "--enable-libfaad"错误.
2.安装segmenter
如果您有一定的linux使用经验,ffmpeg编译自然不在话下,也比较简单的,最难的就是这部分的segmenter的编译安装了.
先取出源代码:
svn checkout http://svn.assembla.com/svn/legend/segmenter/ segmenter
修改一个小地方:
vi +242 segmenter.c
把guess_format修改成av_guess_format
不然segmenter会在编译的时候提示:
segmenter.c:242: warning: ‘guess_format’ is deprecated (declared at /usr/local/include/libavformat/avformat.h:764)
接下来选择一种编译方式:
gcc -Wall -g segmenter.c -o segmenter -L/usr/include/ffmpeg/libavformat -lavformat -L/usr/include/ffmpeg/libavcodec -lavcodec -L/usr/include/ffmpeg/libavutil -lavutil -I/usr/include/ffmpeg/ -lbz2 -lm -lmp3lame -lxvidcore -lx264 -lfaad -lfaac -lpthread -lz
或者
gcc -Wall -g segmenter.c -o segmenter -L/usr/local/src/ffmpeg/ffmpeg-0.6.1/libavformat -lavformat -L/usr/local/src/ffmpeg/ffmpeg-0.6.1/libavcodec -lavcodec -L/usr/local/src/ffmpeg/ffmpeg-0.6.1/libavutil -lavutil -I/usr/local/src/ffmpeg/ffmpeg-0.6.1/ -lbz2 -lm -lmp3lame -lxvidcore -lx264 -lfaad -lfaac -lpthread -lz
其实无论哪种编译方式都是手动指定了库文件的位置,不然的话编译不过,这个地方最坑人,费了很多很多时间!
3.编码视频文件并切割
这之前的地方如果你遵循笔者的安装文档和提示应该很容易就通过了(虽然笔者花费了大量的时间摸索).但是正确编译以后,你并不知道正确切割文件以后的效果是什么样的,所以笔者在这里花费了超级大量的时间,这也是笔者为什么坚持要写出这篇文章的原因.
先列出笔者犯的几个致命错误吧:
1).不按apple文档格式转码
因为笔者使用的输入文件在编码的时候是针对apple的设备优化过的,可以直接在apple设备上播放并获得良好的观看效果.而在使用原作者的编码参数:
ffmpeg -i <in file> -f mpegts -acodec libmp3lame -ar 48000 -ab 64k -s 320×240 -vcodec libx264 -b 96k -flags +loop -cmp +chroma -partitions +parti4x4+partp8x8+partb8x8 -subq 5 -trellis 1 -refs 1 -coder 0 -me_range 16 -keyint_min 25 -sc_threshold 40 -i_qfactor 0.71 -bt 200k -maxrate 96k -bufsize 96k -rc_eq 'blurCplx^(1-qComp)' -qcomp 0.6 -qmin 10 -qmax 51 -qdiff 4 -level 30 -aspect 320:240 -g 30 -async 2 <output file>
时报错,在这种情况下,考虑到前一个原因,笔者自己摸索了一个编码代码:
ffmpeg -y -i <in file> -vcodec copy -acodec copy -vbsf h264_mp4toannexb <output file>
是可以正常编码和分割视频文件的.但是将应用提交给苹果审核后,苹果依旧给出了9.2的提示并拒绝了应用.这才想起来源视频在进行编码的过程中音频并没有使用64k的编码也没有单独增加一路音频流.
2).浪费时间解决可以忽略的错误提示
无论直接正常编译成功还是编译失败从别的机器上拷贝segmenter过来,在分割视频的时候都出现了:
[mpegts @ 0x2942160]max_analyze_duration reached
Output #0, mpegts, to 'a/index':
Stream #0.0: Video: libx264, yuv420p, 536x402, q=2-31, 90k tbn, 25 tbc
Stream #0.1: Audio: libmp3lame, 48000 Hz, 2 channels, 64 kb/s
[mpegts @ 0x2a08430]muxrate 1 bps, pcr every 5 pkts, sdt every 200, pat/pmt every 40 pkts
[NULL @ 0x2956900]missing picture in access unit
"max_analyze_duration reached"和"missing picture in access unit"的提示.最初这两个提示困扰了笔者很久,不断的在网上搜索寻找解决办法;不断的重新编译ffmpeg和segmenter;不断的更换视频输入源,重新编码;直到最后发现即便有这两个提示存在并不影响视频的正常播放的时候,笔者决定接受现实:这两个提示可以存在.
3).解决视频长度问题
即使上面走过了那么多的艰难,但是你还是会发现这个世界是不完美的.毕竟segmenter是苹果开发了以后用在mac上的.不知道是移值到linux还是什么原因,这个工具的表现有点让人理解不了.它的参数是这样的:
segmenter <input MPEG-TS file> <segment duration in seconds> <output MPEG-TS file prefix> <output m3u8 index file> <http prefix>
第二个参数,你指定视频分割间隔的时候,比如说指定了15秒.如果你的视频时长是32秒的话,你的视频文件会被分割成3段(每15秒一段,最后的2秒一段),而最后一段的播放时长,它竟然会写成15秒!明明就2秒干嘛要写成15秒!!!用quicktime还好说,它似乎会自动检查视频的时长纠正时间和进度条,而在iphone上,显示时长是取的视频文件里的时长(15x3=45s),而下载进度条显示的是实际文件的视频时长(32s),这样的话,你会发现,当一个视频被播放完的时候,时间还差13秒!怎么办呢?没办法了,我是看不懂c程序,但是哥会php啊,不就是时间不对嘛,哥给你重新计算一下时间重写一下文件,搞定!
4).测试时的网速问题
为了"大规模"的随机测试视频,笔者是在服务器上直接编码测试的.无论在quicktime还是iphone上,正常的表现应该是视频会被提前下载两到三个小段.结果笔者测试的时候,发现视频总是播一条下一段,笔者郁闷了很久发现:原来是公司网速太慢了.直接在iphone上用3G测试,很给力!
5).转码耗用cpu问题
视频转码是最费cpu的东东,如果想提高转码速度还是买两颗8核的cpu一块干活吧,速度哇哇的,你懂的.
ok,废话半天说一下笔者用的转码指令.
ffmpeg -y -i a.mp4 -f mpegts -acodec libmp3lame -ar 48000 -ab 64k -vcodec libx264 -b 250k \
-flags +loop -cmp +chroma -partitions +parti4x4+partp8x8+partb8x8 -subq 5 -trellis 1 -refs 1 \
-coder 0 -me_range 16 -keyint_min 25 -sc_threshold 40 -i_qfactor 0.71 \
-bt 250k -maxrate 250k -bufsize 250k -rc_eq 'blurCplx^(1-qComp)' \
-qcomp 0.6 -qmin 10 -qmax 51 -qdiff 4 -level 30 -aspect 320:240 -g 30 -async 2 a.ts
segmenter a.ts 15 a a/index.m3u8 http://vod.rainbird.cc/
rm -rf a.ts
这个时候测试时访问的url为:http://vod.rainbird.cc/a/index.m3u8(随便写的,请勿对号入座)
4.nginx配置
vi mime.types
添加以下两条儿,重启nginx
application/x-mpegURL m3u8;
video/MP2T ts;
一切顺利的话,这时候可以通过测试url观看视频了.
参考文档:
iPhone HTTP Streaming with FFMpeg and an Open Source Segmenter
Howto:Install and use the latest FFmpeg and x264
"Best Practices for Creating and Deploying HTTP Live Streaming Media for the iPhone and iPad" and "Media Stream Validator Tool Errors/Warnings Explained"
//***************************
童鞋门,翻译的文章害死人啊,还是琢磨一下上面的英文版吧,特别是后面提到的
- The supported bitrates for streaming are: 100 Kbps to 1.6 Mbps
- The suggested bitrates for streaming are*:
- Low – 96 Kbps video, 64 Kbps audio
- Medium – 256 Kbps video, 64 Kbps audio
- High – 800 Kbps video, 64 Kbps audio
------
Step 7: Create a variable rate HTTP stream
Once you have creating a single stream down you need to try out creating a variable bitrate stream. There isn't much to it, just create different bitrate encoded streams and link to their stream definition files in a separate stream definition file. Here is an example:
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=96000
http://192.168.132.15/ipv/stream-96k.m3u8
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=256000
http://192.168.132.15/ipv/stream-256k.m3u8
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=800000
http://192.168.132.15/ipv/stream-800k.m3u8
如果编写完毕,可以用下面的命令行测试
mediastreamvalidator validate http://xxx/playlist.m3u8
发表评论
-
Xib Enhanced by XCode8
2016-12-05 17:02 726I have a solution: Open stor ... -
Script to Build Universal Lib
2016-11-30 11:06 717https://www.raywenderlich.com/ ... -
Fortify Scan
2016-11-21 18:53 1300sourceanalyzer -b buidl_id -Xm ... -
Inside Code Signing
2016-11-17 14:44 608Mac OS Version 10.0 Cheeta 1 ... -
Cross Compile Script of Tesseract
2016-11-14 18:51 903The script on internet is both ... -
Homebrew saying Xcode is outdated
2016-10-28 18:44 558http://stackoverflow.com/ques ... -
iOS开发--适配iOS 10以及Xcode 8
2016-10-17 15:35 595http://www.cocoachina.com/ios/ ... -
install app to simulator
2016-09-26 16:44 1017前言 刚刚接触iOS的时候,我就一直很好奇,模拟器上面能不 ... -
issues in XCode 8
2016-09-26 16:37 645http://www.cocoachina.com/bbs/ ... -
XCode Plugin
2016-07-15 18:43 712* cmd+shift+9 //manage plugi ... -
Speedup Coding in XCode
2016-07-15 17:52 523www.cocoachina.com/ios/201607 ... -
Wifi API in iOS
2016-07-15 10:31 461查漏补缺集是自己曾经做过相关的功能,但是重做相关功能或者 ... -
About Hockey App
2016-07-04 11:38 498* free acc can only has 2 app, ... -
Appium Device Test
2016-06-29 17:18 399* set udid, device name won't ... -
[Trans] Integration between OC and JS
2016-06-28 18:47 495iOS 开发中,我们时不时的需要加载一些 Web ... -
Jenkins iOS Automation Comment
2016-06-24 16:47 594* SDK null will by default bui ... -
Salabash Test Comment
2016-06-08 19:29 433* Device test need to enable U ... -
Calabash
2016-06-02 18:24 709//calabash-cucumber for ios ... -
BDD Setup
2016-05-20 15:04 538—brew /usr/bin/ruby -e " ... -
Setup Git
2016-04-01 19:23 567http://www.tomdalling.com/blo ...
相关推荐
苹果CMS是一款广泛应用于在线视频平台的开源内容管理系统,专为构建点播系统设计。这款源码不包含采集插件,意味着用户需要自行处理内容的上传、管理和更新,从而确保了内容的原创性和版权的合规性。 苹果CMS的核心...
本文将深入解析该系统的核心组件和关键技术,帮助你了解如何利用这些源码构建一个功能完善的视频点播应用。 1. **项目构建工具与依赖管理** - `gradlew.bat` 和 `gradlew` 是Gradle构建工具的Windows和Unix版本,...
视频点播系统的核心是流媒体技术,这种技术可以在有限的网络带宽上实现实时的多媒体信息传输。流媒体技术有三大应用场景:点播型、直播型和会议型应用。 点播型应用是最常见的形式,用户可以从服务器上选择并观看...
青苹果影视系统源码 v1.4.15,使用青苹果影视系统(MacCms)可以快速搭建一个免更新、免维护的影视聚合、影视导航、影视点播网站。 功能列表 1、数据模块 – 一键对接市面上的影视资源站API接口、现已支持FeiFeiCms...
Linux下视频点播系统的实现 Linux 操作系统作为全球最流行的开源操作系统之一,已经广泛应用于各个领域,而视频点播系统作为一种常见的多媒体应用,也逐渐成为了Linux平台上的一个重要组件。 本文将详细介绍如何...
苹果CMS是一款开源的内容管理系统,主要用于视频、音频类网站的建设和管理。其核心优势在于强大的媒体资源管理、灵活的模板系统和易于扩展的插件机制。在这个模板中,苹果CMS被用作后台支撑,负责内容的发布、分类、...
3、点播模块 – 视频模块的基础在线点播功能,使用大名鼎鼎的Dplayer作为H5播放器、常见的包括mp4、m3u8、flv、mp3等格式都支持。 4、微信公众号 – 可对接微信公众号开发者工具(影视机器人系统),对接后微信用户...
在互联网技术高速发展的今天,视频点播系统已经成为人们日常娱乐、学习的重要平台。本文将深入解析一个基于Java Web技术栈,结合Spring、SpringMVC和MyBatis(简称SSM)框架构建的在线视频点播系统。该系统不仅满足...
【基于jsp流媒体的vod视频点播网源码数据库论文】文档主要涵盖了使用Java JSP技术构建一个基于流媒体的视频点播(VOD)网络系统的设计与实现。VOD系统允许用户在网络上按需观看视频内容,它涉及到多个关键的技术领域,...
3、点播模块 - 视频模块的基础在线点播功能,使用大名鼎鼎的Dplayer作为H5播放器、常见的包括mp4、m3u8、flv、mp3等格式都支持。 4、微信公众号 - 可对接微信公众号开发者工具(影视机器人系统),对接后微信用户...
综上所述,Android直播和点播视频源码涉及了多媒体处理、网络通信、用户交互等多个方面的技术。对于开发者来说,理解并掌握这些知识点对于开发高质量的视频应用至关重要。而"VST-1.1.9-0928"这个源码项目则为学习和...
本项目致力于开发一个全面、高效的视频点播(VOD)网站,旨在利用流媒体技术提供高质量的在线视频服务。项目的开发背景、目的及意义在摘要中有所体现。随着互联网技术的快速发展以及计算机网络应用的普及,越来越多...
HLS(HTTP Live Streaming)是由苹果公司开发的一种基于HTTP的流媒体互联网传输协议,主要用于适应不同的网络条件,确保视频播放的流畅性。HLS协议将视频分割成多个小段(m3u8索引文件),用户可以根据自己的网络...
苹果cms论坛一个基于 vue 和 gin 实现的在线观影网站 项目采用vite + vue作为前端技术栈, 使用 ElementPlus 作为UI 框架进行开发 后端程序使用 Gin + gorm + go-redis 等相关框架提供接口服务, 使用 gocolly 和 ...
基于Linux的视频点播系统的实现 本文介绍使用Darwin流服务器实现Linux下的视频点播系统的方法和步骤。Darwin流服务器是苹果公司QuickTime流服务器的opensource版本,是完全基于QuickTime流服务器代码开发的,其实现...
5. `vodplayer.php`:vod(Video on Demand)视频点播相关的文件,可能与自定义的视频播放体验有关。 6. `far10.php`:可能是一个特定版本或者功能增强的采集脚本,比如FAR的10版本或某种特定任务。 7. `ajax_player...
源码的核心功能是提供视频点播服务,可以与苹果CMS v10内容管理系统对接,用于管理视频内容和用户界面。 描述中提到的“里面有搭建教程,还有app修改对接网址的方法”,意味着在压缩包内包含了一份详细的搭建指南,...
本源码提供给大家学习研究借鉴美工之用,请勿用于商业和非法用途,无任何技术支持! 此版带会员功能,对接的是 如意验证1.71版+苹果cms后端APP 电视TV4.5版,会员功能带注册邀请,绑定邮箱,邮箱找回密码,修改新密码,...
在线直播和视频点播是现代互联网技术的重要组成部分,它们为用户提供了实时互动和灵活观看的体验。本篇文章将深入探讨这些技术背后的关键知识点。 首先,我们来看“在线直播”。在线直播是一种通过互联网实时传输...