質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

2回答

5008閲覧

C#のWPFアプリでwebViewで表示された画面上に画像を表示したいのですが方法がわかりません

kishidamisao

総合スコア16

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

0グッド

0クリップ

投稿2021/06/15 03:10

C#のWPFアプリを使用して「webView」を使用してHPページを表示しています。
そのHPページ上に画像を表示したいのですが、常に「webView」が最前面に表示され
画像が背面に表示されます。
画像を最前面に表示する方法をご存知でしたらご教授ください。

画像と、「webView」に「Panel.ZIndex」を指定したのですが、変化はありませんでした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hihijiji

2021/06/15 04:57

WebView2じゃだめですか?
kishidamisao

2021/06/15 05:09

<code> 表示には、WebView2を使用していますが、webViewの上に画像が表示されないので どのようにすればと、困ってます。 <wv2:WebView2 x:Name="webView" Panel.ZIndex="9999"> webView2.CoreWebView2.Navigate(URI); </code>
hihijiji

2021/06/15 06:49

別の描画エンジンで描画したものをオーバーレイ表示しているみたいですね。 通常の方法ではだめっぽいです。
kishidamisao

2021/06/15 10:04

そのようですね。では、HTMLを用いて画像を重ねることにはできますね。 ついてに、HTML画像をクリックした時に、javascriptでイベントを拾えば、 WPF側でもイベントを拾えそうですね。 試してみます。  結果は、お知らせします。
guest

回答2

0

WebBrowserWebViewWebVew2すべてそうだと思いますが、別のハンドルを持ったウィンドウ(IEEgdeの描画部分のようなもの)が重なっているからです。

空域問題(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>

アプリ動画

投稿2021/06/15 10:23

編集2024/11/13 13:17
TN8001

総合スコア9862

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自己解決

C#のWPFアプリでwebView2上に画像等を重ねる場合は、新しいwebView2を作成して重ねる
と出来ました。
つまり、webView2上に、別のwebView2を重ねるということになります。

「webView2」と画像表示とは別のエンジンであることが、今回の肝になりました。
ありがとうございました。

投稿2021/06/16 03:00

kishidamisao

総合スコア16

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問