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

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

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

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

Windows Forms

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

Q&A

解決済

2回答

2521閲覧

CefSharpのChromiumWebBrowserでZoomを実装したい(Winforms)

neji-thon

総合スコア7

C#

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

Windows Forms

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

1グッド

0クリップ

投稿2021/01/19 04:37

タイトル通り、Chromiumブラウザに対して画面の拡大、縮小を実装したいのですが、できずに苦戦しております。

ソースコードは以下のサイトから拾ってきたものを試しました。

参考サイト
https://ja.ojit.com/so/wpf/1456010

しかしながら、画像の通りkeyなどでエラーが多発し、電球マークに提案される内容でいろいろ変更を試しましたが、エラーが消えることはなく、Zoomできずにいます。
イメージ説明

うまくいかないソースコートはこちらです。

C#

1private void OnPreviewKeyUp(object sender, KeyEventArgs e) 2{ 3 if (e.Key == Key.RightCtrl || e.Key == Key.LeftCtrl) 4 { 5 isControlKeyPressed = false; 6 } 7} 8 9private void OnKPreviewKeyDown(object sender, KeyEventArgs e) 10{ 11 if (e.Key == Key.RightCtrl || e.Key == Key.LeftCtrl) 12 { 13 isControlKeyPressed = true; 14 } 15} 16 17private void OnMouseWheel(object sender, MouseWheelEventArgs e) 18{ 19 if (isControlKeyPressed) 20 { 21 if (e.Delta > 0 && browser.ZoomLevel <= maxZoomLevel) 22 { 23 browser.ZoomInCommand.Execute(null); 24 } 25 else if (e.Delta < 0 && browser.ZoomLevel >= minZoomLevel) 26 { 27 browser.ZoomOutCommand.Execute(null); 28 } 29 } 30}

目的は通常のChromeのようにCTRL+マウスホイールで画面の拡大・縮小ができるようになることなのです。

ソース内のbrowser.ZoomLevel等のbrowserの部分は自分の指定したブラウザ名になりそうですが、それ以外の大部分でエラーが解決できないため、ご存じの方がおりましたらご教示いただけますと幸いです。

よろしくお願いします。

TN8001👍を押しています

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

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

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

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

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

guest

回答2

0

ベストアンサー

ちょっと試してみたのですが、フォームでやるのはかなり大変そうです。

CefSharp.Wpfでは簡単に実現できましたが、CefSharp.WinFormsのほうは同様にやろうとしてもそもそものイベントが来ない状態でした。

おそらくこれが答えだと思いますが、私もちょっとわかりません^^;
chromium embedded - Allow user to zoom with mousewheel using the cefsharp browser - Stack Overflow

それ以外の方法としては

  • WPFに移行
    なかなかハードルが高いか?^^;
  • ElementHostCefSharp.Wpf.ChromiumWebBrowserをホスト
    バカバカしいが簡単にテストした限り動いた
  • WebView2を使う
    何もしないでもズームに対応していた

このどれかでよければミニマムサンプルは提示可能です。


