ToPng
Often I need to do one of the following:
- Convert some HTML to a PNG
- Take the content of a Xamarin.Forms.WebView and turn it into a PNG
I've had to do this enough times that I finally broke down and added it to Forms9Patch.
Convert HTML to a PNG
Usage is as follows:
if (await Forms9Patch.ToPngService.ToPngAsync(_htmlEditor.Text, "myHtmlPage") is ToFileResult result)
{
if (result.IsError)
{
using (Forms9Patch.Toast.Create("PNG error", result.Result)) { }
}
else
{
var entry = new Forms9Patch.MimeItemCollection();
entry.AddBytesFromFile("image/png", result.Result);
if (e.Segment.Text == shareButtonText)
Forms9Patch.Sharing.Share(entry, _destinationSelector);
else if (e.Segment.Text == copyButtonText)
Forms9Patch.Clipboard.Entry = entry;
}
}
In the above example, we are putting the PNG onto the clipboard. Xamarin.Essentials.Sharing could also be used.
Xamarin.Forms.WebView to a PNG
Below, we take the contents of a Xamarin.Forms.WebView and Share it as a PNG:
...
var myWebView = new Xamarin.Forms.WebView();
WebViewPrintEffect.ApplyTo(myWebView);
myWebView.Source = new HtmlWebViewSource { Html = "some HTML text here" };
...
if (await myWebView.ToPngAsync("output.png") is ToFileResult result)
{
if (result.IsError)
{
using (Forms9Patch.Toast.Create("PNG error", result.Result)) { }
}
else
{
await Xamarin.Essentials.Share.RequestAsync(new Xamarin.Essentials.ShareFileRequest
{
Title = "myWebView sharing title",
File = new Xamarin.Forms.ShareFile(result.Result, "image/png")
});
}
}
Using EmbeddedResource as a source for a Xamarin.Forms.WebView
This is sort of an experimental feature but I've found it useful. As such the documentation is sparse. It allow you to put HTML content in a folder in your app's EmbeddedResources folder and then use it as a source for a WebView. A much nicer solution than using platform specific approach provided by Xamarin. It also supports putting all of the HTML content into a zip file. Please take a look at the source code to see how it works.