C#完整版浏览器开发

这篇具有很好参考价值的文章主要介绍了C#完整版浏览器开发。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

C#完整版浏览器开发

采用谷歌内核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之间
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
图片预览
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
JS调用原生相机进行拍照,返回Base64位图片
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频

JS调用强大的VLC视频解码dll,可以播放本地视频,网络视频,流视频,播放任何格式的视频,解决HTML播放视频问题
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
自定义右键菜单
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
JS调用弹窗框视频播放(多屏播放)
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
系统配置,添加默认的Logo和系统访问地址
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
JS调用单屏弹出框播放视频
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
浏览器集成了视频播放源码,支持HTML视频播放,视频流畅不卡顿
c# 浏览器,WinForm,CefSharp,C#,c#,winform开发之嵌入Chrome内核浏览器,视频
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#源码包下载

希望能帮助到需要的你,同时也需要你的支持,非常感谢!文章来源地址https://www.toymoban.com/news/detail-794254.html

到了这里,关于C#完整版浏览器开发的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C# 关于浏览器——WebBrowser篇

    最近要写一个浏览器包裹一个网站,试了各种浏览器插件,记录一下。 第一个就是微软的WebBrowser,这个很容易,直接拖过来,然后写一下注册表调用IE11的内核显示,这个代码是抄的: 然后在Form的Load里面写: SetWebBrowserFeatures(11);//内核为11 就OK了,然后就是处理新窗口的问题

    2024年02月12日
    浏览(40)
  • 【WinForm】WebView2-个性化浏览器-桌面程序开发详解

    这是一个桌面程序上的浏览器,是用插件WebView2开发的浏览器桌面程序,功能体验堪比Edge浏览器,相比使用Chrome内核插件开发浏览器来说,还是用插件WebView2开发来得简单一些,接下来讲一讲实现过程。 开发之前,建议先看看微软的 WebView2 开发文档,很有帮助 使用Visual Stu

    2024年02月04日
    浏览(36)
  • 用C#破解Chrome浏览器cookie值

    背景 最近小编接到一个获取网站请求数据的需求,要求抓取网站某个页面请求的数据。我使用Google Chrome浏览器查看了一下请求链接的传入参数,发现需要传入一个Token值才能获取数据。于是我在Chrome中登录后,通过Postman请求成功,并将Token存储到了Cookie中。然而问题又来了,

    2023年04月18日
    浏览(35)
  • C# WebBrowser无法跳转默认浏览器问题

    使用WebBrowser只是为了做内嵌页展示,内嵌页内容链接要跳转系统默认浏览器。 1.非ui主线程打开的WebBrowser加载的网页内容链接无法跳转 2.非链接标签无法跳转,如下button标签 WebBrowser控件的内核为IE,默认为IE7,很多的网站不支持IE7,所以需要使用WebBrowser的话,对WebBrowser提升

    2024年02月07日
    浏览(40)
  • 『DotNetBrowser』.Net的浏览器嵌入组件,该选择DotNetBrowser 还是 CefSharp?

    📣读完这篇文章里你能收获到 全方位对比 DotNetBrowser 和 CefSharp 的优缺点 将浏览器嵌入 .NET 应用程序中: DotNetBrowser 还是 CefSharp ? 为 WPF 或 WinForms 应用程序选择浏览器组件,对于那些搜索基于Chrome的解决方案的人来说,, DotNetBrowser和CefSharp是最明显的选择。 本文是在考虑其

    2024年02月17日
    浏览(62)
  • C# 在win10/win11调用默认浏览器打开网页

    对于使用C#调用默认浏览器打开网页这个话题,网上资源一般都用的是 Registry.ClassesRoot.OpenSubKey(@\\\"httpshellopencommand\\\"); 或者 System.Diagnostics.Process.Start(\\\"explorer.exe\\\", \\\"...\\\") 之类,但在实践过程中发现前者在Windows 10之后修改默认浏览器并不会修改注册表的这一字节而导致只会调用

    2024年02月13日
    浏览(63)
  • winform嵌入浏览器 webView2

    1、项目引用nuget 2、winform窗体中初始化 3、webView2中的js调用c#代码

    2024年02月10日
    浏览(42)
  • net中winform教程 浏览器控件,还是微软的WebView2最好用

    如果想在Winform项目中使用浏览器控件,可能想到的第一个控件就是微软自带的WebBrowser,可这个不争气的家伙,从出现到现在,没有一丁点的升级,即使身为Net程序员,也不得不对它竖起了中指。不过,好在微软迷途知返,提供了升级控件,才算摆平。不然让Google的Cef控件抢

    2024年02月11日
    浏览(52)
  • 前端:html实现页面切换、顶部标签栏,类似于浏览器的顶部标签栏(完整版)

    效果 代码 解决BUG:关闭单页时,单页数据未清空,导致再次打开单页时出现内容仍然存在的问题

    2024年02月11日
    浏览(53)
  • 一.Winform使用Webview2(Edge浏览器核心) 创建demo(Demo1)实现回车导航到指定地址

    往期相关文章目录 专栏目录 WinForms 应用中的 WebView2 入门 按照官方文档一路操作,可以自行百度或者查看WinForms 应用中的 WebView2 入门。为了避坑,本人安装的时vs2022(visual studio 以下简称vs) 打开vs(visual studio 以下简称vs) 点击 创建新项目 ,选择 C# Windows 窗体应用 (.NET Framework

    2024年02月21日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包