参考
WPFコントロールをWindowsフォームに配置する - .NET Tips (VB.NET,C#...)

WebView2 for WinForms アプリの概要 - Microsoft Edge Development | Microsoft Docs


追記 ElementHostミニマムサンプル

参考ページの通りに参照の追加をします。
NuGetでCefSharp.Wpfのほうを入れます。

cs

1using System; 2using System.Diagnostics; 3using System.Windows.Forms; 4using System.Windows.Forms.Integration; 5 6namespace Questions316976 7{ 8 public partial class Form1 : Form 9 { 10 public Form1() 11 { 12 InitializeComponent(); 13 Load += Form1_Load; 14 } 15 16 private void Form1_Load(object sender, EventArgs e) 17 { 18 var browser = new CefSharp.Wpf.ChromiumWebBrowser("www.google.com"); 19 browser.PreviewMouseWheel += Browser_PreviewMouseWheel; 20 21 var elementHost = new ElementHost 22 { 23 Child = browser, 24 Dock = DockStyle.Fill, 25 }; 26 Controls.Add(elementHost); 27 } 28 29 private void Browser_PreviewMouseWheel(object sender, System.Windows.Input.MouseWheelEventArgs e) 30 { 31 if (sender is CefSharp.Wpf.ChromiumWebBrowser browser) 32 { 33 if ((System.Windows.Input.Keyboard.Modifiers & System.Windows.Input.ModifierKeys.Control) == System.Windows.Input.ModifierKeys.Control) 34 { 35 if (0 < e.Delta) browser.ZoomInCommand.Execute(null); 36 else browser.ZoomOutCommand.Execute(null); 37 38 Debug.WriteLine(browser.ZoomLevel); 39 } 40 } 41 } 42 } 43}

投稿2021/01/19 10:32

編集2023/07/26 13:19
TN8001

総合スコア9387

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

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

neji-thon

2021/01/19 11:19

ありがとうございます。 >ElementHostでCefSharp.Wpf.ChromiumWebBrowserをホスト Winforms側でのソースコードも増えてきてるので、部分的にWPFを呼び出す?ようなこちらがいいのかもしれません。 お手数ですが、ご教示いただいてよろしいでしょうか。 参考サイトなど見ながらちょっと勉強しにいってきます。
TN8001

2021/01/19 11:47

追記しました^^
neji-thon

2021/01/20 00:53

ありがとうございます! 早速いただいたコードと参照の追加をして、実行したときに画面上部にWinformsの時にはなかったバー?のようなものが出てきてるのでWPFはできてると思うのですが、ブラウザはCTRLがうまく噛んでないというか、マウスのホイールをくるくるしても、上下にスクロールするだけでズームできない状態です。 シンプルに一からプロジェクト作成した場合どうなるかとかやろうと思いますので少々お時間いただきそうです。。 ちなみに、そもそも自分の勉強不足で恐縮ですが、WinformsにはブラウザがIE6のものしかないと思って、CefSharp導入したのですが、WebView2の方がMicrosoft製のものとして最近出ていて、Visual studioとの親和性も高くなってきそうだから、WebView2のブラウザで構築しなおした方が今後、よさそうな感じなんでしょうか? 今のうちに乗り換えようかしら?とも思い始めています。
neji-thon

2021/01/20 04:34 編集

今のうちとか今後とかは自分判断ですね。失礼しました。 調べた限り、WebView2にしたいと思い始めております。 今夜にでもWebView2採用するか確認してみます。
TN8001

2021/01/20 08:18

>マウスのホイールをくるくるしても、上下にスクロールするだけでズームできない状態です。 Browser_PreviewMouseWheel自体呼ばれていないということでしょうかね? CefSharpのセットアップ法等にもよるのかもしれません??(手元では面倒だったのでx86ビルドで試しました) >シンプルに一からプロジェクト作成した場合どうなるかとかやろうと思いますので少々お時間いただきそうです。。 **私は**全然急いでいませんので大丈夫です^^; >WebView2の方がMicrosoft製のものとして最近出ていて、Visual studioとの親和性も高くなってきそうだから、WebView2のブラウザで構築しなおした方が今後、よさそうな感じなんでしょうか? サポートされているプラットフォーム等に問題がなければ、新規開発でWebView2を採用しない理由はないと思います。 もう読んでおられるでしょうが、↓周辺を一通り確認してください。 [Microsoft Edge WebView2 control - Microsoft Edge Development | Microsoft Docs](https://docs.microsoft.com/ja-jp/microsoft-edge/webview2/#next-steps 置き換えるかはCefSharpとコンパチというわけでもないので、既存コード量にもよるでしょう。 とはいえまだ新しいため、情報が全くないのが辛いところです^^;
neji-thon

2021/01/20 21:48

WebView2 めっちゃ簡単ですね! インストールしてランタイムがあれば動きました。 ZoomどころかCTRL+Fとかデベロッパーツールまで。。容量も少ないしChromiumからの乗り換えを決めました。 ありがとうございます。
guest

0

参考サイトはWpfのようですが、WindowsFormsとは細かい所で互換性が無いので、WpfのソースをそのままWindowsFormsに持ってきても使えないと思います。クラスリファレンスを見ながら、対応する定数やプロパティを探して地道に置き換えるしかないのではないでしょうか。

投稿2021/01/19 04:49

編集2021/01/19 04:55
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

neji-thon

2021/01/19 07:06

radianさん早速ご提案ありがとうございます。 まだWPFとWinformsの違いが分かってないのですが、ソースコードを見る限り、Winformsのものかと思って試してみていた次第です。 やはり地道にやるしかないですかね。引き続きいろいろ試してみますが、どなたか知ってたら教えていただきたいほど、着地が遠そうだな。。と感じています。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問