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

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

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

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

Windows Forms

Windows Forms(WinForms)はMicrosoft .NET フレームワークに含まれる視覚的なアプリケーションのプログラミングインターフェイス(API)です。WinFormsは管理されているコードの既存のWindowsのAPIをラップすることで元のMicrosoft Windowsのインターフェイスのエレメントにアクセスすることができます。

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

Q&A

0回答

881閲覧

FormアプリケーションのWebBrowserコントロール内のHTML要素のマウスホバーでポップアップを表示したい

abroad128

総合スコア60

C#

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

Windows Forms

Windows Forms(WinForms)はMicrosoft .NET フレームワークに含まれる視覚的なアプリケーションのプログラミングインターフェイス(API)です。WinFormsは管理されているコードの既存のWindowsのAPIをラップすることで元のMicrosoft Windowsのインターフェイスのエレメントにアクセスすることができます。

.NET Framework

.NET Framework は、Microsoft Windowsのオペレーティングシステムのために開発されたソフトウェア開発環境/実行環境です。多くのプログラミング言語をサポートしています。

0グッド

0クリップ

投稿2021/02/18 04:06

編集2021/02/18 04:20

下記コードで,C#とjsを連携してToolStripDropDownでポップアップを出すところまでは上手くいくのですが,HTML要素からマウスを外してもjsのmouseleaveイベントが発火しません.
ただし,マウスをポップアップの上に持っていくと発火するようです.
ポップアップ側ではなく他の方向からマウスを逃がすと発火しません.
イメージ説明

また,C#側でポップアップをShowしない場合は発火するようです.
試しにShowの後にWebBrowserコントロールにFocusするコードを書いてみましたが,それでもjsのmouseleaveが発火しません.
何故なのでしょうか.

C#

1using System; 2using System.Collections.Generic; 3using System.ComponentModel; 4using System.Data; 5using System.Drawing; 6using System.Linq; 7using System.Runtime.InteropServices; 8using System.Text; 9using System.Threading.Tasks; 10using System.Windows.Forms; 11 12namespace WindowsFormsApp5 13{ 14 public partial class Form1 : Form 15 { 16 public ToolStripDropDown toolStripDropDown; 17 18 public Form1() 19 { 20 InitializeComponent(); 21 22 toolStripDropDown = new ToolStripDropDown(); 23 toolStripDropDown.Margin = Padding.Empty; 24 toolStripDropDown.Padding = Padding.Empty; 25 toolStripDropDown.DropShadowEnabled = false; 26 27 webBrowser1.ObjectForScripting = new TestClasss(this); 28 webBrowser1.DocumentText = @"<script> 29 window.onload = function() { 30 var elm = document.createElement('div'); 31 elm.innerHTML = 'test'; 32 document.body.appendChild(elm); 33 34 elm.onmouseover = function() { 35 window.external.ShowPopup(this.getBoundingClientRect().left, this.getBoundingClientRect().top); 36 }; 37 38 elm.onmouseleave = function() 39 { 40 window.external.ClosePopup(); 41 }; 42 }; 43 </script>"; 44 } 45 } 46 47 [ComVisible(true)] 48 public class TestClasss 49 { 50 private Form1 viewer; 51 52 public TestClasss(Form1 viewer) 53 { 54 this.viewer = viewer; 55 } 56 57 public void ShowPopup(int x, int y) 58 { 59 var panel1 = new Panel(); 60 panel1.BackColor = Color.Red; 61 62 var label1 = new Label(); 63 label1.Text = "popup"; 64 panel1.Controls.Add(label1); 65 66 var toolStripControlHost = new ToolStripControlHost(panel1); 67 toolStripControlHost.Margin = Padding.Empty; 68 toolStripControlHost.Padding = Padding.Empty; 69 70 viewer.toolStripDropDown.Items.Clear(); 71 viewer.toolStripDropDown.Items.Add(toolStripControlHost); 72 viewer.toolStripDropDown.Show(viewer.webBrowser1, new Point(x, y), ToolStripDropDownDirection.AboveRight); 73 } 74 75 public void ClosePopup() 76 { 77 viewer.toolStripDropDown.Close(); 78 } 79 } 80} 81

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問