C#實(shí)現(xiàn)老板鍵功能的代碼
C#設(shè)置熱鍵隱藏指定窗口的代碼
using System; using System.Text; using System.Collections; using System.Runtime.InteropServices; namespace WindowHider { /// <summary> /// Object used to control a Windows Form. /// </summary> public class Window { /// <summary> /// Win32 API Imports /// </summary> [DllImport("user32.dll")] private static extern bool ShowWindowAsync(IntPtr hWnd, int nCmdShow); [DllImport("user32.dll")] private static extern bool SetForegroundWindow(IntPtr hWnd); [DllImport("user32.dll")] private static extern bool IsIconic(IntPtr hWnd); [DllImport("user32.dll")] private static extern bool IsZoomed(IntPtr hWnd); [DllImport("user32.dll")] private static extern IntPtr GetForegroundWindow(); [DllImport("user32.dll")] private static extern IntPtr GetWindowThreadProcessId(IntPtr hWnd, IntPtr ProcessId); [DllImport("user32.dll")] private static extern IntPtr AttachThreadInput(IntPtr idAttach, IntPtr idAttachTo, int fAttach); /// <summary> /// Win32 API Constants for ShowWindowAsync() /// </summary> private const int SW_HIDE = 0; private const int SW_SHOWNORMAL = 1; private const int SW_SHOWMINIMIZED = 2; private const int SW_SHOWMAXIMIZED = 3; private const int SW_SHOWNOACTIVATE = 4; private const int SW_RESTORE = 9; private const int SW_SHOWDEFAULT = 10; /// <summary> /// Private Fields /// </summary> private IntPtr m_hWnd; private string m_Title; private bool m_Visible = true; private string m_Process; private bool m_WasMax = false; /// <summary> /// Window Object's Public Properties /// </summary> public IntPtr hWnd { get{return m_hWnd;} } public string Title { get{return m_Title;} } public string Process { get{return m_Process;} } /// <summary> /// Sets this Window Object's visibility /// </summary> public bool Visible { get{return m_Visible;} set { //show the window if(value == true) { if(m_WasMax) { if(ShowWindowAsync(m_hWnd,SW_SHOWMAXIMIZED)) m_Visible = true; } else { if(ShowWindowAsync(m_hWnd,SW_SHOWNORMAL)) m_Visible = true; } } //hide the window if(value == false) { m_WasMax = IsZoomed(m_hWnd); if(ShowWindowAsync(m_hWnd,SW_HIDE)) m_Visible = false; } } } /// <summary> /// Constructs a Window Object /// </summary> /// <param name="Title">Title Caption</param> /// <param name="hWnd">Handle</param> /// <param name="Process">Owning Process</param> public Window(string Title, IntPtr hWnd, string Process) { m_Title = Title; m_hWnd = hWnd; m_Process = Process; } //Override ToString() public override string ToString() { //return the title if it has one, if not return the process name if (m_Title.Length > 0) { return m_Title; } else { return m_Process; } } /// <summary> /// Sets focus to this Window Object /// </summary> public void Activate() { if(m_hWnd == GetForegroundWindow()) return; IntPtr ThreadID1 = GetWindowThreadProcessId(GetForegroundWindow(), IntPtr.Zero); IntPtr ThreadID2 = GetWindowThreadProcessId(m_hWnd,IntPtr.Zero); if (ThreadID1 != ThreadID2) { AttachThreadInput(ThreadID1,ThreadID2,1); SetForegroundWindow(m_hWnd); AttachThreadInput(ThreadID1,ThreadID2,0); } else { SetForegroundWindow(m_hWnd); } if (IsIconic(m_hWnd)) { ShowWindowAsync(m_hWnd,SW_RESTORE); } else { ShowWindowAsync(m_hWnd,SW_SHOWNORMAL); } } } /// <summary> /// Collection used to enumerate Window Objects /// </summary> public class Windows : IEnumerable, IEnumerator { /// <summary> /// Win32 API Imports /// </summary> [DllImport("user32.dll")] private static extern int GetWindowText(int hWnd, StringBuilder title, int size); [DllImport("user32.dll")] private static extern int GetWindowModuleFileName(int hWnd, StringBuilder title, int size); [DllImport("user32.dll")] private static extern int EnumWindows(EnumWindowsProc ewp, int lParam); [DllImport("user32.dll")] private static extern bool IsWindowVisible(int hWnd); //delegate used for EnumWindows() callback function public delegate bool EnumWindowsProc(int hWnd, int lParam); private int m_Position = -1; // holds current index of wndArray, // necessary for IEnumerable ArrayList wndArray = new ArrayList(); //array of windows //Object's private fields private bool m_invisible = false; private bool m_notitle = false; /// <summary> /// Collection Constructor with additional options /// </summary> /// <param name="Invisible">Include invisible Windows</param> /// <param name="Untitled">Include untitled Windows</param> public Windows(bool Invisible, bool Untitled) { m_invisible = Invisible; m_notitle = Untitled; //Declare a callback delegate for EnumWindows() API call EnumWindowsProc ewp = new EnumWindowsProc(EvalWindow); //Enumerate all Windows EnumWindows(ewp, 0); } /// <summary> /// Collection Constructor /// </summary> public Windows() { //Declare a callback delegate for EnumWindows() API call EnumWindowsProc ewp = new EnumWindowsProc(EvalWindow); //Enumerate all Windows EnumWindows(ewp, 0); } //EnumWindows CALLBACK function private bool EvalWindow(int hWnd, int lParam) { if (m_invisible == false && !IsWindowVisible(hWnd)) return(true); StringBuilder title = new StringBuilder(256); StringBuilder module = new StringBuilder(256); GetWindowModuleFileName(hWnd, module, 256); GetWindowText(hWnd, title, 256); if (m_notitle == false && title.Length == 0) return(true); wndArray.Add(new Window(title.ToString(), (IntPtr)hWnd, module.ToString())); return(true); } //implement IEnumerable public IEnumerator GetEnumerator() { return (IEnumerator)this; } //implement IEnumerator public bool MoveNext() { m_Position++; if (m_Position < wndArray.Count) { return true; } else { return false; } } public void Reset() { m_Position = -1; } public object Current { get { return wndArray[m_Position]; } } } }
再給大家分享一個(gè)其他網(wǎng)友的方法,也非常不錯(cuò),詳情請(qǐng)看注釋。
using System; using System.Collections.Generic; using System.Runtime.InteropServices; using System.Windows.Forms; namespace drmaple { class HotKey { //如果函數(shù)執(zhí)行成功,返回值不為0。 //如果函數(shù)執(zhí)行失敗,返回值為0。要得到擴(kuò)展錯(cuò)誤信息,調(diào)用GetLastError。 [DllImport("user32.dll", SetLastError = true)] public static extern bool RegisterHotKey( IntPtr hWnd, //要定義熱鍵的窗口的句柄 int id, //定義熱鍵ID(不能與其它ID重復(fù)) KeyModifiers fsModifiers, //標(biāo)識(shí)熱鍵是否在按Alt、Ctrl、Shift、Windows等鍵時(shí)才會(huì)生效 Keys vk //定義熱鍵的內(nèi)容 ); [DllImport("user32.dll", SetLastError = true)] public static extern bool UnregisterHotKey( IntPtr hWnd, //要取消熱鍵的窗口的句柄 int id //要取消熱鍵的ID ); //定義了輔助鍵的名稱(將數(shù)字轉(zhuǎn)變?yōu)樽址员阌谟洃?,也可去除此枚舉而直接使用數(shù)值) [Flags()] public enum KeyModifiers { None = 0, Alt = 1, Ctrl = 2, Shift = 4, WindowsKey = 8 } } } //簡(jiǎn)單說(shuō)明一下: //“public static extern bool RegisterHotKey()”這個(gè)函數(shù)用于注冊(cè)熱鍵。由于這個(gè)函數(shù)需要引用user32.dll動(dòng)態(tài)鏈接庫(kù)后才能使用,并且 //user32.dll是非托管代碼,不能用命名空間的方式直接引用,所以需要用“DllImport”進(jìn)行引入后才能使用。于是在函數(shù)前面需要加上 //“[DllImport("user32.dll", SetLastError = true)]”這行語(yǔ)句。 //“public static extern bool UnregisterHotKey()”這個(gè)函數(shù)用于注銷熱鍵,同理也需要用DllImport引用user32.dll后才能使用。 //“public enum KeyModifiers{}”定義了一組枚舉,將輔助鍵的數(shù)字代碼直接表示為文字,以方便使用。這樣在調(diào)用時(shí)我們不必記住每一個(gè)輔 //助鍵的代碼而只需直接選擇其名稱即可。 //(2)以窗體FormA為例,介紹HotKey類的使用 //在FormA的Activate事件中注冊(cè)熱鍵,本例中注冊(cè)Shift+S,Ctrl+Z,Alt+D這三個(gè)熱鍵。這里的Id號(hào)可任意設(shè)置,但要保證不被重復(fù)。 private void Form_Activated(object sender, EventArgs e) { //注冊(cè)熱鍵Shift+S,Id號(hào)為100。HotKey.KeyModifiers.Shift也可以直接使用數(shù)字4來(lái)表示。 HotKey.RegisterHotKey(Handle, 100, HotKey.KeyModifiers.Shift, Keys.S); //注冊(cè)熱鍵Ctrl+B,Id號(hào)為101。HotKey.KeyModifiers.Ctrl也可以直接使用數(shù)字2來(lái)表示。 HotKey.RegisterHotKey(Handle, 101, HotKey.KeyModifiers.Ctrl, Keys.B); //注冊(cè)熱鍵Alt+D,Id號(hào)為102。HotKey.KeyModifiers.Alt也可以直接使用數(shù)字1來(lái)表示。 HotKey.RegisterHotKey(Handle, 102, HotKey.KeyModifiers.Alt, Keys.D); } //在FormA的Leave事件中注銷熱鍵。 private void FrmSale_Leave(object sender, EventArgs e) { //注銷Id號(hào)為100的熱鍵設(shè)定 HotKey.UnregisterHotKey(Handle, 100); //注銷Id號(hào)為101的熱鍵設(shè)定 HotKey.UnregisterHotKey(Handle, 101); //注銷Id號(hào)為102的熱鍵設(shè)定 HotKey.UnregisterHotKey(Handle, 102); } 重載FromA中的WndProc函數(shù) /// /// 監(jiān)視Windows消息 /// 重載WndProc方法,用于實(shí)現(xiàn)熱鍵響應(yīng) /// /// protected override void WndProc(ref Message m) { const int WM_HOTKEY = 0x0312; //按快捷鍵 switch (m.Msg) { case WM_HOTKEY: switch (m.WParam.ToInt32()) { case 100: //按下的是Shift+S //此處填寫(xiě)快捷鍵響應(yīng)代碼 break; case 101: //按下的是Ctrl+B //此處填寫(xiě)快捷鍵響應(yīng)代碼 break; case 102: //按下的是Alt+D //此處填寫(xiě)快捷鍵響應(yīng)代碼 break; } break; } base.WndProc(ref m); }
以上所述就是本文的全部?jī)?nèi)容了,希望對(duì)大家學(xué)習(xí)C#能夠有所幫助。
- C#生成Word文檔代碼示例
- C#實(shí)現(xiàn)關(guān)閉其他程序窗口或進(jìn)程代碼分享
- C#判斷某個(gè)軟件是否已安裝實(shí)現(xiàn)代碼分享
- C#實(shí)現(xiàn)的json序列化和反序列化代碼實(shí)例
- C#代碼性能測(cè)試類(簡(jiǎn)單實(shí)用)
- C#對(duì)稱加密(AES加密)每次生成的結(jié)果都不同的實(shí)現(xiàn)思路和代碼實(shí)例
- C#實(shí)現(xiàn)開(kāi)機(jī)自動(dòng)啟動(dòng)設(shè)置代碼分享
- C#對(duì)文件進(jìn)行加密解密代碼
- C#之IO讀寫(xiě)文件方法封裝代碼
- C#一個(gè)簡(jiǎn)單的定時(shí)小程序?qū)崿F(xiàn)代碼
- C#獲取網(wǎng)頁(yè)源代碼的方法
- 10個(gè)C#程序員經(jīng)常用到的實(shí)用代碼片段
相關(guān)文章
Visual Studio中根據(jù)系統(tǒng)區(qū)分引用64位、32位DLL動(dòng)態(tài)庫(kù)文件的配置方法
這篇文章主要介紹了Visual Studio中根據(jù)系統(tǒng)區(qū)分引用64位、32位DLL動(dòng)態(tài)庫(kù)文件的配置方法,本文在VS2008中測(cè)試通過(guò),其它VS版本可以參考下2014-09-09c#高效率導(dǎo)出多維表頭excel的實(shí)例代碼
這篇文章介紹了c#高效率導(dǎo)出多維表頭excel的實(shí)例代碼,有需要的朋友可以參考一下2013-11-11C#截取中英文混合指定長(zhǎng)度字符串實(shí)例
這篇文章主要介紹了C#截取中英文混合指定長(zhǎng)度字符串,大家參考使用2013-12-12C#中循環(huán)語(yǔ)句:while、for、foreach的使用
本篇文章主要介紹了C#中的三種循環(huán)語(yǔ)句(while、for、foreach)的實(shí)現(xiàn)方式,需要的朋友可以參考下2015-07-07淺析C#?AsyncLocal如何實(shí)現(xiàn)Thread間傳值
這篇文章主要是來(lái)和大家一起討論一下C#?AsyncLocal如何實(shí)現(xiàn)Thread間傳值,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01C#中使用DataContractSerializer類實(shí)現(xiàn)深拷貝操作示例
這篇文章主要介紹了C#中使用DataContractSerializer類實(shí)現(xiàn)深拷貝操作示例,本文給出了實(shí)現(xiàn)深拷貝方法、測(cè)試深拷貝方法例子、DataContractSerializer類實(shí)現(xiàn)深拷貝的原理等內(nèi)容,需要的朋友可以參考下2015-06-06C#中的時(shí)間顯示格式(12小時(shí)制VS24小時(shí)制)
這篇文章主要介紹了C#中的時(shí)間顯示格式(12小時(shí)制VS24小時(shí)制),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01