3 个不稳定版本

0.2.0 2024年5月11日
0.1.1 2023年3月2日
0.1.0 2022年10月2日

#248 in Unix APIs

MIT 许可证

79KB
1.5K SLoC

Rust 中 HID Gadget 模拟

github crate docs MIT CI

Rust crate,用于与 Linux HID Gadget 设备(/dev/hidgX)进行接口交互。

由于所有功能都依赖于 Linux 函数调用,因此此 crate 仅适用于 Linux 系统。

Crates

  • hidg-core - 核心抽象和低级接口(不适用于最终用户)
  • hidg - 仅支持同步操作的标准接口
  • tokio-hidg - 为 tokio 运行时提供的异步接口
  • async-hidg - 为其他运行时提供的异步接口

功能

使用示例

键盘输入模拟

use hidg::{Class, Device, Keyboard, Key, Led, StateChange};

fn main() -> std::io::Result<()> {
    let mut device = Device::<Keyboard>::open(0)?; // open device

    // Create input report
    let mut input = Keyboard.input();

    // Press left ctrl modifier
    input.press_key(Key::LeftCtrl);

    // Press key 'A'
    input.press_key(Key::A);

    // Send input report
    device.input(&input)?;

    // Get pressed keys
    println!("Keys: {:?}", input.pressed().collect::<Vec<Key>>());

    // Release left ctrl modifier
    input.release_key(Key::LeftCtrl);

    // Release key 'A'
    input.release_key(Key::A);

    // Send input report
    device.input(&input)?;

    // Create output report
    let mut output = Keyboard.output();

    // Receive output report
    device.output(&mut output)?;

    // Print lit LEDs
    println!("LEDs: {:?}", output.lit().collect::<Vec<Led>>());

    Ok(())
}

鼠标输入模拟

use hidg::{Button, Class, Device, Mouse, StateChange, ValueChange};

fn main() -> std::io::Result<()> {
    let mut device = Device::<Mouse>::open("hidg0")?; // open device

    // Create input report
    let mut input = Mouse.input();

    // Press primary button
    input.press_button(Button::Primary);

    // Update pointer coordinates
    input.change_pointer((150, 50), false);

    // Send input report
    device.input(&input)?;

    // Move pointer relatively
    input.change_pointer((70, -30), true);

    // Get pressed buttons
    println!("Buttons: {:?}", input.pressed().collect::<Vec<Button>>());

    // Release primary button
    input.release_button(Button::Primary);

    // Send input report
    device.input(&input)?;

    Ok(())
}

依赖项

~115–360KB