这是一个 Python 包,其提供了对 CH9329 芯片的快捷通信方法
CH9329 芯片是由沁恒生产的一种串口转HID键盘鼠标芯片。它可以将上位机发送的串口数据转换为标准的USB键鼠设备信号,并将其发送给下位机,从而实现硬件级别的键鼠模拟。
导入包:
pip install ch9329Comm
注意!
在开始之前,您需要自行将 CH9329 芯片参数修改为:波特率:
115200
、串口包间隔:1ms
,否则某些方法不能正常工作。
(可以参考协议文档向串口发送数据包修改,也可以使用厂商的上位机软件修改,注意修改配置后在下一次上电时才会生效)
keyboard
模块的 DataComm
类中提供了向串口快速发送键盘数据包的方法:send_data()
语法:
ch9329Comm.keyboard.DataComm()
参数:无
返回:
- 一个 keyboard 模块 DataComm 类的实例
示例:
import ch9329Comm
keyboard = ch9329Comm.keyboard.DataComm()
语法:
send_data(data, [ctrl], [port])
参数:
- data (str): 要发送的按键信息,一次最多发送6个按键信息。
按键信息包含在字典中,默认仅包含了26个字母按键,比如按键C
对应CC
,如需要使用其它按键可以自行根据协议文档扩充 - ctrl (str): 可选,要发送的控制键,不填则默认不按下控制键。
- port (serial): 可选,要发送数据的串口,如果不填则默认为serial。
返回:
- bool: 如果数据成功发送,则为True,否则为False。
示例:
import serial
import ch9329Comm
serial.ser = serial.Serial('COM4', 115200) # 开启串口
# 键盘输出helloworld
keyboard = ch9329Comm.keyboard.DataComm()
keyboard.send_data('HHEELLLLOO') # 按下HELLO
keyboard.release() # 松开
keyboard.send_data('WWOORRLLDD') # 按下WORLD
keyboard.release() # 松开
serial.ser.close() # 关闭串口
注意! 无法同时按下多个普通按键,后按下的按键会覆盖原来的按键,哪怕是一次发送多个按键
控制键的可选值:
可选值 | 含义 |
---|---|
R_WIN | 右Winodws键 |
R_ALT | 右Alt键 |
R_SHIFT | 右Shift键 |
R_CTRL | 右Ctrl键 |
L_WIN | 左Winodws键 |
L_ALT | 左Alt键 |
L_SHIFT | 左Shift键 |
L_CTRL | 左Ctrl键 |
你也可以传入一个16进制的数值以发送组合键,形如0x00
,关于数值的定义与通信协议文档中相同
示例:
import serial
import ch9329Comm
serial.ser = serial.Serial('COM4', 115200) # 开启串口
keyboard = ch9329Comm.keyboard.DataComm()
keyboard.send_data('',0x03) # 同时按下ctrl+shift
keyboard.release() # 松开
serial.ser.close() # 关闭串口
mouse
模块的 DataComm
类中提供了向串口快速发送鼠标数据包的四个方法:
-
send_data_absolute()
:绝对移动,将鼠标闪现到相对于屏幕左上角距离x,y的位置 -
send_data_relatively()
:相对移动,将鼠标闪现到以鼠标当前位置为原点的坐标系上点(x,y)的位置 -
move_to_basic()
:基于send_data_relatively()
,其会自动生成随机路径,将鼠标指针沿轨迹移动到点(x,y)的位置 -
move_to()
(推荐):对于move_to()
的改进方法,添加了自动误差校正
语法:
ch9329Comm.mouse.DataComm([screen_width],[screen_height])
参数:
- screen_width:可选,屏幕的宽度,默认为3840
- screen_height:可选,屏幕的高度,默认为2160
返回:
- 一个 mouse 模块 DataComm 类的实例
示例:
import ch9329Comm
mouse = ch9329Comm.mouse.DataComm(1920,1080) # 屏幕分辨率为1920*1080
将鼠标闪现到相对于屏幕左上角距离x,y的位置
语法:
send_data_absolute(x, y, [ctrl], [port])
参数:
- x (int):鼠标光标的x坐标。
- y (int):鼠标光标的y坐标。
- ctrl (str):可选,按下的控制键,如果省略则默认为NU,即只移动鼠标,不按下任何按键。
注意!这表示按住鼠标控制键并移动鼠标,
- port (serial):可选,要发送数据的串口,如果不填则默认为serial。
返回:
- 如果成功发送数据,则返回True,否则返回False。
示例:
import serial
import ch9329Comm
serial.ser = serial.Serial('COM4', 115200) # 开启串口
mouse = ch9329Comm.mouse.DataComm()
mouse.send_data_absolute(100, 100) # (绝对)鼠标移动到屏幕的左上100*100的位置
serial.ser.close() # 关闭串口
控制键的可选值:
可选值 | 含义 |
---|---|
NU | |
LE | 左键 |
RI | 右键 |
CE | 中键 |
你也可以传入一个16进制的数值以发送组合键,形如0x00
,关于数值的定义与通信协议文档中相同
将鼠标闪现到以鼠标当前位置为原点的坐标系上点(x,y)的位置
语法:
send_data_relatively(x, y, [ctrl], [port])
参数:
- x (int):相对的x坐标。
- y (int):相对的y坐标。
- ctrl (str):可选,按下的控制键,如果省略则默认为NU,即只移动鼠标,不按下任何按键。
注意!这表示按住鼠标控制键并移动鼠标,
- port (Serial):可选,要发送数据的串口,如果不填则默认为serial。
返回:
- bool:如果成功发送数据,则返回True,否则返回False。
示例:
import serial
import ch9329Comm
serial.ser = serial.Serial('COM4', 115200) # 开启串口
# (相对)鼠标右移100px 下移100px并单击左键
mouse = ch9329Comm.mouse.DataComm()
mouse.send_data_relatively(100, -100)
mouse.click() # 单击左键
serial.ser.close() # 关闭串口
控制键的可选值:
可选值 | 含义 |
---|---|
NU | |
LE | 左键 |
RI | 右键 |
CE | 中键 |
你也可以传入一个16进制的数值以发送组合键,形如0x00
,关于数值的定义与通信协议文档中相同
将鼠标沿随机生成的轨迹移动到以鼠标当前位置为原点的坐标系上点(x,y)的位置
其会调用BezierTrajectory
类中的方法,自动生成随机路径,并将路径分解为步长 0 ~ 2px 的路径点的集合,
其以每 1.6ms 一个的频率发送数据包,指针每1.6ms最多会在屏幕上移动两个像素点(大部分时间只会移动1个像素点)
语法:
move_to_basic(x, y, ctrl, port)
参数:
- x:目标的x坐标。
- y:目标的y坐标。
- ctrl:鼠标移动的控制字符(默认为空字符串)。
- port:串口(默认为serial)。
返回:
- None
控制键的可选值:
可选值 | 含义 |
---|---|
NU | |
LE | 左键 |
RI | 右键 |
CE | 中键 |
你也可以传入一个16进制的数值以发送组合键,形如0x00
,关于数值的定义与通信协议文档中相同
将鼠标沿随机生成的轨迹移动到以鼠标当前位置为原点的坐标系上点(x,y)的位置
其是对于 move_to_basic()
的改进方法,添加了自动误差校正
注意初始化:
第一次调用该方法时,其会自动在项目路径下新建
\corrector\information.json
文件,然后自动多次调用
check_difference_ratio()
方法,检查当前环境中鼠标指针在屏幕上的移动理论值和实际值之间的差异,并根据差异的平均值对目标(x,y)进行修正,在此期间鼠标指针会自动在屏幕上跳跃或者移动,请不要触碰你的实际物理鼠标以免影响检查。
其会将在修正值存储在
\corrector\information.json
中,以后调用该方法时会自动到文件中读取修正值,如果需要重新生成校正值,请手动删除\corrector\information.json
文件
语法:
move_to(dest_x, dest_y, ctrl, port)
参数:
- dest_x (int):目标的x坐标。
- dest_y (int):目标的y坐标。
- ctrl (str, optional):要发送到串口的控制字符。默认为''。
- port (serial, optional):要使用的串口。默认为serial。
返回:
- difference_ratio:鼠标指针实际移动量与期待移动量的比值(0 ~ 1)
示例:
import serial
import ch9329Comm
serial.ser = serial.Serial('COM4', 115200) # 开启串口
mouse = ch9329Comm.mouse.DataComm()
mouse.move_to(-230,-480) # 生成路径并沿路径移动到(-230,-480)
serial.ser.close() # 关闭串口
控制键的可选值:
可选值 | 含义 |
---|---|
NU | |
LE | 左键 |
RI | 右键 |
CE | 中键 |
你也可以传入一个16进制的数值以发送组合键,形如0x00
,关于数值的定义与通信协议文档中相同