当前位置: 首页 > news >正文

STM32 CubeMX USB_(HID 鼠标和键盘)

STM32 CubeMX


STM32 CubeMX USB_HID(HID 鼠标和键盘)

  • STM32 CubeMX
    • 前言
  • 《鼠标小节》
  • 一、STM32 CubeMX 设置
    • USB时钟设置
    • USB使能
    • UBS功能选择
  • 二、代码部分
    • 添加代码
    • 鼠标发送给PC的数据解析
    • 实验效果
  • 《键盘小节》
    • STM32 CubeMX 设置(同上)
    • 代码部分



前言

STM32 CubeMX 自动生成的USB_HID是鼠标类型的:键盘类型要做一点小修改;

《鼠标小节》

一、STM32 CubeMX 设置

USB时钟设置

在这里插入图片描述

USB使能

在这里插入图片描述

UBS功能选择

二、代码部分

在这里插入图片描述
在这里插入图片描述

添加代码

 
#include "usbd_hid.h"extern USBD_HandleTypeDef hUsbDeviceFS;uint8_t HID_biff[4];
        HAL_Delay(1000);USBD_HID_SendReport(&hUsbDeviceFS,HID_Mouse_buff,4);//按下鼠标右键HID_Mouse_buff[0]=0x08;//恒为1HID_Mouse_buff[1]=10;//X+1HID_Mouse_buff[2]=10;//Y+1HID_Mouse_buff[3]=0; //鼠标滑轮

鼠标发送给PC的数据解析

数据格式
鼠标发送给PC的数据每次4个字节
BYTE1 BYTE2 BYTE3 BYTE4
定义分别是:
BYTE1 –
|–bit7: 1 表示 Y 坐标的变化量超出-256 ~ 255的范围,0表示没有溢出
|–bit6: 1 表示 X 坐标的变化量超出-256 ~ 255的范围,0表示没有溢出
|–bit5: Y 坐标变化的符号位,1表示负数,即鼠标向下移动
|–bit4: X 坐标变化的符号位,1表示负数,即鼠标向左移动
|–bit3: 恒为1
|–bit2: 1表示中键按下
|–bit1: 1表示右键按下
|–bit0: 1表示左键按下
BYTE2 – X坐标变化量,与byte的bit4组成9位符号数,负数表示向左移,正数表右移。用补码表示变化量
BYTE3 – Y坐标变化量,与byte的bit5组成9位符号数,负数表示向下移,正数表上移。用补码表示变化量
BYTE4 – 滚轮变化。BYTE1高5位是可以不用关注的,一般这5bit 在HID描述符中都是作为填充位使用,置0即可。

实验效果

请添加图片描述

《键盘小节》

STM32 CubeMX 设置(同上)

代码部分

参考:
STM32CubeMX学习笔记
USB鼠标HID描述符以及数据格式

http://www.lryc.cn/news/111184.html

相关文章:

  • [PM]敏捷开发之Scrum总结
  • 大数据Flink(五十七):Yarn集群环境(生产推荐)
  • web集群学习:源码安装nginx配置启动服务脚本
  • LNMP
  • Python网络爬虫在信息采集中的应用及教程
  • 云主机测试Flink磁盘满问题解决
  • iOS开发-NSOperationQueue实现上传图片队列
  • 通过 CCIP 构建跨链应用(5 个案例)
  • 基于 yolov8 的人体姿态评估
  • 计算机视觉(六)图像分类
  • 解决:vue通过params传参刷新页面参数丢失问题以及实现vue路由可选参数的解决办法
  • 将postman接口导出的json转换为markdown
  • 教您一招解决找素材困难好的方法
  • python_PyQt5开发验证K线视觉想法工具V1.2_批量验证
  • 应急响应-web后门(中间件)的排查思路
  • XML 学习笔记 7:XSD
  • neo4j图数据库基础操作命令(CQL语法)
  • vscode无法连接远程服务器的可能原因:远程服务器磁盘爆了
  • SSL 证书过期巡检脚本 (Python 版)
  • 从0到1自学网络安全(黑客)【附学习路线图+配套搭建资源】
  • Michael.W基于Foundry精读Openzeppelin第20期——EnumerableMap.sol
  • 深入探索二叉树:应用、计算和遍历
  • 关于 1 + 1 = 2 的证明
  • 【C++】——内存管理
  • Jmeter录制HTTPS脚本
  • Linux 的Centos 7 安装 启动 Google Chrome
  • DNS WEB HTTP
  • 微信小程序animation动画,微信小程序animation动画无限循环播放
  • node.js
  • 【微信小程序创作之路】- 小程序远程数据请求、获取个人信息