首页 > 编程语言 >C++模拟真人动态生成鼠标滑动路径

C++模拟真人动态生成鼠标滑动路径

时间:2024-11-03 10:30:23浏览次数:3  
标签:轨迹 鼠标 C++ delay SN time 滑动 800

一.简介

鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。

鼠标轨迹算法的底层实现采用C/C++语言,原因在于C/C++提供了高性能的执行能力和直接访问操作系统底层资源的能力。

鼠标轨迹算法具有以下优势:

  • 模拟人工轨迹:算法能够模拟出非贝塞尔曲线的自然鼠标移动,避免了机械式的直线移动。
  • 适当的停顿/加速/减速:算法能够根据需要模拟出鼠标的停顿、加速和减速,使得轨迹更加真实。
  • 随机轨迹:在固定两点间,算法能够生成不同的随机轨迹,增加了轨迹的不可预测性。

二.应用场景

  • 游戏鼠标轨迹检测(检测能过无畏fps类型、传奇、梦幻等游戏,已经在游戏中验证)
  • 滑块拖动验证
  • 部分网页鼠标轨迹检测

三.支持多种编程语言

1.C++头文件

  1. /******************************************************************************************/
  2. @SDK功能描述:C++鼠标轨迹
  3. /******************************************************************************************/
  4. #ifndef _SN_SDK_H__
  5. #define _SN_SDK_H__
  6. #include <windows.h>
  7. //返回参数
  8. typedef struct SN_RESULT {
  9. int code; //错误码,如果为 0 表示成功,否则表示错误号
  10. char message[4096]; //错误信息,如果为 "OK" 表示成功,否则返回错误信息
  11. }SN_RESULT;
  12. //坐标参数
  13. typedef struct SN_POINT
  14. {
  15. int x; //屏幕坐标,左上角(0,0),右下角(1920,1080 - 以实际屏幕为准)
  16. int y; //屏幕坐标,左上角(0,0),右下角(1920,1080 - 以实际屏幕为准)
  17. }SN_POINT;
  18. //轨迹参数
  19. typedef struct SN_POINT_PARAMS
  20. {
  21. struct SN_POINT point;//屏幕坐标,左上角(0,0),右下角(1920,1080 - 以实际屏幕为准)
  22. int delayTime; //延时时间(单位:毫秒),仅供参考
  23. }SN_POINT_PARAMS;
  24. /*创建句柄
  25. *
  26. * 参数:
  27. * [in] szKey: 卡密
  28. * [out] pResult: 返回错误信息,参数pResult.code(错误码)如果为 0 表示成功,否则表示错误号;
  29. *
  30. * 返回值:成功返回句柄,失败返回NULL
  31. *
  32. */
  33. HANDLE WINAPI apiSNCreateHandle(char* szKey, SN_RESULT* pResult);
  34. /*获取鼠标移动轨迹
  35. *
  36. * 参数:
  37. * [in] handle: 句柄(通过调用apiSNCreateHandle得到)
  38. * [in] startPoint: 开始坐标,左上角(0,0),右下角(1920,1080 - 以实际屏幕为准)
  39. * [in] endPoint: 结束坐标,左上角(0,0),右下角(1920,1080 - 以实际屏幕为准)
  40. * [out] points: 轨迹数组,如果数组中元素 point 出现(-1,-1),表示鼠标轨迹结束
  41. *
  42. * 返回值:返回参数SN_RESULT.code(错误码)如果为 0 表示成功,否则表示错误号;
  43. *
  44. */
  45. SN_RESULT WINAPI apiSNMouseMove(HANDLE handle, SN_POINT startPoint, SN_POINT endPoint, SN_POINT_PARAMS* points);
  46. /*获取版本号
  47. *
  48. * 参数:
  49. * [in] handle: 句柄(通过调用apiSNCreateHandle得到)
  50. * [out] szVersion: 版本号
  51. *
  52. * 返回值:返回参数SN_RESULT.code(错误码)如果为 0 表示成功,否则表示错误号;
  53. *
  54. */
  55. SN_RESULT WINAPI apiSNGetVersion(HANDLE handle, char* szVersion);
  56. /*获取错误信息
  57. *
  58. * 参数:
  59. * [in] handle: 句柄(通过调用apiSNCreateHandle得到)
  60. *
  61. * 返回值:返回参数SN_RESULT.code(错误码)如果为 0 表示成功,否则表示错误号;
  62. *
  63. */
  64. SN_RESULT WINAPI apiSNGetError(HANDLE handle);
  65. /*释放句柄(内存)
  66. *
  67. * 参数:
  68. * [in] handle: 句柄(通过调用apiSNCreateHandle得到)
  69. *
  70. * 返回值:返回参数SN_RESULT.code(错误码)如果为 0 表示成功,否则表示错误号;
  71. *
  72. */
  73. SN_RESULT WINAPI apiSNDestroyHandle(HANDLE handle);
  74. #endif // !_SN_SDK_H__

