基于现代浏览器,使用MJPEG over HTTP实现简单视讯网络广播
作者:V君 发布于:2015-9-21 9:39 Monday 分类:挖坑经验
TL;DR:
实现一个数据源来提供一系列帧图像数据(本例jpeg), 随便找个请求处理程序贴上以下代码,
用现代浏览器(Chrome/FF)访问即可
const string boundary = "frame";
Response.Buffer = false;
Response.BufferOutput = false;
Response.ContentType = "multipart/x-mixed-replace; boundary=" + boundary;
while (true)
{
byte[] buf;
while (null == (buf = VideoQueue.Pull()))
{
Thread.Sleep(100);
}
var output = Response.OutputStream;
output.WriteAscii("--" + boundary);
output.WriteAscii("\r\n");
output.WriteAscii("Content-Type: image/jpeg");
output.WriteAscii("\r\n");
output.WriteAscii("Content-Length: " + buf.Length);
output.WriteAscii("\r\n");
output.WriteAscii("\r\n");
output.Write(buf, 0, buf.Length);
output.WriteAscii("\r\n");
}
扯一扯:
要在浏览器实时查看摄像头画面,
然而摄像头在NAT背后, 只能搭一个平台来转发数据.
用AForge的DirectShow封装取得每一帧画面, 推到平台上.
那么剩下的就是如何在浏览器呈现了.
定时轮询? 感觉图样, 有没有以视频方式呈现? H5的Video标签好像可以用的样子.
然而并没有找到从一堆图像生成视频流的方式,AForge只能写文件,
用了各种关键字最后找到 MJPEG 方式,
参照 CodeProject 上面的一个例子写了这个长连接的请求处理程序.
只能在浏览器地址栏直接打或者给img标签的src, video标签并不支持.
你可以从多个浏览器访问视频画面, 就像广播一样 乂目
写了个屏幕录像并以 MJPEG 广播的 Demo, 泥可以从这里获取
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)