はじめに
Microsoft Internet Explorer もなくなり、Microsoft Edge も Chromium になって世の中が Chromium 一色となりました。Wpf を使ってWeb Browser を作るときは System.Windows.Controls.WebBrowser でしたが、これは内部がIE7というとんでもない骨董品でした。Wpf で Chromium は扱えなくもないですが、微妙に扱いにくいのでどうしたものかと思っていたら Microsoft が Microsoft.Web.WebView2 を出してくれたのでこれをちょっと触ってみることにします。
XAMLに埋め込む
XAMLに埋め込むのはこんな感じです。
<UserControl x:Class="UserControls.WebBrowser" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:wv2="clr-namespace:Microsoft.Web.WebView2.Wpf;assembly=Microsoft.Web.WebView2.Wpf" mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"> <Grid> <wv2:WebView2 x:Name="WebViewer" /> </Grid> </UserControl>
Microsoft.Web.WebView2 は Nuget から拾ってきます。
URLで画面遷移する
アドレスバーの入力など任意のWebページに遷移するのは Source Property を指定します。
using Microsoft.Web.WebView2.Wpf; using System; using System.IO; using System.Windows; using System.Windows.Controls; namespace UserControls.WebBrowser; public partial class WebBrowser : UserControl { public WebBrowser() { InitializeComponent(); WebViewer..Source = new Uri(@"https://www.lutheta.jp/"); } }
Responseを拾う
Response を拾うには WebResourceResponseReceived を拾えばいいです。ただ、これは Microsoft.Web.WebView2.Wpf.WebView2 の CoreWebView2 Property の Microsoft.Web.WebView2.Core.CoreWebView2 にあるので注意が必要です。
using Microsoft.Web.WebView2.Wpf; using System; using System.IO; using System.Windows; using System.Windows.Controls; namespace UserControls.WebBrowser; public partial class WebBrowser : UserControl { public WebBrowser() { InitializeComponent(); WebViewer.CoreWebView2InitializationCompleted += (sender, e) => { if (sender != null) ((WebView2)sender).CoreWebView2.WebResourceResponseReceived += async (sender, e) => { } }; } }
CoreWebView2 は Component の Initialize 時には Null なので CoreWebView2InitializationCompleted Event で WebResourceResponseReceived Event をセットするようにします。
これを利用して
とりあえず MarineTraffic から航跡を抽出するアプリを作ってみました。
MarinTraffic |
なかなか応用幅が広がりそうな感じでです。
0 件のコメント:
コメントを投稿