2.其他编程语言

为了易于集成和使用,我们将鼠标轨迹算法封装为DLL(动态链接库)。这种封装方式不仅保留了算法的性能优势,还提供了跨平台和跨语言的兼容性,目前支持编程语言如下:

  • C++
  • Python
  • 易语言

推算轨迹算法耗时均为毫秒级,<= 5ms ,速度超快,fps类型游戏完全无压力!

3.鼠标轨迹API调用流程图

注意:如果是多线程,每个线程都需要通过apiSNCreateHandle创建HANDLE句柄,这样才能多个线程互不影响

4.加载C++鼠标轨迹dll接口

  1. /****************************************************************************************/
  2. @SDK功能描述:鼠标轨迹
  3. /******************************************************************************************/
  4. //
  5. #include <iostream>
  6. #include "include/SNSDK.h"
  7. #pragma comment(lib,"./dll/x86/SNSDK.lib")
  8. int main()
  9. {
  10. SN_RESULT pResult = { 0 };
  11. char* pKey = (char*)"SNKJaURwbfuhcaQaCMJVhdByPZMVsZdqRUMjfWrxY1A5";
  12. //1.创建句柄
  13. HANDLE pHandle = apiSNCreateHandle(pKey,&pResult);
  14. if (!pHandle)
  15. {
  16. printf("error code:%d message:%s \n",pResult.code,pResult.message);
  17. return -__LINE__;
  18. }
  19. //2.获取轨迹
  20. SN_POINT startPoint = { 100,100 }; //开始坐标
  21. SN_POINT endPoint = { 800,800 }; //结束坐标
  22. SN_POINT_PARAMS track[4096] = { 0 };//轨迹
  23. pResult = apiSNMouseMove(pHandle, startPoint, endPoint, track);
  24. if (pResult.code != 0)
  25. {
  26. printf("error code:%d message:%s \n", pResult.code, pResult.message);
  27. return -__LINE__;
  28. }
  29. //3.鼠标根据轨迹移动,轨迹最后一个点(-1,-1)
  30. for (int i = 0; i < 4096; i++)
  31. {
  32. struct SN_POINT point = track[i].point;
  33. if (point.x <= 0 && point.y <= 0)//轨迹最后一个点(-1,-1)
  34. break;
  35. printf("x:%d y:%d delay_time:%d \n", point.x, point.y, track[i].delayTime);
  36. }
  37. //4.释放内存
  38. pResult = apiSNDestroyHandle(pHandle);
  39. return 1;
  40. }
  41. /*
  42. x:100 y:100 delay_time:0
  43. x:100 y:98 delay_time:10
  44. x:103 y:98 delay_time:15
  45. x:111 y:98 delay_time:16
  46. x:116 y:101 delay_time:15
  47. x:122 y:104 delay_time:2
  48. x:129 y:107 delay_time:13
  49. x:135 y:109 delay_time:2
  50. x:144 y:112 delay_time:14
  51. x:155 y:117 delay_time:2
  52. x:167 y:123 delay_time:14
  53. x:180 y:128 delay_time:2
  54. x:193 y:134 delay_time:13
  55. x:209 y:138 delay_time:2
  56. x:225 y:144 delay_time:13
  57. x:238 y:149 delay_time:5
  58. x:254 y:157 delay_time:10
  59. x:269 y:162 delay_time:5
  60. x:282 y:168 delay_time:11
  61. x:298 y:175 delay_time:5
  62. x:311 y:180 delay_time:10
  63. x:326 y:185 delay_time:6
  64. x:341 y:193 delay_time:9
  65. x:369 y:211 delay_time:15
  66. x:396 y:231 delay_time:16
  67. x:419 y:251 delay_time:16
  68. x:442 y:270 delay_time:16
  69. x:461 y:285 delay_time:17
  70. x:481 y:300 delay_time:15
  71. x:491 y:311 delay_time:15
  72. x:502 y:319 delay_time:2
  73. x:513 y:329 delay_time:14
  74. x:523 y:343 delay_time:2
  75. x:535 y:355 delay_time:14
  76. x:546 y:369 delay_time:0
  77. x:558 y:383 delay_time:15
  78. x:570 y:397 delay_time:2
  79. x:582 y:411 delay_time:13
  80. x:596 y:427 delay_time:2
  81. x:608 y:443 delay_time:14
  82. x:620 y:459 delay_time:5
  83. x:633 y:476 delay_time:10
  84. x:645 y:490 delay_time:5
  85. x:656 y:503 delay_time:11
  86. x:666 y:515 delay_time:5
  87. x:675 y:527 delay_time:11
  88. x:684 y:538 delay_time:5
  89. x:694 y:551 delay_time:11
  90. x:702 y:565 delay_time:5
  91. x:710 y:577 delay_time:11
  92. x:716 y:588 delay_time:5
  93. x:723 y:598 delay_time:11
  94. x:728 y:606 delay_time:5
  95. x:733 y:615 delay_time:11
  96. x:738 y:622 delay_time:5
  97. x:743 y:631 delay_time:11
  98. x:747 y:637 delay_time:5
  99. x:750 y:644 delay_time:11
  100. x:753 y:652 delay_time:5
  101. x:756 y:659 delay_time:10
  102. x:759 y:666 delay_time:5
  103. x:761 y:673 delay_time:11
  104. x:764 y:680 delay_time:5
  105. x:766 y:687 delay_time:11
  106. x:768 y:694 delay_time:5
  107. x:769 y:701 delay_time:10
  108. x:771 y:708 delay_time:5
  109. x:772 y:714 delay_time:11
  110. x:773 y:722 delay_time:5
  111. x:774 y:729 delay_time:10
  112. x:777 y:743 delay_time:16
  113. x:778 y:755 delay_time:15
  114. x:778 y:764 delay_time:16
  115. x:780 y:775 delay_time:16
  116. x:781 y:784 delay_time:16
  117. x:781 y:785 delay_time:15
  118. x:781 y:789 delay_time:2
  119. x:781 y:790 delay_time:13
  120. x:781 y:792 delay_time:2
  121. x:782 y:796 delay_time:14
  122. x:782 y:796 delay_time:2
  123. x:782 y:797 delay_time:14
  124. x:782 y:798 delay_time:15
  125. x:782 y:800 delay_time:311
  126. x:784 y:800 delay_time:16
  127. x:784 y:800 delay_time:5
  128. x:785 y:800 delay_time:10
  129. x:786 y:800 delay_time:5
  130. x:786 y:800 delay_time:11
  131. x:788 y:800 delay_time:6
  132. x:789 y:800 delay_time:9
  133. x:790 y:800 delay_time:5
  134. x:791 y:800 delay_time:10
  135. x:793 y:800 delay_time:16
  136. x:795 y:800 delay_time:16
  137. x:796 y:800 delay_time:15
  138. x:797 y:800 delay_time:15
  139. x:797 y:800 delay_time:2
  140. x:798 y:800 delay_time:15
  141. x:798 y:800 delay_time:30
  142. x:799 y:800 delay_time:15
  143. x:799 y:800 delay_time:15
  144. */
  145. ————————————————

