123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- using GeekDesk.Control.UserControls.Config;
- using GeekDesk.ViewModel;
- using Gma.System.MouseKeyHook;
- using System;
- using System.Windows;
- using System.Windows.Threading;
- namespace GeekDesk.MyThread
- {
- public class MouseHookThread
- {
- private static AppConfig appConfig = MainWindow.appData.AppConfig;
- private static IKeyboardMouseEvents m_GlobalHook = Hook.GlobalEvents();
- private static Dispatcher dispatcher;
- public static void MiddleHook()
- {
- //使用dispatcher来单独监听UI线程 防止程序卡顿
- dispatcher = DispatcherBuild.Build();
- m_GlobalHook = Hook.GlobalEvents();
- dispatcher.BeginInvoke((Action)(() =>
- {
- m_GlobalHook.MouseUpExt += M_GlobalHook_MouseUpExt;
- }));
- }
- public static void Dispose()
- {
- m_GlobalHook.MouseUpExt -= M_GlobalHook_MouseUpExt;
- m_GlobalHook.Dispose();
- dispatcher.InvokeShutdown();
- }
- /// <summary>
- /// 鼠标中键呼出
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private static void M_GlobalHook_MouseUpExt(object sender, System.Windows.Forms.MouseEventArgs e)
- {
- if (appConfig.MouseMiddleShow && e.Button == System.Windows.Forms.MouseButtons.Middle)
- {
- if (MotionControl.hotkeyFinished)
- {
- App.Current.Dispatcher.BeginInvoke(System.Windows.Threading.DispatcherPriority.Render, new Action(() =>
- {
- if (MainWindow.mainWindow.Visibility == Visibility.Collapsed || MainWindow.mainWindow.Opacity == 0)
- {
- MainWindow.ShowApp();
- }
- else
- {
- MainWindow.HideApp();
- }
- }));
- }
- }
- }
- }
- }
|