C#模擬實現鼠標自動點擊與消息發送功能
一個簡單的實現版本,沒有去Hook鍵鼠等操作,事先錄制好操作步驟(將鼠標移動到需要操作的位置,按下熱鍵執行相應動作),點擊運行即可。
主要還是用windows api來實現,模擬點擊、右擊、雙擊、發送文本等。
代碼可能略長一點,下面發下關鍵代碼
主要的思路就是操作熱鍵的時候,將操作類型以及坐標記錄到一個List中,然後利用Windows Api循環執行List中的數據
實現功能
模擬鼠標點擊、文本輸入
開發環境
開發工具: Visual Studio 2013
.NET Framework版本:4.5
實現代碼
#region 鼠標操作類型 private const int MOUSEEVENTF_MOVE = 1;//鼠標移動 private const int MOUSEEVENTF_LEFTDOWN = 2;//按下鼠標左鍵 private const int MOUSEEVENTF_LEFTUP = 4;//抬起鼠標左鍵 private const int MOUSEEVENTF_RIGHTDOWN = 8;//按下鼠標右鍵 private const int MOUSEEVENTF_RIGHTUP = 16;//抬起鼠標右鍵 #endregion #region Windows Api /// <summary> /// 鼠標操作 /// </summary> /// <param name="dwFlags"></param> /// <param name="dx"></param> /// <param name="dy"></param> /// <param name="cButtons"></param> /// <param name="dwExtraInfo"></param> [DllImport("user32.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Auto)] public static extern void mouse_event(int dwFlags, int dx, int dy, int cButtons, int dwExtraInfo); /// <summary> /// 設置鼠標位置 /// </summary> /// <param name="x"></param> /// <param name="y"></param> /// <returns></returns> [DllImport("user32")] public static extern int SetCursorPos(int x, int y); /// <summary> /// 註冊熱鍵 /// </summary> /// <param name="hWnd"></param> /// <param name="id"></param> /// <param name="control"></param> /// <param name="vk"></param> /// <returns></returns> [DllImport("user32")] public static extern bool RegisterHotKey(IntPtr hWnd, int id, uint control, Keys vk); /// <summary> /// 取消熱鍵 /// </summary> /// <param name="hWnd"></param> /// <param name="id"></param> /// <returns></returns> [DllImport("user32")] public static extern bool UnregisterHotKey(IntPtr hWnd, int id); #endregion
private List<EventClass> listEvent = new List<EventClass>(); /// <summary> /// 註冊/取消熱鍵 /// </summary> /// <param name="isReg"></param> private void RegistKey(bool isReg) { if (isReg) { RegisterHotKey(base.Handle, 30001, MOD_CONTROL, Keys.D1); RegisterHotKey(base.Handle, 30002, MOD_CONTROL, Keys.D2); RegisterHotKey(base.Handle, 30003, MOD_CONTROL, Keys.D3); RegisterHotKey(base.Handle, 30004, MOD_CONTROL, Keys.D4); RegisterHotKey(base.Handle, 30005, MOD_CONTROL, Keys.E); } else { UnregisterHotKey(base.Handle, 30001); UnregisterHotKey(base.Handle, 30002); UnregisterHotKey(base.Handle, 30003); UnregisterHotKey(base.Handle, 30004); UnregisterHotKey(base.Handle, 30005); } } //執行點擊事件 private void MouseClick(EventClass eventData) { SetCursorPos(eventData.X, eventData.Y); switch (eventData.clickType) { case ClickType.leftClick: mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); break; case ClickType.rightClick: mouse_event(MOUSEEVENTF_RIGHTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_RIGHTUP, 0, 0, 0, 0); break; case ClickType.doubleClick: mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); Thread.Sleep(100); mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); break; } } //執行設置文本事件 private void SetText(EventClass eventData) { SendKeys.SendWait(eventData.Text); } /// <summary> /// 錄制 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnRecord_Click(object sender, EventArgs e) { CancelTask = new CancellationTokenSource(); RegistKey(true); EnableControl(false); AddLog("正在錄制..."); KeyPress += new KeyPressEventHandler(Click_KeyPress); } /// <summary> /// 執行 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnRun_Click(object sender, EventArgs e) { int interval = string.IsNullOrEmpty(txtInterval.Text) ? 0 : Convert.ToInt32(txtInterval.Text); int count = string.IsNullOrEmpty(txtCount.Text) ? 1 : Convert.ToInt32(txtCount.Text); Task.Factory.StartNew(() => { for (int i = 0; i < count; i++) { foreach (EventClass current in listEvent) { if (current.clickType == ClickType.SendKeys) { SetText(current); } else { MouseClick(current); } Thread.Sleep(interval * 1000); } AddLog("第" + (i + 1) + "次執行結束"); try { CancelTask.Token.ThrowIfCancellationRequested(); } catch (System.OperationCanceledException ex) { AddLog("已手動結束執行"); return; } } AddLog("自動執行結束..."); KeyPress += new KeyPressEventHandler(Click_KeyPress); }, CancelTask.Token); } private void Click_KeyPress(object sender, KeyPressEventArgs e) { string logStr = string.Empty; ClickType clickType = ClickType.leftClick; string key = e.KeyChar.ToString().ToUpper(); switch (key) { case "1": clickType = ClickType.leftClick; logStr = "點擊瞭鼠標左鍵"; break; case "2": clickType = ClickType.rightClick; logStr = "點擊瞭鼠標右鍵"; break; case "3": clickType = ClickType.doubleClick; logStr = "雙擊瞭鼠標左鍵"; break; case "4": clickType = ClickType.SendKeys; logStr = "發送瞭文本:" + txtValue.Text; break; default: logStr = "按下瞭" + e.KeyChar + "鍵,無效!"; break; } int x = Cursor.Position.X; int y = Cursor.Position.Y; AddLog("在 (" + x + "," + y + ") 位置," + logStr); EventClass eventClass = new EventClass(); eventClass.clickType = clickType; eventClass.X = x; eventClass.Y = y; if (!string.IsNullOrEmpty(txtValue.Text)) { eventClass.Text = txtValue.Text; } listEvent.Add(eventClass); }
實現效果
到此這篇關於C#模擬實現鼠標自動點擊與消息發送功能的文章就介紹到這瞭,更多相關C#鼠標點擊 消息發送內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- C#實現全局快捷鍵功能
- C#實現十六進制與十進制相互轉換以及及不同進制表示
- C#實現字符串進制轉換方法匯總
- C# 字符串與unicode互相轉換實戰案例
- C# string轉換為幾種不同編碼的Byte[]的問題解讀