5.云盘源码下载

云盘目录介绍:

demo - 包含各种编程语言的demo

dll - 分别是x86和x64平台所需要的dll/lib/h文件

windows 鼠标轨迹测试工具 - exe测试鼠标轨迹效果( demo 中的 c++ 工程编译后的exe可执行文件)

四.效果演示

1.开始坐标为(100,100),结束坐标为(800,800),通过调用接口获得 4 条鼠标轨迹

2.开始坐标为(1000,100),结束坐标为(800,800),通过调用接口获得 2 条鼠标轨迹

五.常见问题

1.是否支持多线程

支持

2.如何使用多线程

参考前面的《2.鼠标轨迹API调用流程图》,多线程和单线程类似;如果是多线程,那么每个线程都需要通过apiSNCreateHandle创建HANDLE句柄,这样才能多个线程互不影响

六.更新日志

  • 2024.09.28 新增易语言demo
  • 2024.09.21 修复部分水平/垂直轨迹出现负数的情况
  • 2024.09.19 优化部分轨迹延迟时间为0的情况(可能会造成鼠标瞬移)
  • 2024.08.20 优化部分轨迹可能出现负数的问题
  • 2024.07.15 优化水平/垂直轨迹
  • 2024.06.25 新增错误日志信息
  • 2024.06.06 python 模拟人工鼠标轨迹demo
  • 2024.02.06 c++ 模拟人工鼠标轨迹demo

