WebBrowser
・WebView
・WebVew2
すべてそうだと思いますが、別のハンドルを持ったウィンドウ(IE
やEgde
の描画部分のようなもの)が重なっているからです。
空域問題(Airspace problem)といって、上にコントロールを重ねたり透過にしたりができません。
WPF 相互運用 : "空域" およびウィンドウ領域の概要 | Microsoft Docs
ではどうするかですが、Popup
や別のWindow
をさらに上に重ねるのをよく見ますね(もちろんウィンドウが動いたら一緒に動かす必要があります)
「wpf webview airspace」あたりで検索してみてください。
WebView2
でも要望は上がっています。
技術的には可能でも需要が少ないと優先度が上がりませんので、投票等しておくといいかもしれません。
When using Webview2 in WPF, unable to overlay WPF controls on the Webview · Issue #286 · MicrosoftEdge/WebView2Feedback
WebBrowser overlaps other controls in WPF? · Issue #356 · MicrosoftEdge/WebView2Feedback
#286を見ると、もしかしたら何か動きがあるのかも??
ついにWebView2CompositionControl
が来ました^^
WebView2CompositionControl Class (Microsoft.Web.WebView2.Wpf) | Microsoft Learn
xml
1<Window
2 x:Class="Q344069.MainWindow"
3 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
4 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
5 xmlns:wv2="clr-namespace:Microsoft.Web.WebView2.Wpf;assembly=Microsoft.Web.WebView2.Wpf"
6 Width="800"
7 Height="450">
8 <Grid>
9 <Grid.ColumnDefinitions>
10 <ColumnDefinition />
11 <ColumnDefinition />
12 </Grid.ColumnDefinitions>
13 <GroupBox Header="WebView2">
14 <wv2:WebView2 Source="https://teratail.com/questions/344069" />
15 </GroupBox>
16
17 <GroupBox Grid.Column="1" Header="WebView2CompositionControl">
18 <wv2:WebView2CompositionControl Source="https://teratail.com/questions/344069" />
19 </GroupBox>
20
21 <Border
22 Grid.ColumnSpan="2"
23 HorizontalAlignment="Center"
24 VerticalAlignment="Center"
25 BorderBrush="Red"
26 BorderThickness="4">
27 <Image Source="https://teratail-v2.storage.googleapis.com/uploads/avatars/u13/132786/KnkDDC5A_thumbnail.jpg" Stretch="None" />
28 </Border>
29 </Grid>
30</Window>
xml
1<Project Sdk="Microsoft.NET.Sdk">
2
3 <PropertyGroup>
4 <OutputType>WinExe</OutputType>
5 <TargetFramework>net9.0-windows10.0.19041.0</TargetFramework>
6 <Nullable>enable</Nullable>
7 <ImplicitUsings>enable</ImplicitUsings>
8 <UseWPF>true</UseWPF>
9 </PropertyGroup>
10
11 <ItemGroup>
12 <PackageReference Include="Microsoft.Web.WebView2" Version="1.0.2895-prerelease" />
13 </ItemGroup>
14
15</Project>