赞
踩
采用谷歌内核CefSharp进行开发,主要是为了实现JS交互,实现前端JS调用原生能力,如:相机、VLC视频能力(主要播放流视频)等。
实现主要功能:
浏览器标签、HTML页面能播放视频、下载记录、JS交互(能调用原生相机、调用VLC集成能力:流视频播放)、软件更新、自定义右键菜单、F11全屏模式、F12调试模式、F5刷新、ALT+F5强制刷新、系统配置等功能、网络请求(HttpClient,支持网络接口情况,json数据解析)、图像处理工具(ImageUtils)、加密解密函数(Cipher)。
浏览器优化:
使用软件渲染和合成(禁用 GPU)来提高 FPS 并降低 CPU 使用率、同步所有进程之间的帧率避免生成额外的帧来降低 CPU 使用率、增加手机预览模式(需要自己在代码里面开启)
源码支持二次开发,所有的代码都有注释,二次开发更便捷,集成视频VLC dll库、相机AForge dill库、Svg dill库(主要用来解决部分网站使用SVG做icon的解析,如:百度、CSDN等)。
源码编程采用简单有效的编码方式,结构化清晰。
案例图片
浏览器优化过,即使开了很多窗口,CPU的占用依旧很低,内存占用在120M之间
图片预览
JS调用原生相机进行拍照,返回Base64位图片
JS调用强大的VLC视频解码dll,可以播放本地视频,网络视频,流视频,播放任何格式的视频,解决HTML播放视频问题
自定义右键菜单
JS调用弹窗框视频播放(多屏播放)
系统配置,添加默认的Logo和系统访问地址
JS调用单屏弹出框播放视频
浏览器集成了视频播放源码,支持HTML视频播放,视频流畅不卡顿
HTML、JS调用源码
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>测试</title> <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0,viewport-fit=cover"> <meta charset="UTF-8"> <meta http-equiv="Cache-Control" content="max-age=7200" /> <meta http-equiv="Expires" content="Mon, 20 Jul 2099 23:00:00 GMT" /> <meta name=renderer content=webkit> <meta http-equiv="X-UA-Compatible" content="IE=edge"> </head> <body style="background: #eee"> <div> <button onclick="test1()">播放视频</button> </div> <div> <button onclick="test2()">多屏播放</button> </div> <div> <button onclick="test3()">相机</button> </div> <div> <button onclick="test4()">嵌入播放</button> </div> <div> <button onclick="test5()">嵌入多屏播放</button> </div> <div> <button onclick="test6()">关闭视频窗口</button> </div> <div> <img id="imgurl" width="320" height="320" /> </div> </body> <script type="text/javascript"> //首先必须添加JS注册,要不然无法调用C#的接口(可以进行全局加载,到时候任何地方都直接使用方法) CefSharp.BindObjectAsync("JsEvent"); //弹出视频播放弹窗(单屏) function test1(){ JsEvent.jsToVideo("rtsp://liveplay.guiyang.vcn.ctyun.cn/vaas/live/5200000100002_52010334031322000033_live_1?auth_key=1660815415-41df1645ee134df381da506eed26fe85-30003-9c875bc7519e3a5c6a02613ac578ce7b", 2); } //弹出视频播放弹窗(多屏播放)需要播放多个视频,就执行多次,系统自动计算播放的位置 function test2() { JsEvent.jsToVideoMore("http://devimages.apple.com.edgekey.net/streaming/examples/bipbop_4x3/gear2/prog_index.m3u8"); JsEvent.jsToVideoMore("http://devimages.apple.com.edgekey.net/streaming/examples/bipbop_4x3/gear2/prog_index.m3u8"); } //调用相机 function test3() { JsEvent.jsToCamera(); } //嵌入单屏屏播放 /// <summary> /// 播放视频 /// </summary> /// <param name="videoURL"></param> /// <param name="type"></param> 1、播放本地文件 2、播放视频流文件 /// <param name="x"></param> x坐标 /// <param name="y"></param> y坐标 /// <param name="width"></param> 宽度 /// <param name="height"></param> 高度 function test4() { var width = JsEvent.getScreenWidth(); var height = JsEvent.getScreenHeight(); JsEvent.jsToVideoIn("http://devimages.apple.com.edgekey.net/streaming/examples/bipbop_4x3/gear2/prog_index.m3u8", 2, 240, 48, 1200, 800); } //嵌入多屏播放 /// <summary> /// 视频嵌入 /// </summary> /// <param name="url"></param> 播放地址 /// <param name="x"></param> x 坐标 /// <param name="y"></param> y 坐标 /// <param name="width"></param> 宽度 /// <param name="height"></param> 高度 function test5() { var width = JsEvent.getScreenWidth(); var height = JsEvent.getScreenHeight(); JsEvent.jsToVideoMoreIn("http://devimages.apple.com.edgekey.net/streaming/examples/bipbop_4x3/gear2/prog_index.m3u8", 240, 48, 1200, 800); } //关闭视频播放界面 function test6() { JsEvent.jsToCloseVideo(); } //相机回调 返回base64位图片 function toJSCamera(url) { document.getElementById("imgurl").src = url; } </script> </html>
C#源码
/// <summary> /// 初始化浏览器 /// </summary> /// <param name="cf"></param> public void InitChromiumWeb(String url, TabPage wPage) { form.tab = wPage; browser = new ChromiumWebBrowser(url); //开启js交互 js注册函数:JsEvent CefSharpSettings.WcfEnabled = true; browser.JavascriptObjectRepository.Settings.LegacyBindingEnabled = true; browser.JavascriptObjectRepository.Register("JsEvent", new JsEvent(), isAsync: true, options: BindingOptions.DefaultBinder); //浏览器满屏展示 browser.Dock = DockStyle.Fill; this.Controls.Add(browser); //设置标题 browser.TitleChanged += new EventHandler<TitleChangedEventArgs>((object sender, TitleChangedEventArgs e) => { form.BeginInvoke(new Action(() => { wPage.Text = e.Title; })); }); //事件绑定 browser.FrameLoadEnd += new EventHandler<FrameLoadEndEventArgs>(FrameEndFunc); //绑定加载完浏览器事件 browser.MenuHandler = new MenuHandlerCall(); //绑定鼠标事件 browser.DownloadHandler = new DownloadHandler(); //绑定下载事件 browser.KeyboardHandler = new CEFKeyBoardHander(); //绑定键盘操作事件 browser.LifeSpanHandler = new CEFLifeSpanHandler(); //绑定打开新窗口事件 } /// <summary> /// JS相互事件 注意:首字母小写,否则js那边调用大写的会报错 /// </summary> public class JsEvent { /// <summary> /// 播放视频 /// </summary> /// <param name="videoURL"></param> /// <param name="type"></param> public void jsToVideo(String videoURL, int type) { form.BeginInvoke(new Action(() => { if (form.video == null) { form.video = new VLCVideo(); form.video.Show(); form.video.PlayVideo(videoURL, type); } else { form.video.PlayVideo(videoURL, type); } })); } /// <summary> /// 播放视频 /// </summary> /// <param name="videoURL"></param> /// <param name="type"></param> 1、播放本地文件 2、播放视频流文件 /// <param name="x"></param> x坐标 /// <param name="y"></param> y坐标 /// <param name="width"></param> 宽度 /// <param name="height"></param> 高度 public void jsToVideoIn(String videoURL, int type, int x, int y, int width, int height) { form.BeginInvoke(new Action(() => { //视频播放位置 form.videopanel.Visible = true; form.videopanel.Location = new Point(x, y); form.videopanel.Width = width; form.videopanel.Height = height; if (form.video == null) { form.video = new VLCVideo(); form.video.TopLevel = false; form.video.FormBorderStyle = FormBorderStyle.None; form.video.Dock = DockStyle.Fill; //添加视图 form.videopanel.Controls.Clear(); form.videopanel.Controls.Add(form.video); //tp.Controls.Add(form.videopanel); form.video.Show(); form.video.PlayVideo(videoURL, type); } else { form.video.PlayVideo(videoURL, type); } })); } /// <summary> /// 实时播放多个视频 /// </summary> /// <param name="url"></param> public void jsToVideoMore(String url) { form.BeginInvoke(new Action(() => { if (form.vLCVideo == null) { form.vLCVideo = new VLCVideoMore(); form.vLCVideo.Show(); form.vLCVideo.PlayVideo(url); } else { form.vLCVideo.PlayVideo(url); } })); } /// <summary> /// 视频嵌入 /// </summary> /// <param name="url"></param> 播放地址 /// <param name="x"></param> x 坐标 /// <param name="y"></param> y 坐标 /// <param name="width"></param> 宽度 /// <param name="height"></param> 高度 public void jsToVideoMoreIn(String url, int x, int y, int width, int height) { form.BeginInvoke(new Action(() => { //视频播放位置 form.videopanel.Visible = true; form.videopanel.Location = new Point(x, y); form.videopanel.Width = width; form.videopanel.Height = height; if (form.vLCVideo == null) { form.vLCVideo = new VLCVideoMore(); form.vLCVideo.TopLevel = false; form.vLCVideo.FormBorderStyle = FormBorderStyle.None; form.vLCVideo.Dock = DockStyle.Fill; //添加视图 form.videopanel.Controls.Clear(); form.videopanel.Controls.Add(form.vLCVideo); form.vLCVideo.Show(); form.vLCVideo.PlayVideo(url); } else { form.vLCVideo.PlayVideo(url); } })); } /// <summary> /// 关闭视频窗口 /// </summary> public void jsToCloseVideo() { form.BeginInvoke(new Action(() => { form.videopanel.Visible = false; if (form.vLCVideo != null) { form.vLCVideo.Close(); } if (form.video != null) { form.video.Close(); } })); } /// <summary> /// 开启摄像头 /// </summary> public void jsToCamera() { form.BeginInvoke(new Action(() => { if (form.camera == null) { form.camera = new Camera.OpenCamera(); form.camera.Show(); } })); } /// <summary> /// 获取可视化屏幕的宽度 /// </summary> /// <returns></returns> public int getScreenWidth() { return form.Width; } /// <summary> /// 获取可视化屏幕的高度 /// </summary> /// <returns></returns> public int getScreenHeight() { return form.Height; } }
源码包下载
C#源码包下载
希望能帮助到需要的你,同时也需要你的支持,非常感谢!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。