标签:轨迹,鼠标,C++,delay,SN,time,滑动,800
From: https://www.cnblogs.com/shuopython/p/18522987

相关文章

  • 鼠标打字的背后,隐藏着一个感人的故事
    感谢所有善良的人‍转载声明原文:有什么软件官方已经停更了或者公司已经倒闭了,但是你还在用并且觉得很好用的?-黄亮的回答-知乎优化了下排版,改正了两个错别字,以下是正文:正文2019年,有一个叫方瑜,网名冷敏寒子夜的女孩在网上寻找一个极为冷僻的软件输入法:“鼠标打字·高级版......
  • 基于SpringBoot乡村书屋小程序设计与实现--31881(免费领源码)可做计算机毕业设计JAVA、P
    摘要随着信息技术的快速发展和互联网的广泛普及,数字化服务的需求不断增长,乡村书屋作为传统的文化服务机构也需要适应这一变革。本研究将使用Java开发技术,通过springboot作为框架,结合微信小程序,和MySQL作为数据存储的技术,开发一套功能齐备可移动的乡村书屋小程序,旨在提升乡......
  • 【C++】类与对象(下)
     1.再探构造函数 •之前我们实现构造函数时,初始化成员变量主要使⽤函数体内赋值,构造函数初始化还有⼀种方式,就是初始化列表,初始化列表的使⽤⽅式是以⼀个冒号开始,接着是⼀个以逗号分隔的数据成员列表,每个"成员变量"后⾯跟⼀个放在括号中的初始值或表达式。 •每个成员......
  • C和C++的字符串有什么不同?
    一、C语言中字符串的存储方式C语言没有专门用于存储字符串的变量类型,字符串都被存储在char类型的数组中,且以字符\0结尾;字符数组存储在C语言中,字符串常常以字符数组的形式进行存储。例如:charstr[]="Hello";这里定义了一个字符数组str,编译器会自动在字符串......
  • C++优选算法 分治-快排
    一、基本思想快速排序采用分治法策略,将一个大数组(或子数组)分为两个小数组,然后递归地对这两个小数组进行排序。其基本思想可以概括为“分解、解决、合并”三个步骤:分解:将原问题(即待排序的数组)分解为若干个规模较小、相互独立且与原问题形式相同的子问题(即子数组)。解决:若子问题......
  • C++ 手撕--共享式智能指针(shared_ptr)的简单实现
    C++手撕--共享式智能指针(shared_ptr)的简单实现共享式智能指针(shared_ptr):#include<iostream>#include<mutex>usingnamespacestd;template<typenameT>classShared_ptr{private:T*ptr;int*ref_count;std::mutex*mtx;voidrelease(){......
  • C++ 创建动态二维数组
    方法一:使用vector容器1.创建整数型二维数组先建列,再建行,先创建一个包含m个元素的向量a,再创建二维向量arr,通过push_back将一维向量作为行添加到二维向量中#include<iostream>#include<vector>usingnamespacestd;intmain(){ //创建一个包含m个元素,每个元素初始值为0......
  • 打卡信奥刷题(159)用C++工具信奥P1416[普及组/提高] 攻击火星
    攻击火星题目描述一群外星人将要攻击火星。火星的地图是一个nnn个点的无向图。这伙外星人将按照如下方法入侵,先攻击度为0......
  • 【C++动态规划】有效括号的嵌套深度
    本文涉及知识点C++动态规划LeetCode1111.有效括号的嵌套深度有效括号字符串定义:对于每个左括号,都能找到与之对应的右括号,反之亦然。详情参见题末「有效括号字符串」部分。嵌套深度depth定义:即有效括号字符串嵌套的层数,depth(A)表示有效括号字符串A的嵌套深度。详......