* Upgrade to v88.2.40-pre WPF - Add https scheme to default URL to workaround upstream issue https://bitbucket.org/chromiumembedded/cef/issues/3079/cant-load-urls-without-scheme * Net Core - Add AnyCPU Platform to projects/solution * Net Core - Add RuntimeIdentifier based on PlatformTarget - Set RuntimeIdentifier based on PlatformTarget (PlatformTarget isn't set of AnyCPU) - Set SelfContained to false so as not to provide a Framework Dependant build (don't include the whole .net framework) * WPF/WinForms - Change CefSharpBuildAction to Content For testing of ClickOnce publish * Net 5.0 - Update to include PublishSingleFile settings - .Net 5.0 Publish Settings for PublishSingleFile https://docs.microsoft.com/en-us/dotnet/core/deploying/single-file Defaults differ compared to .Net Core 3.1 - Set RollForward to Major so runs on newer runtime version - Add net5.0-windows TargetFramework * .Net 5.0 - Publish Single Exe Example - Use the main application exe as the BrowserSubprocess when self publishing a .Net 5.0 exe - Only the WPF and WinForms examples have been updated https://github.com/cefsharp/CefSharp/issues/3407 * Upgrade to 88.2.90
135 lines
5.6 KiB
C#
135 lines
5.6 KiB
C#
// Copyright © 2010-2015 The CefSharp Authors. All rights reserved.
|
|
//
|
|
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
|
|
|
|
using CefSharp.OffScreen;
|
|
using System;
|
|
using System.Diagnostics;
|
|
using System.IO;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace CefSharp.MinimalExample.OffScreen
|
|
{
|
|
public class Program
|
|
{
|
|
private static ChromiumWebBrowser browser;
|
|
|
|
public static int Main(string[] args)
|
|
{
|
|
#if ANYCPU
|
|
//Only required for PlatformTarget of AnyCPU
|
|
AppDomain.CurrentDomain.AssemblyResolve += Resolver;
|
|
#endif
|
|
|
|
const string testUrl = "https://www.google.com/";
|
|
|
|
Console.WriteLine("This example application will load {0}, take a screenshot, and save it to your desktop.", testUrl);
|
|
Console.WriteLine("You may see Chromium debugging output, please wait...");
|
|
Console.WriteLine();
|
|
|
|
var settings = new CefSettings()
|
|
{
|
|
//By default CefSharp will use an in-memory cache, you need to specify a Cache Folder to persist data
|
|
CachePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "CefSharp\\Cache")
|
|
};
|
|
|
|
var dependencyCheck = true;
|
|
|
|
#if NETCOREAPP || ANYCPU
|
|
//For .Net Core/.Net 5 this should be fixed as part of https://github.com/cefsharp/CefSharp/issues/3388
|
|
dependencyCheck = false;
|
|
#endif
|
|
|
|
//Perform dependency check to make sure all relevant resources are in our output directory.
|
|
Cef.Initialize(settings, performDependencyCheck: dependencyCheck, browserProcessHandler: null);
|
|
|
|
// Create the offscreen Chromium browser.
|
|
browser = new ChromiumWebBrowser(testUrl);
|
|
|
|
// An event that is fired when the first page is finished loading.
|
|
// This returns to us from another thread.
|
|
browser.LoadingStateChanged += BrowserLoadingStateChanged;
|
|
|
|
// We have to wait for something, otherwise the process will exit too soon.
|
|
Console.ReadKey();
|
|
|
|
// Clean up Chromium objects. You need to call this in your application otherwise
|
|
// you will get a crash when closing.
|
|
Cef.Shutdown();
|
|
|
|
return 0;
|
|
}
|
|
|
|
private static void BrowserLoadingStateChanged(object sender, LoadingStateChangedEventArgs e)
|
|
{
|
|
// Check to see if loading is complete - this event is called twice, one when loading starts
|
|
// second time when it's finished
|
|
// (rather than an iframe within the main frame).
|
|
if (!e.IsLoading)
|
|
{
|
|
// Remove the load event handler, because we only want one snapshot of the initial page.
|
|
browser.LoadingStateChanged -= BrowserLoadingStateChanged;
|
|
|
|
var scriptTask = browser.EvaluateScriptAsync("document.querySelector('[name=q]').value = 'CefSharp Was Here!'");
|
|
|
|
scriptTask.ContinueWith(t =>
|
|
{
|
|
//Give the browser a little time to render
|
|
Thread.Sleep(500);
|
|
// Wait for the screenshot to be taken.
|
|
var task = browser.ScreenshotAsync();
|
|
task.ContinueWith(x =>
|
|
{
|
|
// Make a file to save it to (e.g. C:\Users\jan\Desktop\CefSharp screenshot.png)
|
|
var screenshotPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Desktop), "CefSharp screenshot.png");
|
|
|
|
Console.WriteLine();
|
|
Console.WriteLine("Screenshot ready. Saving to {0}", screenshotPath);
|
|
|
|
// Save the Bitmap to the path.
|
|
// The image type is auto-detected via the ".png" extension.
|
|
task.Result.Save(screenshotPath);
|
|
|
|
// We no longer need the Bitmap.
|
|
// Dispose it to avoid keeping the memory alive. Especially important in 32-bit applications.
|
|
task.Result.Dispose();
|
|
|
|
Console.WriteLine("Screenshot saved. Launching your default image viewer...");
|
|
|
|
// Tell Windows to launch the saved image.
|
|
Process.Start(new ProcessStartInfo(screenshotPath)
|
|
{
|
|
// UseShellExecute is false by default on .NET Core.
|
|
UseShellExecute = true
|
|
});
|
|
|
|
Console.WriteLine("Image viewer launched. Press any key to exit.");
|
|
}, TaskScheduler.Default);
|
|
});
|
|
}
|
|
}
|
|
|
|
// Will attempt to load missing assembly from either x86 or x64 subdir
|
|
//when PlatformTarget is AnyCPU
|
|
#if ANYCPU
|
|
private static System.Reflection.Assembly Resolver(object sender, ResolveEventArgs args)
|
|
{
|
|
if (args.Name.StartsWith("CefSharp.Core.Runtime"))
|
|
{
|
|
string assemblyName = args.Name.Split(new[] { ',' }, 2)[0] + ".dll";
|
|
string archSpecificPath = Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase,
|
|
Environment.Is64BitProcess ? "x64" : "x86",
|
|
assemblyName);
|
|
|
|
return File.Exists(archSpecificPath)
|
|
? System.Reflection.Assembly.LoadFile(archSpecificPath)
|
|
: null;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
#endif
|
|
}
|
|
}
|