DotNetBrowser.WinForms
3.0.0
Prefix Reserved
dotnet add package DotNetBrowser.WinForms --version 3.0.0
NuGet\Install-Package DotNetBrowser.WinForms -Version 3.0.0
<PackageReference Include="DotNetBrowser.WinForms" Version="3.0.0" />
paket add DotNetBrowser.WinForms --version 3.0.0
#r "nuget: DotNetBrowser.WinForms, 3.0.0"
// Install DotNetBrowser.WinForms as a Cake Addin #addin nuget:?package=DotNetBrowser.WinForms&version=3.0.0 // Install DotNetBrowser.WinForms as a Cake Tool #tool nuget:?package=DotNetBrowser.WinForms&version=3.0.0
DotNetBrowser
Integrate a Chromium-based browser into your .NET application to load and process modern web pages built with HTML5, CSS3, JavaScript etc.
To be able to use DotNetBrowser, you should obtain a license. A free 30-day evaluation license can be requested by filling a form at https://www.teamdev.com/dotnetbrowser#evaluate
Deep Chromium integration
DotNetBrowser provides API that can be used to interact with a huge set of various Chromium features directly from the code:
- DOM API: you can access Document Object Model of the loaded web page, find elements and interact with them, handle and dispatch DOM events for the particular nodes.
- JS-.NET bridge: you can execute JavaScript on the web page and process the results. You can also inject any .NET object into the web page and then use it in your JavaScript code.
- Printing API: you can initiate and configure printing programmatically. Printing to PDF is also supported out of box.
- Network API: you can intercept, redirect, handle, and suppress network requests, override HTTP headers and POST data, filter out incoming and outgoing cookies, change proxy settings on the fly.
See the examples to understand what can be implemented with DotNetBrowser.
Easy deployment
All required Chromium binaries are deployed as DotNetBrowser DLLs and can be extracted automatically during execution. You don't need to pre-install Chromium, Google Chrome, or a Chromium-based runtime to work with DotNetBrowser.
The current release of DotNetBrowser uses Chromium build 131.0.6778.70.
Headless mode
DotNetBrowser can be used in Windows services and server apps. The web page can be loaded and rendered completely in memory without displaying any visible windows. You can then take a screenshot of the loaded web page.
User input simulation
DotNetBrowser provides means to simulate mouse and keyboard input and interact with the web page programmatically - exactly as regular users do.
UI
DotNetBrowser provides UI controls for WPF and Windows Forms applications. These controls can be used to display web pages as integral parts of the .NET applications. It is also possible to use DotNetBrowser to create VSTO add-ins.
Usage
Note: The VB.NET examples can be found in the examples repository.
WPF
XAML
<Window x:Class="Sample.Wpf.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:wpf="clr-namespace:DotNetBrowser.Wpf;assembly=DotNetBrowser.Wpf"
mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800" Closed="MainWindow_OnClosed">
<Grid>
<wpf:BrowserView x:Name="browserView"/>
</Grid>
</Window>
Code
using System;
using System.Windows
using DotNetBrowser.Browser;
using DotNetBrowser.Engine;
namespace Sample.Wpf {
public partial class MainWindow : Window {
private readonly IEngine engine;
private readonly IBrowser browser;
public MainWindow() {
InitializeComponent();
// Create and initialize the IEngine
engine = EngineFactory.Create();
// Create the IBrowser
browser = engine.CreateBrowser();
browser.Navigation.LoadUrl("https://html5test.teamdev.com/");
// Initialize the WPF BrowserView control
browserView.InitializeFrom(browser);
}
private void MainWindow_OnClosed(object sender, EventArgs e) {
browser.Dispose();
engine.Dispose();
}
}
}
Windows Forms
using System;
using System.Windows.Forms;
using DotNetBrowser.Browser;
using DotNetBrowser.Engine;
using DotNetBrowser.WinForms;
namespace Sample.WinForms {
public partial class Form1 : Form {
private readonly IEngine engine;
private readonly IBrowser browser;
public Form1() {
InitializeComponent();
// Create and initialize the IEngine
engine = EngineFactory.Create();
// Create the Windows Forms BrowserView control
BrowserView browserView = new BrowserView() {
Dock = DockStyle.Fill
};
// Create the IBrowser
browser = engine.CreateBrowser();
browser.Navigation.LoadUrl("https://html5test.teamdev.com/");
// Initialize the Windows Forms BrowserView control
browserView.InitializeFrom(browser);
// Add the BrowserView control to the Form
Controls.Add(browserView);
Closed += Form1Closed;
}
private void Form1Closed(object sender, EventArgs e) {
browser.Dispose();
engine.Dispose();
}
}
}
Avalonia UI
AXAML
<Window xmlns="https://github.com/avaloniaui"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:app="clr-namespace:DotNetBrowser.AvaloniaUi;assembly=DotNetBrowser.AvaloniaUi"
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
x:Class="Embedding.AvaloniaUi.MainWindow"
Title="Embedding.AvaloniaUi" Closed="Window_Closed">
<app:BrowserView x:Name="BrowserView"/>
</Window>
Code
using System;
using Avalonia.Controls;
using DotNetBrowser.Browser;
using DotNetBrowser.Engine;
namespace Embedding.AvaloniaUi
{
/// <summary>
/// This example demonstrates how to embed DotNetBrowser
/// into an Avalonia application.
/// </summary>
public partial class MainWindow : Window
{
private const string Url = "https://html5test.teamdev.com/";
private readonly IBrowser browser;
private readonly IEngine engine;
public MainWindow()
{
// Create and initialize the IEngine
engine = EngineFactory.Create();
// Create the IBrowser instance.
browser = engine.CreateBrowser();
InitializeComponent();
// Initialize the Avalonia UI BrowserView control.
BrowserView.InitializeFrom(browser);
browser.Navigation.LoadUrl(Url);
}
private void Window_Closed(object? sender, EventArgs e)
{
browser?.Dispose();
engine?.Dispose();
}
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp3.0 is compatible. netcoreapp3.1 was computed. |
.NET Framework | net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
-
.NETCoreApp 3.0
- DotNetBrowser (>= 3.0.0)
-
.NETFramework 4.6.2
- DotNetBrowser (>= 3.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
3.0.0 | 217 | 12/3/2024 |
3.0.0-eap.2 | 114 | 8/20/2024 |
3.0.0-eap.1 | 83 | 5/22/2024 |
2.27.7 | 126 | 12/5/2024 |
2.27.6 | 190 | 11/12/2024 |
2.27.5 | 543 | 10/2/2024 |
2.27.4 | 253 | 9/13/2024 |
2.27.3 | 371 | 8/5/2024 |
2.27.2 | 284 | 6/21/2024 |
2.27.1 | 413 | 5/30/2024 |
2.27.0 | 162 | 5/22/2024 |
2.26.2 | 491 | 4/24/2024 |
2.26.1 | 270 | 3/28/2024 |
2.26.0 | 390 | 2/27/2024 |
2.25.1 | 373 | 1/22/2024 |
2.25.0 | 281 | 12/27/2023 |
2.24.2 | 348 | 11/22/2023 |
2.24.1 | 420 | 10/20/2023 |
2.24.0 | 501 | 10/3/2023 |
2.23.3 | 427 | 9/6/2023 |
2.23.2 | 554 | 8/3/2023 |
2.23.1 | 604 | 6/22/2023 |
2.23.0 | 1,912 | 5/25/2023 |
2.22.1 | 370 | 4/27/2023 |
2.22.0 | 535 | 3/23/2023 |
2.21.0 | 1,898 | 2/27/2023 |
2.20.1 | 468 | 2/7/2023 |
2.20.0 | 622 | 12/28/2022 |
2.19.0 | 473 | 12/5/2022 |
2.18.0 | 1,192 | 10/21/2022 |
2.17.0 | 967 | 10/5/2022 |
2.16.1 | 2,160 | 8/23/2022 |
2.16.0 | 656 | 8/8/2022 |
2.15.1 | 1,173 | 6/17/2022 |
2.15.0 | 811 | 6/14/2022 |
2.14.0 | 1,007 | 4/29/2022 |
2.13.1 | 721 | 4/12/2022 |
2.13.0 | 632 | 4/7/2022 |
2.12.0 | 1,167 | 3/23/2022 |
2.11.0 | 1,591 | 1/14/2022 |
2.10.0 | 2,770 | 11/18/2021 |
2.9.0 | 1,753 | 9/24/2021 |
2.8.0 | 1,186 | 8/20/2021 |
2.7.0 | 524 | 7/26/2021 |
2.6.0 | 1,374 | 5/27/2021 |
2.5.0 | 1,970 | 4/7/2021 |
2.4.0 | 1,190 | 3/2/2021 |
2.3.0 | 4,482 | 11/26/2020 |
2.2.0 | 1,733 | 9/9/2020 |
2.1.1 | 1,782 | 7/2/2020 |
2.1.0 | 834 | 6/18/2020 |
2.0.0 | 1,828 | 2/27/2020 |
We've bumped Chromium to version 131.0.6778.70.
Find more about fixes and improvements in our release notes:
https://teamdev.com/dotnetbrowser/release-notes/2024/v3-0-0.html